本文實例講述了C#實現(xiàn)把圖片轉(zhuǎn)換成二進制以及把二進制轉(zhuǎn)換成圖片的方法。分享給大家供大家參考,具體如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
private void button1_Click( object sender, EventArgs e) { string path = this .textBox1.Text; byte [] imgBytesIn = SaveImage(path); ShowImgByByte(imgBytesIn); //Parameters.Add("@Photo", SqlDbType.Binary).Value = imgBytesIn; } //將圖片以二進制流 public byte [] SaveImage(String path) { FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read); //將圖片以文件流的形式進行保存 BinaryReader br = new BinaryReader(fs); byte [] imgBytesIn = br.ReadBytes(( int )fs.Length); //將流讀入到字節(jié)數(shù)組中 return imgBytesIn; } //現(xiàn)實二進制流代表的圖片 public void ShowImgByByte( byte [] imgBytesIn) { MemoryStream ms = new MemoryStream(imgBytesIn); pictureBox1.Image = Image.FromStream(ms); } |
二、將圖片保存到數(shù)據(jù)庫中,并從數(shù)據(jù)庫中讀取:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
#region 將圖片從數(shù)據(jù)庫中讀取 /// <summary> /// 將圖片從數(shù)據(jù)庫中讀取 /// </summary> /// <param name="xs_ID">要讀取圖片的學(xué)號</param> /// <param name="ph">pictureBox1控件名</param> public void get_photo( string xs_ID, PictureBox ph) //將圖片從數(shù)據(jù)庫中讀取 { byte [] imagebytes = null ; getcon(); SqlCommand con = new SqlCommand( "select * from S_jiben where S_num='" + xs_ID + "'" , link); SqlDataReader dr = con.ExecuteReader(); while (dr.Read()) { imagebytes =( byte [])dr.GetValue(18); } dr.Close(); con_close(); MemoryStream ms = new MemoryStream(imagebytes); Bitmap bmpt = new Bitmap(ms); ph.Image = bmpt; } #endregion #region public void SaveImage( string MID, OpenFileDialog openF) //將圖片以二進制存入數(shù)據(jù)庫中 { string strimg = openF.FileName.ToString(); //記錄圖片的所在路徑 FileStream fs = new FileStream(strimg, FileMode.Open, FileAccess.Read); //將圖片以文件流的形式進行保存 BinaryReader br = new BinaryReader(fs); byte [] imgBytesIn = br.ReadBytes(( int )fs.Length); //將流讀入到字節(jié)數(shù)組中 getcon(); StringBuilder strSql = new StringBuilder(); strSql.Append( "update S_jiben Set xs_photo=@Photo where S_num=" + MID); SqlCommand cmd = new SqlCommand(strSql.ToString(), link); cmd.Parameters.Add( "@Photo" , SqlDbType.Binary).Value = imgBytesIn; cmd.ExecuteNonQuery(); con_close(); } #endregion |
希望本文所述對大家C#程序設(shè)計有所幫助。