美文网首页
关于手机端发送16*16汉字点阵取模相关问题(二)

关于手机端发送16*16汉字点阵取模相关问题(二)

作者: gazyy1 | 来源:发表于2019-02-22 16:35 被阅读0次
这是“我”横向扫描后的0,1点阵

提醒:在这里要首先明白取模方向是什么意思。下面列举下取模放向及实例

横向扫描

与上图“我”字对应 这种取模后取值为 00000100 10000000 00001110 10100000.。。。以此类推

但是发送给硬件需要倒叙即为  00100000 00000001 01110000 00000101.。。依次类推


纵向扫描的一种

只要注意扫描方式跟0,1阵的关系就很容易理解。这种扫描即为 00000100 00100100.。。 按照0,1阵方向取值

同样需要倒叙


下面引入下面这种扫描发送的代码,因为项目用到的是这种,其他种都可以按此思路进行编写

- (void)sendText:(NSString *)str{           

FILE* fphzk = NULL;   

int offset;   

unsigned char buffer[32];   

unsigned char key[8] = { 0x80,0x40,0x20,0x10,0x08,0x04,0x02,0x01 };   

unsigned char word[3]; // 改成你的转码后的汉字编码//   

//文件路径    NSString *path = [[NSBundle mainBundle] pathForResource:@"HZK16" ofType:@""];   

fphzk = fopen(path.UTF8String, "rb");     

if(fphzk == NULL){       

fprintf(stderr, "error hzk16\n");       

return;   

}             

//循环解码    --》因为可能是多个汉字

NSMutableString *sendStr = [NSMutableString string];//   

NSMutableString *twoSendStr = [NSMutableString string];   

for (int i=0; i<str.length; i++) {               

NSString *endStr = [str substringWithRange:NSMakeRange(i, 1)];       

Byte *bytes = [self convertStringToGBKStr:endStr];        //汉字ascii编码 

 word[0] = bytes[0];       

word[1] = bytes[1];       

offset = (94*(unsigned int)(word[0]-0xa0-1)+(word[1]-0xa0-1))*32;       

fseek(fphzk, offset, SEEK_SET);       

fread(buffer, 1, 32, fphzk);       

NSMutableArray<NSArray *> *ary = [NSMutableArray array];       

for(int k=0; k<16; k++){           

NSMutableArray<NSString *> *str = [NSMutableArray array];           

for(int j=0; j<2; j++){               

for(int i=0; i<8; i++){                   

int flag = buffer[k*2+j]&key[i];                   

printf("%s", flag?"1":"0");                   

[str addObject:flag?@"1":@"0"];               

}           

}           

printf("\n");           

[ary addObject:str];       

}       

//开始处理取模方式   --》在这里进行扫描以及取模的计算      

NSMutableString *overStr = [NSMutableString string];       

for (int i = 0; i < 16; i ++) {           

NSMutableString *newStr = [NSMutableString string];           

for (int j = 0; j < 8; j ++) {               

NSArray *strArr = ary[7-j];               

[newStr appendFormat:@"%@",strArr[i]];           

}           

[overStr appendFormat:@"%@",[self getHexByBinary:newStr]];       

}       

for (int i = 0; i < 16; i ++) {           

NSMutableString *newStr = [NSMutableString string];           

for (int j = 0; j < 8; j ++) {               

NSArray *strArr = ary[15-j];               

[newStr appendFormat:@"%@",strArr[i]];           

}           

[overStr appendFormat:@"%@",[self getHexByBinary:newStr]];       

}       

NSLog(@"最终输出的自处穿%@",overStr);       

[sendStr appendString:overStr];   

}   

fclose(fphzk);   

fphzk = NULL;

//在这里得到的sendStr即为按该中方式取模后的十六进制字符串

}


可以根据不同需求对方法进行修改。因为想要逻辑简单 所以没有对代码进行优化,方面理解。

调用方法:[self sendText:@"你我他"];

相关文章

  • 关于手机端发送16*16汉字点阵取模相关问题(二)

    提醒:在这里要首先明白取模方向是什么意思。下面列举下取模放向及实例 与上图“我”字对应 这种取模后取值为 0000...

  • 关于iOS 蓝牙 字库 发送16*16汉字点阵取模相关问题(一)

    在与硬件的蓝牙通讯过程中,硬件需要手机端发送16*16的汉字点阵过去,用于硬件直接显示汉字。这里采用的是通用的HZ...

  • 蓝桥杯2018真题——明码

    题目:明码汉字的字形存在于字库中,即便在今天,16点阵的字库也仍然使用广泛。16点阵的字库把每个汉字看成是16x1...

  • 蓝牙点阵之汉字取模

    下载16*16字库到AndroidStudio的assets目录(需自行创建)下,并在程序中最好定义private...

  • iOS mqtt发送汉字出现乱码

    问题描述 项目中利用mqtt向电视发送汉字的时候,电视端显示乱码;并且查看手机端发送字符串为正常的汉字 问题原因 ...

  • iOS 蓝牙 16*16 点阵,汉字字模

    这段时间搞了蓝牙,主要弄iOS平台汉字点阵,之前用字体库,但是只支持简体,后面改内存绘图方式,实现了,折腾啊,可以...

  • 点阵字体与矢量字体

    点阵字体 点阵字体是把每一个字符都分成16×16或24×24个点,然后用每个点的虚实来表示字符的轮廓。点阵字体也叫...

  • 16位数的高低八位

    大小端高位字节在前,低位字节在后称之为大端。反之,为小端。 以下都是基于大端16位二进制数来说,小端反之。 取低八...

  • TCP/IP三次握手和四次挥手

    一 首先我们看下TCP报文头 说明:1 源端口号(16位):标识发送端端口号2 目的端口号(16位):标识目的端口...

  • day25-TCP/IP 的三挥四握

    TCP数据报文格式 1)源端口号和目的端口号这个字段均为16位的长度,表示发送端和接收端的端口,用于确认发送端和接...

网友评论

      本文标题:关于手机端发送16*16汉字点阵取模相关问题(二)

      本文链接:https://www.haomeiwen.com/subject/mgveyqtx.html