二进制文件图形转换工具

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

技术核心:

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

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

   3、有序存储图片;

软件截图:

2011061416235590.png 2011061416241477.png

2011061416243118.png 2011061416244271.png

2011061416250078.png

程序代码:

  一、数据库创建

 [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、为了方便大家学习与使用,本人出提供源代码下载;

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

转载于:https://www.cnblogs.com/waren168/archive/2011/06/14/2080793.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值