搜索
bottom↓
回复: 0

VB.net汉字取摸的问题!

[复制链接]

出0入0汤圆

发表于 2012-5-30 14:32:54 | 显示全部楼层 |阅读模式
  1. Private Sub Button_SendData_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button_SendData.Click
  2.         Dim Count As Byte                           '字符数量,1个汉字作2位处理
  3.         Dim Number As Byte                          '字符数量,一个汉字做1位处理
  4.         Dim StartAddrss As String                   '起始地址,
  5.         Dim sendASdata(63) As Byte                  'ASSIC字符数组
  6.         Dim SendHZdata(127) As Byte                 '汉字数组

  7.         FileOpen(1, "C:\Users\Mr.ZHang\Desktop\LED3232DipslaySystem\HZK32", OpenMode.Binary, OpenAccess.Read, OpenShare.LockRead)
  8.         FileOpen(2, "C:\Users\Mr.ZHang\Desktop\LED3232DipslaySystem\ASC32", OpenMode.Binary, OpenAccess.Read, OpenShare.LockRead)
  9.         Count = Lenx(TextBox_EditHZ.Text)           '获取字符数量,一个汉字拆为2个字符
  10.         If Count < 1 Then                           '输入的字符为1则退出函数
  11.             FileClose(1)                            '关闭已打开的文件1
  12.             FileClose(2)                            '关闭已打开的文件2
  13.             MsgBox("不能发送空内容,请输入节目内容!", vbExclamation, "警告 ") '提示警告信息
  14.             Exit Sub                                '退出函数
  15.         End If
  16.         Number = 0                                  '把字数归0
  17.         While Number < Len(TextBox_EditHZ.Text)     '判断字符是否传输完毕
  18.             StartAddrss = Hex(Asc(Mid(TextBox_EditHZ.Text, 1 + Number, 1))) '获取字符在文件中的地址信息
  19.             Dim I As Integer, J As Integer          '循环计数用变量Dat
  20.             Dim BUFF(0) As Byte
  21.             If (("&H" + StartAddrss) < 255) Then    '输入的为数字
  22.                 StartAddrss = StartAddrss * 64      '取得字符的起始地址
  23.                 For I = 0 To 63 Step 1
  24.                     FileGet(2, BUFF, StartAddrss + 1 + I)
  25.                     sendASdata(I) = BUFF(0)
  26.                     MsgBox(Hex(BUFF(0)) & "+" & I)
  27.                 Next

  28.             Else                                    '输入的为汉字
  29.                 Dim N As Integer
  30.                 StartAddrss = 128 * ("&H" + Mid(StartAddrss, 5, 2) - 161) * 94 + ("&h" + Mid(StartAddrss, 7, 2) - 161) '取汉字的起始字节地址
  31.                 '   MsgBox(StartAddrss)
  32.                 BUFF(0) = 0
  33.                 N = 0
  34.                 For I = 0 To 3                      '分4次做
  35.                     For J = 0 To 127 Step 4
  36.                         FileGet(1, BUFF, StartAddrss + 1 + I + J)
  37.                         SendHZdata(N) = BUFF(0)
  38.                         MsgBox(SendHZdata(I) & "+" & I + J)
  39.                         N = N + 1
  40.                     Next


  41.                 Next
  42.             End If
  43.             Number = Number + 1                     '传送下个汉字
  44.         End While                                   '完毕则退出循环
  45.         FileClose(1)     '关闭文件1               
  46.         FileClose(2)     '关闭文件2
  47.     End Sub
复制代码
取模感觉不对,老是提示些许错误,请大侠指教一下,因为不懂,一遇到问题就是百度一下,一点一点的写到了这里,但总发现里面有些语法错误,只说汉字部分,就是ELSE的部分 。另外fileget文件的内容这么获取对吗?

阿莫论坛20周年了!感谢大家的支持与爱护!!

你熬了10碗粥,别人一桶水倒进去,淘走90碗,剩下10碗给你,你看似没亏,其实你那10碗已经没有之前的裹腹了,人家的一桶水换90碗,继续卖。说白了,通货膨胀就是,你的钱是挣来的,他的钱是印来的,掺和在一起,你的钱就贬值了。
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-10-3 01:30

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表