二进制文件图形转换工具

好久没有写文章 ,今天刚好有点空就把我写的一个小工具分享一下吧,就是把数据库中的存储的二进制图形文件转换成直观的JPEG 图像,并有序的保存起来。

技术核心:

   1、使用多线程操作,委托;

   2、有完美的进度条和相关揭示;

   3、有序存储图片;

软件截图:

 

 

程序代码:

  一、数据库创建

 [UserImage] 表数据源表  用于存储图像(为二进制文件)

CREATE TABLE [dbo].[UserImage](
	[vcEmployeeID] [char](10) NOT NULL,
	[vcName] [varchar](200) NULL,
	[vcAccount] [varchar](30) NULL,
	[pWorkPicture] [image] NULL,
	[dOperatorDate] [datetime] NULL,
 CONSTRAINT [PK_UserImage] PRIMARY KEY CLUSTERED 
(
	[vcEmployeeID] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

GO

[Users] 用户信息表 

CREATE TABLE [dbo].[Users](
[Key] [
int] IDENTITY(1,1) primary key NOT NULL,
[Name] [nvarchar](
256) NOT NULL,
[Nickname] [nvarchar](
256) NOT NULL,
[Type] [
int] NOT NULL,
[RegisterTime] [datetime] NOT NULL,
[HomePage] [nvarchar](
256) NULL,
[HeadIMG] [nvarchar](
512) NOT NULL,
[Remark] [text] NOT NULL
)

二、需求

要把UserImage 表的中 [pWorkPicture] 的二进制 文件转换图片并保存在 Users 表中对应的 [HeadIMG] 注意: [HeadIMG] 只能存储的是图片路径

三、程序实现(步骤)

  1、用VS2010 创建新项目 选择 C# ----- WINDOWS 应用程序;

  2、画出上面的图形界面;

  3、写代码实例; 

四、核心代码

  1、进度条、状态信息功能相关代码,为了避免程序进度条卡死,所以我使用了委托线程,代码如下

1 private delegate void DisPrcent(string txtvalue);
2
3 private void showDisPrcent(string txtvalue)
4 {
5 if (prcent.InvokeRequired)
6 {
7 prcent.Invoke(new DisPrcent(showDisPrcent), txtvalue);
8 }
9 else
10 {
11 string[] txt = txtvalue.Split(',');
12 double current = int.Parse(txt[0].ToString());
13 double Totel = int.Parse(txt[1].ToString());
14 prcent.Text = (current / Totel).ToString("0%");
15
16 }
17 }
18
19 private delegate void DisCenterContent(string content);
20 private void ShowDisCenterContent(string content)
21 {
22 if (CenterContent.InvokeRequired)
23 {
24 CenterContent.Invoke(new DisCenterContent(ShowDisCenterContent), content);
25 }
26 else
27 {
28 CenterContent.Text = content;
29 }
30 }
31
32
33 private delegate void dispProgStatus(ProState state);
34
35 private void showProgStatus(ProState state)
36 {
37 if (progressBar1.InvokeRequired)
38 {
39 progressBar1.Invoke(new dispProgStatus(showProgStatus), state);
40 }
41 else
42 {
43 int current = 0;
44 Int32.TryParse(state.MinCount.ToString(), out current);
45 int total = 0;
46 Int32.TryParse(state.MaxCount.ToString(), out total);
47 progressBar1.Value = current;
48 progressBar1.Maximum = total;
49 }
50
51 if (label_pro.InvokeRequired)
52 {
53 label_pro.Invoke(new dispProgStatus(showProgStatus), state);
54 }
55 else
56 {
57 label_pro.Text = state.ValueText;
58 }
59 }
60
61 private delegate void Buttonen(bool state);
62
63 private void ShowButtonen(bool state)
64 {
65 if (button4.InvokeRequired)
66 {
67 button4.Invoke(new Buttonen(ShowButtonen), state);
68 }
69 else
70 {
71 if (state == true)
72 {
73 button4.Enabled = true;
74
75 }
76 else
77 {
78 button4.Enabled = false;
79 }
80 }
81
82 if (SelectFod.InvokeRequired)
83 {
84 button4.Invoke(new Buttonen(ShowButtonen), state);
85 }
86 else
87 {
88 if (state == true)
89 {
90 SelectFod.Enabled = true;
91 }
92 else
93 {
94 SelectFod.Enabled = false;
95 }
96 }
97
98 if (FileUrl.InvokeRequired)
99 {
100 FileUrl.Invoke(new Buttonen(ShowButtonen), state);
101
102 }
103 else
104 {
105 if (state == true)
106 {
107 FileUrl.Enabled = true;
108 }
109 else
110 {
111 FileUrl.Enabled = false;
112
113 }
114 }
115
116
117
118 }

   2、二进制转换为JPEG 图形方法 代码

private void ImageSave(byte[] barrImage, string userName, string Names)
{
MemoryStream ms
= new MemoryStream(barrImage);
Image image
= Image.FromStream(ms);
string Nikname = string.Format("{0}-{1}", userName, Names);
string imgurl = HeadimgeCreatUrl(userName);
image.Save(string.Format("{0}/{1}.jpeg", imgurl, Nikname), ImageFormat.Jpeg);
AccountImage ai
= new AccountImage();
ai.AccountName
= userName;
ai.UserImageUrl
= string.Format("/{0}/{1}.jpeg", imgurl.Substring(imgurl.IndexOf(userName)), Nikname);
ImageList.Add(ai);
}

3、加载数据代码 

public void LoadData(string state)
{
string type = state;
string Count = SqlHelper.ExecuteScalar(ConString, CommandType.Text, "select count(*) as Counts from UserImage").ToString();

int p = int.Parse(Count);
SqlDataReader rd
= SqlHelper.ExecuteReader(ConString, CommandType.Text, "select * from UserImage");
int i = 0;
while (rd.Read())
{
UserInfo ui
= new UserInfo();
ui.UserId
= rd[0].ToString();
ui.FName
= rd[1].ToString();
ui.UserName
= rd[2].ToString();
ui.ImageValue
= (byte[])rd[3];
userList.Add(ui);

i
++;
ProState ps
= new ProState();
ps.MinCount
= i;
ps.MaxCount
= p;
ps.ValueText
= type + i.ToString() + "/" + Count.ToString();
string tt = string.Format("正在取数据 {0} ……", rd[2].ToString());
if (i == p)
{
ps.ValueText
= "数据加载已完,正在分析数据中,请稍后……";
tt
= "进程一处理已完,正等待下一进程中……";
}

showProgStatus(ps);
showDisPrcent(
string.Format("{0},{1}", i, p));
ShowDisCenterContent(tt);
}

}

 4、处理阶段代码  

public string HeadimgeCreatUrl(string UserName)
{
string UrlFile = string.Format("{0}/{1}/pub", Furl, UserName);
return new UserData().CreatDir(UrlFile);
}

public List<AccountImage> ImageList = new List<AccountImage>();
private void StartConvert(object type)
{
int s = 0;
type
= type.ToString();
foreach (var img in userList)
{
object rs = img.ImageValue;
byte[] bary = (byte[])rs;
ImageSave(bary, img.UserName, img.FName);
s
++;
ProState ps
= new ProState();
ps.MinCount
= s;
ps.MaxCount
= userList.Count;
ps.ValueText
= type + s.ToString() + "/" + userList.Count.ToString();
string cc = string.Format("正在转换 {0} ……", img.UserName);
if (s == userList.Count)
{
ps.ValueText
= "图片已转换完成,正在分析头像信息,请稍后……";
cc
= "进程处理二已完成,正等待下一进程中……";
}
string Nikname = string.Format("{0}-{1}", img.UserName, img.FName);
ShowDisCenterContent(cc);
showProgStatus(ps);
showDisPrcent(
string.Format("{0},{1}", s, userList.Count));

}

}

private void UpDataUser(object type)
{
type
= type.ToString();
int t = 0;
foreach (var us in ImageList)
{
SqlHelper.ExecuteNonQuery(ConString, CommandType.StoredProcedure,
"UPdataUserImage", new SqlParameter("@Name", us.AccountName), new SqlParameter("@HeadIMG", us.UserImageUrl));
t
++;
ProState ps
= new ProState();
ps.MinCount
= t;
ps.MaxCount
= userList.Count;
ps.ValueText
= type + t.ToString() + "/" + ImageList.Count.ToString();
string pp = string.Format("正在更新 {0} ……", us.AccountName);
if (t == ImageList.Count)
{
ps.ValueText
= "数据头像更新已完成!";
pp
= "进程处理已全部完成!";
}
ShowDisCenterContent(pp);
showProgStatus(ps);
showDisPrcent(
string.Format("{0},{1}", t, ImageList.Count));

}
MessageBox.Show(
"头像数据处理已完!", "系统提示", MessageBoxButtons.OK, MessageBoxIcon.Information);

}

5、开始执行代码 

private void button4_Click(object sender, EventArgs e)
{

object state = "正在读取数据中……";

ThreadPool.QueueUserWorkItem(dispRentReport, state);

}

private void GetUserImage()
{
object state = "正在转换图片中,请稍后……";
StartConvert(state);

}

private void StartUpdata()
{
object state = "正在更新用户数据表,请稍后……";
UpDataUser(state);
}
private string Furl = string.Empty;

private void dispRentReport(object state)
{
Furl
= FileUrl.Text;
if (Furl != "" & Furl != "")
{
ShowButtonen(
false);
LoadData(state.ToString());
Thread.Sleep(
4000);
GetUserImage();
Thread.Sleep(
4000);
StartUpdata();
ShowButtonen(
true);
}
else
{
MessageBox.Show(
"文件存放路径没有选择", "系统提示", MessageBoxButtons.OK, MessageBoxIcon.Error);
}


}

6、为了方便大家学习与使用,本人出提供源代码下载;

  https://files.cnblogs.com/waren168/ConvertIMage.rar 点击下载

激情燃烧
原文地址:https://www.cnblogs.com/waren168/p/2080793.html