大家都知道条形码(Barcode)是一种可以由机器识别的特殊编码,在生产、生活中也常常会见到并使用它。条形码的类型和种类很多感兴趣的朋友可以详细了解一下。其中Code 39 可以说是一种最为常见并广泛使用的字符与数字结合的编码类型,本篇也将利用它制作一个带有条形码的员工卡应用程序。

在公司内部员工卡是员工身份唯一的识别工具,同时也是考勤及门禁系统的主要信息来源。首先在WPF 中设计一个简单的员工卡样式,具备员工卡标识、员工相片、员工姓名等。

  1. <Border CornerRadius="3" BorderBrush="Gray" BorderThickness="2" Background="White"
  2. MouseLeftButtonDown="Border_MouseLeftButtonDown">
  3. <Canvas x:Name="mainCanvas">
  4. <Grid x:Name="closeBtn" Canvas.Left="330" Canvas.Top="0"
  5. MouseLeftButtonDown="Close_MouseLeftButtonDown">
  6. <Ellipse Height="15" Width="15" HorizontalAlignment="Center">
  7. <Ellipse.Fill>
  8. <SolidColorBrush x:Name="ellipseColor"/>
  9. </Ellipse.Fill>
  10. </Ellipse>
  11. <TextBlock Text="x" Margin="2,-2,2,2" HorizontalAlignment="Center">
  12. <TextBlock.Foreground>
  13. <SolidColorBrush x:Name="textColor" Color="Gray"/>
  14. </TextBlock.Foreground>
  15. </TextBlock>
  16. </Grid>
  17.  
  18. <Border BorderBrush="#FF54545C" Canvas.Top="25" CornerRadius="5"
  19. Height="49" Width="339" Background="#FF2192C4" Canvas.Left="5">
  20. <TextBlock Text="EMPLOYEE CARD" Foreground="White" FontSize="20"
  21. VerticalAlignment="Center" HorizontalAlignment="Center"
  22. FontWeight="Black" FontFamily="Microsoft Sans Serif"/>
  23. </Border>
  24. <Grid Canvas.Left="96" Canvas.Top="78">
  25. <Grid.RowDefinitions>
  26. <RowDefinition />
  27. <RowDefinition />
  28. </Grid.RowDefinitions>
  29. <Image Source="Images/cardpic.png" Grid.Row="0"/>
  30. <TextBlock Text="Li Jing Ran" FontSize="30" FontWeight="Black"
  31. Grid.Row="1" HorizontalAlignment="Center"/>
  32. </Grid>
  33. </Canvas>
  34. </Border>

  1.  代码内容比较简单,其中需要提一下的是x:Name closeBtn 的<Grid>,可以看到它包含了一个<Ellipse>和<Textblock>,它们的颜色填充方式看上去做的很复杂。其实是为了实现一个动态效果:当鼠标移动到关闭图标上时,其<Ellipse>和<Textblock>会改变颜色(如下图对比)。

该效果代码如下,通过Window.Resources 设置一个ColorAnimation Storyboard,再通过MouseEnter、MouseLeave 来触发Storyboard 动画效果。

  1. <Window.Resources>
  2. <Storyboard x:Key="flashClose">
  3. <ColorAnimation Storyboard.TargetName="ellipseColor"
  4. Storyboard.TargetProperty="Color"
  5. From="White" To="Gray" Duration="0:0:0.1"/>
  6. <ColorAnimation Storyboard.TargetName="textColor"
  7. Storyboard.TargetProperty="Color"
  8. From="Gray" To="White" Duration="0:0:0.1"/>
  9. </Storyboard>
  10. </Window.Resources>
  11. <Window.Triggers>
  12. <EventTrigger SourceName="closeBtn" RoutedEvent="Grid.MouseEnter">
  13. <BeginStoryboard x:Name="showClosBtn" Storyboard="{StaticResource flashClose}"/>
  14. </EventTrigger>
  15. <EventTrigger SourceName="closeBtn" RoutedEvent="Grid.MouseLeave">
  16. <StopStoryboard BeginStoryboardName="showClosBtn"/>
  17. </EventTrigger>
  18. </Window.Triggers>
     完成上面的界面设计,最后只需在员工卡下放的空白处添加员工编号条形码即可。首先在项目中加入Barcode 和Code39 类,我们要通过这两个类完成条形码的绘制工作。打开C#程序,编写如下代码。
      通过Barcodes 类创建一个新的条形码,定义BarcodeType 为"Code39",编码Data 为“10001”,如果需要校验则将CheckDigit 设为"Yes"。其中thinWidth、thickWidth 用于定义黑白条码的宽窄度。
  1. Barcodes bb = new Barcodes();
  2. bb.BarcodeType = Barcodes.BarcodeEnum.Code39;
  3. bb.Data = "10001";
  4. bb.CheckDigit = Barcodes.YesNoEnum.Yes;
  5. bb.encode();
  6.  
  7. int thinWidth;
  8. int thickWidth;
  9.  
  10. thinWidth = 2;
  11. thickWidth = 3 * thinWidth;
  12.  
  13. string outputString = bb.EncodedData;
  14. string humanText = bb.HumanText;

绘制条形码

根据编码(EncodedData)的长度利用Rectangle 类逐一绘制黑、白条码,t 表示窄码,w 表示宽码。

  1. int len = outputString.Length;
  2. int currentPos = 50;
  3. int currentTop = 340;
  4. int currentColor = 0;
  5. for (int i = 0; i < len; i++)
  6. {
  7. Rectangle rect = new Rectangle();
  8. rect.Height = 80;
  9. if (currentColor == 0)
  10. {
  11. currentColor = 1;
  12. rect.Fill = new SolidColorBrush(Colors.Black);
  13. }
  14. else
  15. {
  16. currentColor = 0;
  17. rect.Fill = new SolidColorBrush(Colors.White);
  18. }
  19. Canvas.SetLeft(rect, currentPos);
  20. Canvas.SetTop(rect, currentTop);
  21.  
  22. if (outputString[i] == 't')
  23. {
  24. rect.Width = thinWidth;
  25. currentPos += thinWidth;
  26. }
  27. else if (outputString[i] == 'w')
  28. {
  29. rect.Width = thickWidth;
  30. currentPos += thickWidth;
  31. }
  32. mainCanvas.Children.Add(rect);
  33. }

添加可读码

最后在条形码下方添加一行可读码,方便员工认读条形码内容,也就是将“10001”员工编号显示出来。

  1. TextBlock tb = new TextBlock();
  2. tb.Text = humanText;
  3. tb.FontSize = 25;
  4. tb.FontFamily = new FontFamily("Consolas");
  5. Rect rx = new Rect(0, 0, 0, 0);
  6. tb.Arrange(rx);
  7. Canvas.SetLeft(tb, 120);
  8. Canvas.SetTop(tb, currentTop + 80);
  9. mainCanvas.Children.Add(tb);

WPF 员工卡条形码的更多相关文章

  1. 未来工厂——电器行业ERP案例

    江苏科兴电器有限公司位于全国著名的“银杏之乡”泰兴市南首,主要生产35kV及以下电流.电压互感器等系列产品.产品多次经国家及省市技术监督部门抽检合格,广泛应用于国家重点工程.“COSINE”商标荣获泰 ...

  2. 微信公众平台开发教程(八)Session处理

    微信公众平台开发教程(八)Session处理 在微信窗口,输入的信息有限,我们需要将一些信息分多次请求. 比如:在进行用户绑定时,我们需要输入用户的相关信息,比如:用户名.密码,或者姓名.电话号码,服 ...

  3. php 文本框里面显示数据库调出来的资料

    php 文本框里面显示数据库调出来的资料,,,在里面我标注了,,那个地方为什么是!=才能显示正确的数据库资料啊?我理解的是对比正确输出数据库内容的.大师貌似不知道为什么就写错了 <html> ...

  4. ASP.NET Core 认证与授权[5]:初识授权

    经过前面几章的姗姗学步,我们了解了在 ASP.NET Core 中是如何认证的,终于来到了授权阶段.在认证阶段我们通过用户令牌获取到用户的Claims,而授权便是对这些的Claims的验证,如:是否拥 ...

  5. Xamarin 开发过的那些项目

    您可能已经看到类似的统计数据:智能手机用户在手机媒体上花费了89%的时间使用应用程序.或者听说Gartner预测到2017年移动应用程序下载将产生价值770亿美元的收入.很难不考虑这些数字.今天,每个 ...

  6. winform excel导入--NPOI方式

    项目中要用到excel导入数据,用NPOI方式做了一个demo,记录如下: Form1代码: public Form1() { InitializeComponent(); } private voi ...

  7. asp.net 导出excel的一种方法

    项目用到的一种导出excel 的方法予以记录:(具体的业务类可更具情况替换使用) protected void Export(string filename, List<ComponentCon ...

  8. (转)微信公众平台开发教程(七)Session处理

    原文地址:http://www.cnblogs.com/yank/p/3476874.html 微信公众平台开发教程(七)Session处理 在微信窗口,输入的信息有限,我们需要将一些信息分多次请求. ...

  9. 从乌云的错误漏洞分析看Mifare Classic安全

    前言 12年2月初国内著名安全问题反馈平台-乌云发布了有关某公司员工卡的金额效验算法破解的安全问题.从整个漏洞分析来看,漏洞的提交者把员工卡的数据分析得非常仔细,以至很多刚刚接触或者未曾接触的都纷纷赞 ...

随机推荐

  1. [sharepoint]文档库,文件夹授权

    写在前面 在项目中用到了文档库授权的方法,这里将查询到的方式总结一下. 涉及到的方法 在逻辑中用到的方法. /// <summary> /// 获取sharepoint站点角色定义 res ...

  2. 1084. Broken Keyboard (20)【字符串操作】——PAT (Advanced Level) Practise

    题目信息 1084. Broken Keyboard (20) 时间限制200 ms 内存限制65536 kB 代码长度限制16000 B On a broken keyboard, some of ...

  3. perl一次读取多行文本的策略

    在处理文本时,经常遇到这种情况:就是我们须要把两行文本做一个比較,然后选择性输出. 而在while(<FILEHAND>){do something}程序块中默认仅仅能一次读取一行.笔者在 ...

  4. C源程序到可执行文件的四个过程

    C源程序到可执行文件的四个过程 1.预处理:预编译器执行.譬如C中的宏定义就是由预编译器处理,注释等也是由预编译器处理的 gcc -E -hello.c -o hello.i 2.编译:编译器来执行. ...

  5. Weblogic OutOfMemory exception的误解 -- thread limitation

    不是全部的OutofMemory exception都是内存问题... 前几天有个客户的site报了下面错误: [ERROR][thread ] Could not start thread Time ...

  6. 01.Hello Node.js

    程序下载:https://files.cnblogs.com/files/xiandedanteng/helloNodejs.rar 关键代码: var http=require('http'); v ...

  7. Android JNI/NDK开发教程

    JNI/NDK开发指南:http://blog.csdn.net/xyang81/article/details/41759643

  8. 性能测试之Tomcat优化

    1.Tomcat最大连接数等配置   Tomcat的server.xml中Context元素的以下参数都是什么意思? <Connector port="8080"maxThr ...

  9. Linux非阻塞IO(二)网络编程中非阻塞IO与IO复用模型结合

    上文描述了最简易的非阻塞IO,采用的是轮询的方式,这节我们使用IO复用模型.   阻塞IO   过去我们使用IO复用与阻塞IO结合的时候,IO复用模型起到的作用是并发监听多个fd. 以简单的回射服务器 ...

  10. poj1062昂贵的聘礼

    这个题目我最開始看题目看了半天,看不懂.. 可是通过看例子及答案最终看懂了. .. 首先先解决等级的关系. .假设等级越界.则不能交换..所以原本等级的界限是 [rank[1]-m,rank[1]+m ...