一个自动控制机的硅控板检测程序,用多线程和API,没有用控件,少做改动就能用
Unit CommThread;

Interface

Uses
  Windows, Classes, SysUtils, Graphics, Controls, Forms,
  Dialogs, ComCtrls, ExtCtrls;
Type
  TThreadParam = Record
    SusPended: Boolean;
    BaulSpeed: integer;
    Port: Byte;
    Parity: Boolean;
    StopBit: byte;
    StartBit: Byte;
    SB: TStatusBar;
    LEDs: Array[0..24] Of TShape;
  End;

Type
  TReadThread = Class(TThread)
  Private
    { Private declarations }
    hComm: THandle;
    Port: integer;
    FErr: Boolean;
    FPortDescription: String;
    FShape: Array[0..24] Of TShape;
    FSB: TStatusBar;
    cc: TCOMMCONFIG;
    Data: String;
    Procedure ReadPort; //读取串行端口数据
    Procedure UpdateUI;
  Protected
    Procedure Execute; Override;
  Public
    Constructor Create(ThdPrm: TThreadParam);
  End;

Implementation
//uses Unit1; // 声明引用Unit1,必须放在implementation区段

Constructor TReadThread.Create(ThdPrm: TThreadParam);
Var
  i: integer;
Begin
  Port := thdprm.Port;
  FSB := thdprm.SB;
  For i := 0 To 24 Do
  Begin
    FShape[i] := thdPrm.LEDs[i];
  End;
  FreeOnTerminate := True;
  Inherited Create(ThdPrm.SusPended);
End;

Procedure TReadThread.Execute;
Var
  PortToOpen: String;
Begin
  PortToOpen := 'COM' + inttostr(Port); // 选择所要打开的COM
  hComm := CreateFile(PChar(PortToOpen), GENERIC_READ Or GENERIC_WRITE,
    0, Nil, OPEN_EXISTING, 0, 0); // 打开COM
  If (hComm = INVALID_HANDLE_VALUE) Then
  Begin //如果COM 未打开
    FErr := True;
    FPortDescription := '打开端口错误!';
  End
  Else
  Begin
    FErr := False;
    FPortDescription := '打开端口成功';
    GetCommState(hComm, cc.dcb); // 得知目前COM 的状态
    cc.dcb.BaudRate := CBR_9600; // 设置波特率为9600
    cc.dcb.ByteSize := 8; //字节为 8 bit
    cc.dcb.Parity := NOPARITY; // Parity 为 None
    cc.dcb.StopBits := ONESTOPBIT; // 1 个Stop bit
    If Not SetCommState(hComm, cc.dcb) Then
    Begin // 设置COM 的状态
      Ferr := True;
      FPortDescription := FPortDescription + ',设置错误!';
      CloseHandle(hComm); //关闭通信端口
    End
    Else
    Begin
      FErr := False;
      FPortDescription := FPortDescription + ',设置成功';
      While Not Terminated Do
      Begin
        Synchronize(ReadPort); //刚才所定义的读取数据函数
      End;
      Synchronize(UpdateUI);
    End;
  End;

End;

Procedure TReadThread.ReadPort;
Var
  i: integer;
  inbuff: Array[0..29] Of Char;
  nBytesRead, dwEvent, dwError: LongWORD;
  cs: TCOMSTAT;
  Rights, Emptys, Errs: integer;
Const
  RightColor = clBlue;
  ErrorColor = clRed;
  EmptyColor = clWhite;
Begin
  Rights := 0;
  Emptys := 0;
  Errs := 0;
  If (hComm = INVALID_HANDLE_VALUE) Then
  Begin
    Fsb.Panels[3].Text := FPortDescription;
    Terminate; //先判断是否已打开通信端口
    Exit;
  End
  Else
  Begin
    Fsb.Panels[3].Text := FPortDescription;
    ClearCommError(hComm, dwError, @CS); //取得状态
    ReadFile(hComm, inbuff, cs.cbInQue, nBytesRead, Nil); // 接收COM 的数据
    //串行在读取数据后,会自动将缓冲区中已被读取的数据清除掉
    If cs.cbInQue = 0 Then exit;
    // 数据是否大于我们所准备的Buffer
    If cs.cbInQue <> sizeof(inbuff) Then
    Begin
      PurgeComm(hComm, PURGE_RXCLEAR); // 清除COM 数据
      exit;
    End;
    Data := Copy(inbuff, 1, cs.cbInQue); //取出数据
    For i := 1 To 25 Do
    Begin
      If (UpperCase(Data[i]) = 'Y') Then
      Begin
        FShape[i].Brush.Color := RightColor;
        Rights := Rights + 1;
      End
      Else
        If (UpperCase(Data[i]) = 'N') Then
        Begin
          FShape[i].Brush.Color := EmptyColor;
          Emptys := Emptys + 1;
        End
        Else
          If (UpperCase(Data[i]) = 'E') Then
          Begin
            FShape[i].Brush.Color := ErrorColor;
            Errs := Errs + 1;
          End;
    End;
    Fsb.Panels[0].Text := '正确:' + IntTostr(Rights);
    fsb.Panels[1].Text := '空槽:' + IntTostr(Emptys);
    fsb.Panels[2].Text := '错误:' + IntTostr(Errs);
    Fsb.Panels[3].Text := FPortDescription;
    Fsb.Panels[4].Text := '数据:' + Data;
  End;
End;

Procedure TReadThread.UpdateUI;
Begin
  Fsb.Panels[0].Text := '正确:' + IntTostr(0);
  fsb.Panels[1].Text := '空槽:' + IntTostr(0);
  fsb.Panels[2].Text := '错误:' + IntTostr(0);
  Fsb.Panels[3].Text := '';
  Fsb.Panels[4].Text := '数据:' + Data;
End;

End.

delphi 一个自动控制机的硅控板检测程序,用多线程和API,没有用控件,少做改动就能用 用485开发的更多相关文章

  1. 设计一个自动生成棋盘格子的JS小程序

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  2. CentOS6.4关闭触控板

    1. 检查是否安装xorg-x11-app; rpm -qa xorg-x11-apps 如果没有安装使用下面命令安装xorg-x11-app yum install xorg-x11-apps 2. ...

  3. 第一个FPGA工程----点亮开发板上的3个LED灯

    第一个FPGA工程----点亮开发板上的3个LED灯 1.新建FPGA工程 开启Quartus2的画面 File--New Project Wizard..指定工程的路径与工程名 指定所使用的FPGA ...

  4. iOS开发过程中,触控板的使用技巧

    1.在Storyboard鼠标右键可以直接拖线的,如果你用的是外接的第三方鼠标,没必要按着 control 键再用鼠标左键拖线 如果是触控板的话,双指按下去就可以直接拖线,带3Dtouch功能的触控板 ...

  5. synaptics驱动,插入USB鼠标禁用触控板注册表

    Title:synaptics驱动,插入USB鼠标禁用触控板注册表 --2010-11-01 22:21 记得以前用过一个synaptics的驱动,自带有插入USB鼠标禁用触控板的选项的,有些没有自带 ...

  6. win7下一劳永逸地解决触控板禁用的问题

    win7下一劳永逸地解决触控板禁用的问题--有鼠标时触摸板不再可用, 没鼠标时才启用 下载Synaptics触摸板驱动并安装(去官网或驱动之家都可以) →重启 开始→运行→框内输入 regedit 点 ...

  7. Ubuntu下笔记本触控板的禁启

    1.命令行方式,得每次用终端输入命令行设置 sudo rmmod psmouse #禁用触摸板 sudo modprobe psmouse #启用触摸板 2.永久禁用触摸板 打开终端,然后 sudo ...

  8. ​Mac触控板常用的手势操作

    ​Mac触控板常用的手势操作 学习了:http://topbook.cc/archives/151   一个手指直接点击,类似Windows中鼠标左键功能,同时在苹果Safari等浏览器中,这个手势还 ...

  9. Delphi TreeView – 自动展开树形结构

    Delphi TreeView – 自动展开树形结构 当处理完TreeView控件树形结构的数据后,需要默认自动全部展开,可以用到TreeView的Expanded属性. 1 2 3 4 5 6 7 ...

随机推荐

  1. 汇编中bss,data,text,rodata,heap,stack,意义

    bss段: BSS段(bsssegment)通常是指用来存放程序中未初始化的全局变量的一块内存区域.BSS是英文BlockStarted by Symbol的简称.BSS段属于静态内存分配. data ...

  2. .net web端导出Excel个人的看法

    //对已有方法进行重写 public override void VerifyRenderingInServerForm(Control control) { } //设置文件名 string fil ...

  3. ftpget 从Windows FTP服务端获取文件

    /********************************************************************************* * ftpget 从Windows ...

  4. CSS3中:nth-child和:nth-of-type的区别深入理解。 关于:nth-child和:nth-of-type的区别之前一直没太注意,经深入理解才发现里面其实暗藏玄机

    关于:nth-child和:nth-of-type的区别之前一直没太注意.最近打算深入了解一些CSS3,才发现里面其实暗藏玄机. :nth-child可以选择父元素下的字元素,:nth-of-type ...

  5. JUnit报错需导入两个jar包

    <dependency> <groupId>org.hamcrest</groupId> <artifactId>hamcrest-core</a ...

  6. Java中类的数据成员的初始化顺序

    对于单一类: 属性初始化 ---> 按顺序执行静态初始化块(只能操作静态属性) ---> 按顺序执行初始化块 ---> 构造方法 对于存在继承关系的类: 父类属性初始化 ---> ...

  7. Git学习笔记(Mac Linux系统)

    最近参与学校一个比赛,和队友一起做一个小项目,需要将代码传到Coding(国内git代码托管平台),因此这几天才正式入手git版本控制系统,在这里我就记录一下最近的学习git心得体验,一来分享一下自己 ...

  8. glusterfs 中的字典查询

    glusterfs文件系统是一个分布式的文件系统,但是与很多分布式文件系统不一样,它没有元数服务器,听说swift上也是应用了这个技术的.glusterfs中每个xlator的配置信息都是用dict进 ...

  9. struct2的structs.xml文件配置There is no Action mapped for action name 问题

    很久没写过博客,今天重新开始写,新技术太多,只有通过博客才可以不断积累,本人水平有限,如有错误,欢迎指正,谢谢 今天在MAVEN上配置web project的struct2,发现自己忽略了很多问题,再 ...

  10. 迭代器模式(Iterator Pattern)

    迭代器模式(Iterator),提供一种方法顺序访问一个聚合对象中的各种元素,而又不暴露该对象的内部表示. 迭代器模式(Iterator)就是分离了聚合对象的遍历行为,抽象出一个迭代器来负责这样既可以 ...