(1)国标码简介

(2)编码转换

(3)时间获取

(4)显示切换

  最近做了个字符叠加,包括时间叠加,字符中文叠加,位置移动,等功能开启。因为一般的字符叠加的点阵式16位,然后填充着16位的编码是gb2313编码,比如说视讯两个字,

先是视:

编码类型 二进制编码 十六进制编码
Unicode 10001001 11000110 0x89C6
UTF-8 11101000 10100111 10000110 0xE8A786
GB2312 11001010 11010011 0xCAD3

然后讯:

编码类型 二进制编码 十六进制编码
Unicode 10001011 10101111 0x8BAF
UTF-8 11101000 10101110 10101111 0xE8AEAF
GB2312 11010001 10110110 0xD1B6

gb2313国标是占用两个字节一个字,国际标utf8是三个字节一个字,

http://lijunlisu.blog.163.com/blog/static/1639814282012710101844158/

http://www.cnblogs.com/windtail/archive/2012/08/26/2657485.html

http://baike.baidu.com/link?url=CNP55LTT8JmvtkmmQm_Jy-KOLa2zh0_LtTqMpNDL_wepPK3gcqVHpRuX1USESsO4yPC_haMoplNMz34qspE0hK 汉子国标码

然后网页端提交过来给web 服务器的cgi 收到的数据是utf8而且字体间还带百分号间隔符,

编码换算在线查找网站:

http://www.mytju.com/classcode/tools/encode_gb2312.asp

http://www.2fz1.com/so/

(2)编码换算

  由于web端获取的文字编码是utf8,而点阵用的是gb2314,这里的坐下换算,将16进制的字符串转换成对应的数字!

将一个十六进制数的字符串表示形式转换成对应的整数。所谓的十六进制数的字符串形式是指字符串只包含'0'-'9'或者'a'-'z'或者'A'-'Z',前导“0x”或者“0X”是否出现都可以。

要解决这个问题,还需要一个将大写字母转换成小写字母的工具函数:

  1. /*将大写字母转换成小写字母*/
  2. int tolower(int c)
  3. {
  4. if (c >= 'A' && c <= 'Z')
  5. {
  6. return c + 'a' - 'A';
  7. }
  8. else
  9. {
  10. return c;
  11. }
  12. }

下面是转换函数:

  1. //将十六进制的字符串转换成整数
  2. int htoi(char s[])
  3. {
  4. int i;
  5. int n = 0;
  6. if (s[0] == '0' && (s[1]=='x' || s[1]=='X')) //判断是否有前导0x或者0X
  7. {
  8. i = 2;
  9. }
  10. else
  11. {
  12. i = 0;
  13. }
  14. for (; (s[i] >= '0' && s[i] <= '9')
  15. || (s[i] >= 'a' && s[i] <= 'z') || (s[i] >='A' && s[i] <= 'Z');++i)
  16. {
  17. if (tolower(s[i]) > '9')
  18. {
  19. n = 16 * n + (10 + tolower(s[i]) - 'a');
  20. }
  21. else
  22. {
  23. n = 16 * n + (tolower(s[i]) - '0');
  24. }
  25. }
  26. return n;
  27. }
  28. 编码转换:
  29. void UTF_8ToUnicode(wchar_t* pOut,char *pText)
    {
    char* uchar = (char *)pOut;
    uchar[1] = ((pText[0] & 0x0F) << 4) + ((pText[1] >> 2) & 0x0F);
    uchar[0] = ((pText[1] & 0x03) << 6) + (pText[2] & 0x3F);
    }
    void UnicodeToUTF_8(char* pOut,wchar_t* pText)
    {
    // 注意 WCHAR高低字的顺序,低字节在前,高字节在后
    char* pchar = (char *)pText;
    pOut[0] = (0xE0 | ((pchar[1] & 0xF0) >> 4));
    pOut[1] = (0x80 | ((pchar[1] & 0x0F) << 2)) + ((pchar[0] & 0xC0) >> 6);
    pOut[2] = (0x80 | (pchar[0] & 0x3F));
    }
    void UnicodeToGB2312(char* pOut,wchar_t uData)
    {
    WideCharToMultiByte(CP_ACP,NULL,&uData,1,pOut,sizeof(wchar_t),NULL,NULL);
    }
    void Gb2312ToUnicode(wchar_t* pOut,char *gbBuffer)
    {
    ::MultiByteToWideChar(CP_ACP,MB_PRECOMPOSED,gbBuffer,2,pOut,1);
    }
    void GB2312ToUTF_8(string& pOut,char *pText, int pLen)
    {
    char buf[4] = {0};
    int nLength = pLen* 3;
    char* rst = new char[nLength];
    memset(rst,0,nLength);
    int i = 0 ,j = 0;
    while(i < pLen)
    {
    //如果是英文直接复制就可以
    if( *(pText + i) >= 0)
    {
    rst[j++] = pText[i++];
    }
    else
    {
    wchar_t pbuffer;
    Gb2312ToUnicode(&pbuffer,pText+i);
    UnicodeToUTF_8(buf,&pbuffer);
    rst[j] = buf[0];
    rst[j+1] = buf[1];
    rst[j+2] = buf[2];
    j += 3;
    i += 2;
    }
    }

    rst[j] ='\n'; //返回结果
    pOut = rst;
    delete []rst;
    return;
    }
    void UTF_8ToGB2312(char*pOut, char *pText, int pLen)
    {
    char Ctemp[4];
    memset(Ctemp,0,4);
    int i =0 ,j = 0;
    while(i < pLen)
    {
    if(pText[i] >= 0)
    {
    pOut[j++] = pText[i++];
    }
    else
    {
    WCHAR Wtemp;
    UTF_8ToUnicode(&Wtemp,pText + i);
    UnicodeToGB2312(Ctemp,Wtemp);
    pOut[j] = Ctemp[0];
    pOut[j + 1] = Ctemp[1];
    i += 3;
    j += 2;
    }
    }
    pOut[j] ='\n';
    return;
    }

  30. 当然后面还有已经实现的现成的代码

http://www.linuxidc.com/Linux/2012-01/51571.htm

http://blog.163.com/lyq_163_2009/blog/static/13408269620116752322992/

http://blog.csdn.net/yeyuangen/article/details/6722193

http://blog.csdn.net/searchsun/article/details/2443867 yuv格式详解

http://www.cnblogs.com/skywang12345/p/3360348.html

http://blog.csdn.net/shen_001/article/details/7785713 opengl

http://blog.csdn.net/shen_001/article/details/7818972

http://blog.csdn.net/hitexam/article/details/5996607

(3)时间获取

a8 linux 端的时间获取容易直接调用localtime函数,但是dsp m3端的数据获取则只能通过util_time,获取自开机开始的定时时间,并没有从a8端获取准确时间,做的时候以为dsp端能获取时间,后面发现没有时间获取,发现之前的ipnc也是从a8端通过消息发送过来的,所以最后也是通过数据结构体把整个时间获取过来从dsp,

dsp 端的秒换算:

/*
* 毫秒转化
*/
public static String formatTime(long ms) { int ss = 1000;
int mi = ss * 60;
int hh = mi * 60;
int dd = hh * 24; long day = ms / dd;
long hour = (ms - day * dd) / hh;
long minute = (ms - day * dd - hour * hh) / mi;
long second = (ms - day * dd - hour * hh - minute * mi) / ss;
long milliSecond = ms - day * dd - hour * hh - minute * mi - second * ss; String strDay = day < 10 ? "0" + day : "" + day; //天
String strHour = hour < 10 ? "0" + hour : "" + hour;//小时
String strMinute = minute < 10 ? "0" + minute : "" + minute;//分钟
String strSecond = second < 10 ? "0" + second : "" + second;//秒
String strMilliSecond = milliSecond < 10 ? "0" + milliSecond : "" + milliSecond;//毫秒
strMilliSecond = milliSecond < 100 ? "0" + strMilliSecond : "" + strMilliSecond; return strMinute + " 分钟 " + strSecond + " 秒";
}

http://www.educity.cn/wenda/307912.html

http://blog.csdn.net/fuxiaohui/article/details/25505823

http://e2e.ti.com/support/dsp/davinci_digital_media_processors/f/717/p/300747/1048610

http://www.deyisupport.com/question_answer/dsp_arm/davinci_digital_media_processors/f/39/t/67246.aspx 潘哥哥 吼吼!

http://www.baidu.com/s?ie=utf-8&f=8&rsv_bp=1&rsv_idx=1&tn=baidu&wd=8148%20m3%20time&rsv_pq=bda1d8430003d3c6&rsv_t=b4a1GGNFu6c4DQJDxpoJ24o5SVfYK1%2BUvQhz4DOtkNLPQrCQ0P5%2FsAlbY6k&rsv_enter=1&inputT=1233&rsv_sug3=25&rsv_sug4=2728&rsv_sug2=0

http://e2e.ti.com/support/dsp/davinci_digital_media_processors/f/717/t/271976

http://www.360doc.com/content/12/0306/17/19692_192255025.shtml

http://net.pku.edu.cn/~yhf/linux_c/function/02.html

http://blog.donews.com/quickmouse/archive/2008/05/08/1287733.aspx

http://blog.donews.com/quickmouse/archive/2008/05/08/1287733.aspx

(4)显示切换

  这次做布局显示切换时发现,48的功能还是挺强大的,可以做任意矩形图布局,而且还可以做屏幕叠加。

http://www.baidu.com/s?ie=utf-8&f=8&rsv_bp=1&rsv_idx=1&tn=baidu&wd=8148%20m3%20time&rsv_pq=bda1d8430003d3c6&rsv_t=b4a1GGNFu6c4DQJDxpoJ24o5SVfYK1%2BUvQhz4DOtkNLPQrCQ0P5%2FsAlbY6k&rsv_enter=1&inputT=1233&rsv_sug3=25&rsv_sug4=2728&rsv_sug2=0

http://www.deyisupport.com/question_answer/dsp_arm/davinci_digital_media_processors/f/39/t/17971.aspx m3端的地址转换

http://www.deyisupport.com/question_answer/dsp_arm/davinci_digital_media_processors/f/39/t/54118.aspx display

http://www.deyisupport.com/question_answer/dsp_arm/davinci_digital_media_processors/f/39/t/59513.aspx display link

http://www.deyisupport.com/question_answer/dsp_arm/davinci_digital_media_processors/f/39/p/18848/63772.aspx 12路解码

树莓派

http://www.2fz1.com/

嵌入式开发之字符叠加---gb2313 国标码,utf8 国际码,unicode 无码的更多相关文章

  1. Swift开发小技巧--扫描二维码,二维码的描边与锁定,设置扫描范围,二维码的生成(高清,无码,你懂得!)

    二维码的扫描,二维码的锁定与描边,二维码的扫描范围,二维码的生成(高清,无码,你懂得!),识别相册中的二维码 扫描二维码用到的三个重要对象的关系,如图: 1.懒加载各种类 // MARK: - 懒加载 ...

  2. arcgis api 3.x for js 入门开发系列批量叠加 zip 压缩 SHP 图层优化篇(附源码下载)

    前言 关于本篇功能实现用到的 api 涉及类看不懂的,请参照 esri 官网的 arcgis api 3.x for js:esri 官网 api,里面详细的介绍 arcgis api 3.x 各个类 ...

  3. 学习嵌入式开发板的Android平台体系结构和源码结构

    本文转自迅为论坛资料:http://www.topeetboard.com 推荐学习嵌入式开发板平台:iTOP-4412开发板 下面这张图出自Google官方,展示了Android系统的主要组成部分. ...

  4. 嵌入式开发—C语言面试题

    嵌入式开发—C语言面试题 源地址:http://blog.csdn.net/xdx2ct1314/article/details/7358929   1. 用预处理指令#define 声明一个常数,用 ...

  5. [嵌入式开发]Linux性能分析——上下文切换

    一.从一个问题说起 相信很多人在玩手机还是PC时,都曾碰到过这样一种情况,安装的软件多了系统性能就变慢了,但是去查看CPU利用率一直都低于10%,内存也很充足.我在近期的开发工作中就碰到了类似的情况, ...

  6. ARM嵌入式开发板

    iTOP-4412 ARM嵌入式开发板----主要特点 iTOP-4412开发平台是北京迅为电子研发设计的嵌入式开发板平台,核心板配备64位双通道2GB DDR3,16GBEMMC存储,三星原厂S5M ...

  7. 构建 ARM Linux 4.7.3 嵌入式开发环境 —— U-BOOT 引导 Kernel

    经过若干天的反复测试,搜索.终于成功利用 Qemu 在 u-boot 下引导 ARM Linux 4.7.3 内核.如下详细解释整个构建过程. 准备环境 运行环境:Ubuntu 16.04 需要的虚拟 ...

  8. 嵌入式开发平台-iTOP-4418开发板

    详情转自:http://topeetboard.com S5P4418核心板可以无缝支持核心系统S5P6818,并保持底板设计不变,将兼顾更高端 的应用领域,为项目和产品提供更好的灵活性以及可伸缩性. ...

  9. 转:Qt 嵌入式开发环境搭建

    地址: http://www.cnblogs.com/lishixian/articles/3013897.html         作者:lsx_007 这里主要是记录了自己在搭建嵌入式开发环境时阅 ...

随机推荐

  1. Windows 定时删除指定路径下N天前的日志文件

    Windows 定时删除指定路径下N天前的日志文件 Windows 下bat脚本文件的内容为 1. 删除指定路径下5天前的所有文件 @echo off set SrcDir=E:\WORK\Git s ...

  2. 深入分析GCC 与 编绎系统透视

  3. VBA Collection用法总结

    Sub test() ' Dim s As Collection '定义s变量为集合对象 ' Set s = New Collection '初始化集合对象s (否则无法使用) Dim s As Ne ...

  4. 设计模式之原型模式(php实现)

    github地址:https://github.com/ZQCard/design_pattern1.先了解什么是浅拷贝与深拷贝 //深拷贝:赋值时值完全复制,完全的copy,对其中一个作出改变,不会 ...

  5. 使apache的日志文件里不记录图片文件

    找到: LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-A ...

  6. Linux用ps命令查找进程PID再用kill命令终止进程的方法

    使用linux操作系统,难免遇到一些软件"卡壳"的问题,这时就需要使用linux下强大的kill命令来结束相关进程.这在linux系统下是极其容易的事情,你只需要kill xxx即 ...

  7. pip install 报错UnicodeDecodeError: 'ascii' codec can't decode byte

    2017-03-23 报错原因: pip安装Python包会加载我的用户目录,我的用户目录恰好是中文的,ascii不能编码. 解决办法: python目录 Python27\Lib\site-pack ...

  8. JavaScript Best Practices

    原文: https://www.w3schools.com/js/js_best_practices.asp --------------------------------------------- ...

  9. 固态硬盘(Solid State Drives)

    固态硬盘(Solid State Drives) 学习了:https://baike.baidu.com/item/%E5%9B%BA%E6%80%81%E7%A1%AC%E7%9B%98/45351 ...

  10. sql取随机结果集

    应用场景: 某日,接产品姐姐需求,网站搜索页在搜索特定的内容时候,会现实搜索不到结果!如衣服网站,搜索鞋子等.为了不直接呈现一个赤裸裸的无此商品页面,so,需要在搜索商品件数小于3时,在下面随机推荐本 ...