C#打印(PrintDocument、PrintDialog、PageSetupDialog、PrintPreviewDialog)
摘要:这几天一直在弄C#打印,下面整理过后的打印范例,主要介绍了PrintDocument的主要属性、方法的应用。及打印过程中可能用的到得PrintDialog、PageSetupDialog、PrintPreviewDialog对话框。代码:usingSystem;usingSystem.Collect...
阅读全文
posted @
2015-12-29 10:16
peter_zhang
阅读(1972)
推荐(0)
使用Paint事件重画GroupBox来修改边框颜色
摘要:在.Net下进行WinForm开发,GroupBox是经常要用到的一个控件。但是GroupBox自身的边框是灰白色的,其样式很难令开发者满意。在不借用第三方控件的情况下,通过其的Paint事件对GroupBox进行重画,也可以很方便的修改其边框颜色/样式。 简要说一下实现思路。首先用Clear方法清除GroupBox的显示,接着再用合适的样式把GroupBox画出来。把GroupBox拆分为4个圆角,一行标题文字和数段直线等元素,把这些元素摆放在合适的位置,拼凑出GroupBox的外框。定义4个Rectangle(用于后面的画圆角),确定它们的大小和位置;然后在确切的位置上画4个弧段,按圆角.
阅读全文
posted @
2013-06-21 14:49
peter_zhang
阅读(5104)
推荐(0)
<转帖>DataTable批量插入数据库
摘要:最近在将excel中的文件导入到数据库中,用程序进行编写,由于数据量较大所以速度很慢,后来采用了SqlBulkCopy类,解决了速度的问题,我就insert语句,sqldataadapter.update(dataset,tablename);sqlbulkcopy.WriteToServer(datatable);三个方法的性能进行比较:1、生成测试的datatable表,表结构如下:UniqueID(主键,自动增长) | CompanyName | CompanyCode | Address | Owner | Memo共6个字段。SqlConnection sqlconnection =
阅读全文
posted @
2012-12-25 19:13
peter_zhang
阅读(246)
推荐(0)
C# dataTable实用例
摘要:C# dataTable实用例核心提示: 创建一个内存表,下面的代码会用到它 DataTable auto = new DataTable(); auto.Columns.Add("ID"); auto.Columns.Add("Name"); for(int i=1;i<=10;i++) { auto.Rows.Add(new object[]{i,"baibaoqing"}); } 一。创建一个内存表,下面的代码会用到它DataTable auto = new DataTable();auto.Columns.Add(&qu
阅读全文
posted @
2012-10-31 15:15
peter_zhang
阅读(389)
推荐(0)
C#串口SerialPort常用属性方法
摘要:SerialPort()://属性.BaudRate;获取或设置波特率.BytesToRead;得到 接收到数据的字节数.BytesToWrites;得到送往串口的字节数.DataBits;获取或设置数据位.IsOpen;获取一个值,判断串口是否打开.Pariy;获取或设置校验位.PortName;串口名称.ReadBufferSize;获取或设置读取数据的缓存大小.ReadTimeout;读取超时时间.StopBits;停止位.NewLine;用于解释通过ReadLine()与WriteLine()的值.WriteBufferSize;与ReadBufferSize相对.WriteTimeo
阅读全文
posted @
2012-10-16 23:44
peter_zhang
阅读(10423)
推荐(0)
C# SerialPort使用方法
摘要:SerialPort中串口数据的读取与写入有较大的不同。由于串口不知道数据何时到达,因此有两种方法可以实现串口数据的读取。一、线程实时读串口;二、事件触发方式实现。由于线程实时读串口的效率不是十分高效,因此比较好的方法是事件触发的方式。在SerialPort类中有DataReceived事件,当串口的读缓存有数据到达时则触发DataReceived事件,其中SerialPort.ReceivedBytesThreshold属性决定了当串口读缓存中数据多少个时才触发DataReceived事件,默认为1。另外,SerialPort.DataReceived事件运行比较特殊,其运行在辅线程,不能与
阅读全文
posted @
2012-09-11 15:58
peter_zhang
阅读(40650)
推荐(1)
C# 发送电子邮件(含附件)用到的类 system.web.mail
摘要:主要是用到了System.Web.Mail命名空间,用到了此空间的三个类,分别是:●MailMessage类,用于构造电子邮件●MailAttachment类,用于构造电子邮件附件●SmtpMail类,用于发送电子邮件及其附件1、MailMessage类构造电子邮件此类主要有以下属性和方法★From 发件人的地址★To 以分号分隔的收件人的地址列表★Cc 以分号隔开的抄送的收件人的邮件地址列表★Subject 电子邮件的主题★Body 电子邮件的正文★BodyFormat 电子邮件的正文内容类型,由MailFormat枚举值指定,MailFormat.Text或MailFormat.Html★
阅读全文
posted @
2012-07-30 13:21
peter_zhang
阅读(487)
推荐(0)
C# 让程序自动以管理员身份运行
摘要:在程序中加入MANIFEST资源:1) 打开Vs2005或vs2008工程,看在Properties下是否有app.manifest这个文件;如没有,右击工程在菜单中选择“属性”,出现界面如下:选中"Security",在界面中勾选"Enable ClickOnce Security Settings"后,在Properties下就有自动生成app.manifest文件。打开app.manifest文件,将<requestedExecutionLevel level="asInvoker" uiAccess="fals
阅读全文
posted @
2012-06-25 11:13
peter_zhang
阅读(382)
推荐(0)
Datatable删除行的Delete和Remove方法
摘要:有两个方法,delete和removeDelete的使用是 datatable.Rows[i].Delete();Remove的使用是datatable.Rows.Remove(datatable.Rows[i]);这两个的区别是,使用delete后,只是该行被标记为deleted,但是还存在,用Rows.Count来获取行数时,还是删除之前的行数.需要使用datatable.AcceptChanges()方法来提交修改.而Remove方法则是直接删除.如果在for循环里删除行的话,最好是使用delete方法,不然会出现count变化的情况.循环完后再使用AcceptChanges()方法提交
阅读全文
posted @
2012-06-22 13:40
peter_zhang
阅读(950)
推荐(0)
C#下没有注册类 (异常来自 HRESULT:0x80040154 (REGDB_E_CLASSNOTREG))
摘要:原因:没有原生支持64位,而是以32位兼容方式运行解决办法:在项目属性里设置“生成”=>“目标平台”为x86而不是默认的ANY CPU.
阅读全文
posted @
2012-05-31 13:17
peter_zhang
阅读(7415)
推荐(0)
转:C#调用C++的DLL搜集整理的所有数据类型转换方式
摘要://C++中的DLL函数原型为 //extern "C" __declspec(dllexport) bool 方法名一(const char* 变量名1, unsigned char* 变量名2) //extern "C" __declspec(dllexport) bool 方法名二(const unsigned char* 变量名1, char* 变量名2)//C#调用C++的DLL搜集整理的所有数据类型转换方式,可能会有重复或者多种方案,自己多测试 //c++:HANDLE(void *) ---- c#:System.IntPtr //c++:
阅读全文
posted @
2012-04-11 16:30
peter_zhang
阅读(948)
推荐(1)
.Net WebClient 上传文件错误集锦
摘要:一.“远程服务器返回错误: (501) 未实现”的错误解决方法:Web服务扩展中的WebDAV惹得祸,将IIS的"Web服务扩展"中的"WebDAV"设置成"允许"!PS:iis6的 webdav支持 其实就是个基于http的ftp功能 ,明确iis不能直接上传文件,需要扩展支持的话应该不会饶弯路吧?二.“远程服务器返回错误 (403) 已禁止”的错误解决方法:进入网站的虚拟路径目录,虚拟目录属性给写入权限;三.“远程服务器返回错误: (401) 未经授权”的错误解决方法:1、错误号401.1 症状:HTTP 错误 401.1 - 未
阅读全文
posted @
2011-12-31 11:20
peter_zhang
阅读(1688)
推荐(0)
未能加载文件或程序集“XXX.XXX”或它的某一个依赖项。试图加载格式不正确的程序。
摘要:未能加载文件或程序集“XXX.XXX”或它的某一个依赖项。试图加载格式不正确的程序。说明:执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。异常详细信息:System.BadImageFormatException: 未能加载文件或程序集“XXX”或它的某一个依赖项。试图加载格式不正确的程序。源错误:执行当前 Web 请求期间生成了未处理的异常。可以使用下面的异常堆栈跟踪信息确定有关异常原因和发生位置的信息。程序集加载跟踪:下列信息有助于确定程序集“XXX”无法加载的原因。警告: 程序集绑定日志记录被关闭。 要启用程序集绑定失
阅读全文
posted @
2011-12-08 17:46
peter_zhang
阅读(327)
推荐(0)
C#多线程学习(六) 互斥对象
摘要:如何控制好多个线程相互之间的联系,不产生冲突和重复,这需要用到互斥对象,即:System.Threading 命名空间中的 Mutex 类。我们可以把Mutex看作一个出租车,乘客看作线程。乘客首先等车,然后上车,最后下车。当一个乘客在车上时,其他乘客就只有等他下车以后才可以上车。而线程与Mutex对象的关系也正是如此,线程使用Mutex.WaitOne()方法等待Mutex对象被释放,如果它等待的Mutex对象被释放了,它就自动拥有这个对象,直到它调用Mutex.ReleaseMutex()方法释放这个对象,而在此期间,其他想要获取这个Mutex对象的线程都只有等待。下面这个例子使用了Mut
阅读全文
posted @
2011-11-27 22:05
peter_zhang
阅读(198)
推荐(0)
C#多线程学习(五) 多线程的自动管理(定时器)
摘要:Timer类:设置一个定时器,定时执行用户指定的函数。 定时器启动后,系统将自动建立一个新的线程,执行用户指定的函数。初始化一个Timer对象: Timer timer = new Timer(timerDelegate, s,1000, 1000); // 第一个参数:指定了TimerCallback 委托,表示要执行的方法;// 第二个参数:一个包含回调方法要使用的信息的对象,或者为空引用;// 第三个参数:延迟时间——计时开始的时刻距现在的时间,单位是毫秒,指定为“0”表示立即启动计时器;// 第四个参数:定时器的时间间隔——计时开始以后,每隔这么长的一段时间,TimerCallback
阅读全文
posted @
2011-11-27 22:04
peter_zhang
阅读(225)
推荐(0)
C#多线程学习(四) 多线程的自动管理(线程池)
摘要:在多线程的程序中,经常会出现两种情况:一种情况: 应用程序中,线程把大部分的时间花费在等待状态,等待某个事件发生,然后才能给予响应 这一般使用ThreadPool(线程池)来解决;另一种情况:线程平时都处于休眠状态,只是周期性地被唤醒 这一般使用Timer(定时器)来解决;ThreadPool类提供一个由系统维护的线程池(可以看作一个线程的容器),该容器需要 Windows 2000 以上系统支持,因为其中某些方法调用了只有高版本的Windows才有的API函数。将线程安放在线程池里,需使用ThreadPool.QueueUserWorkItem()方法,该方法的原型如下://将一个线程放..
阅读全文
posted @
2011-11-27 22:03
peter_zhang
阅读(203)
推荐(0)
C#多线程学习(三) 生产者和消费者
摘要:前面说过,每个线程都有自己的资源,但是代码区是共享的,即每个线程都可以执行相同的函数。这可能带来的问题就是几个线程同时执行一个函数,导致数据的混乱,产生不可预料的结果,因此我们必须避免这种情况的发生。C#提供了一个关键字lock,它可以把一段代码定义为互斥段(critical section),互斥段在一个时刻内只允许一个线程进入执行,而其他线程必须等待。在C#中,关键字lock定义如下:lock(expression) statement_block expression代表你希望跟踪的对象,通常是对象引用。 如果你想保护一个类的实例,一般地,你可以使用this; 如果你想保护一个静态变量(
阅读全文
posted @
2011-11-27 22:02
peter_zhang
阅读(362)
推荐(0)
C#多线程学习(二) 如何操纵一个线程
摘要:下面我们就动手来创建一个线程,使用Thread类创建线程时,只需提供线程入口即可。(线程入口使程序知道该让这个线程干什么事)在C#中,线程入口是通过ThreadStart代理(delegate)来提供的,你可以把ThreadStart理解为一个函数指针,指向线程要执行的函数,当调用Thread.Start()方法后,线程就开始执行ThreadStart所代表或者说指向的函数。 打开你的VS.net,新建一个控制台应用程序(Console Application),编写完全控制一个线程的代码示例://ThreadTest.csusingSystem;usingSystem.Threading;n
阅读全文
posted @
2011-11-27 22:01
peter_zhang
阅读(157)
推荐(0)
C#多线程学习(一) 多线程的相关概念
摘要:什么是进程?当一个程序开始运行时,它就是一个进程,进程包括运行中的程序和程序所使用到的内存和系统资源。而一个进程又是由多个线程所组成的。什么是线程?线程是程序中的一个执行流,每个线程都有自己的专有寄存器(栈指针、程序计数器等),但代码区是共享的,即不同的线程可以执行同样的函数。什么是多线程?多线程是指程序中包含多个执行流,即在一个程序中可以同时运行多个不同的线程来执行不同的任务,也就是说允许单个程序创建多个并行执行的线程来完成各自的任务。多线程的好处:可以提高CPU的利用率。在多线程程序中,一个线程必须等待的时候,CPU可以运行其它的线程而不是等待,这样就大大提高了程序的效率。 多线程的不利方
阅读全文
posted @
2011-11-27 22:00
peter_zhang
阅读(194)
推荐(0)