这是液晶12864的显示程序
#include <reg51.h>
sbit RS=P2^2// 数据\指令 选择
sbit RW=P2^1// 读\写 选择
sbit E=P2^0// 读\写使能
sbit CS1=P2^4// 片选1
sbit CS2=P2^3// 片选2
unsigned int number=0,mstcnt=0 //number 控制显示的字符个数,mstcnt用于延时控制
unsigned char code ziku[]=
{
/* 此方法显示的汉字为下稿含半列排,即先分为上下两半,然后先取上半部分的点阵数据,且点阵对应的数为从下看到上 D7~D0
/*-- 文字: 我 -- 采用下半列排的方式,送数的派顷方式:它是显8*16后接着换下一页显下半8*16
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
/*-- 文字: 欢 --*/
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
0x14,0x24,0x44,0x84,0x64,0x1C,0x20,0x18,0x0F,0xE8,0x08,0x08,0x28,0x18,0x08,0x00,
0x20,0x10,0x4C,0x43,0x43,0x2C,0x20,0x10,0x0C,0x03,0x06,0x18,0x30,0x60,0x20,0x00,
/*-- 文字: 迎 --*/
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
0x40,0x41,0xCE,0x04,0x00,0xFC,0x04,0x02,0x02,0xFC,0x04,0x04,0x04,0xFC,0x00,0x00,
0x40,0x20,0x1F,0x20,0x40,0x47,0x42,0x41,0x40,0x5F,0x40,0x42,0x44,0x43,0x40,0x00,
/*-- 文字: 大 --*/
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
0x20,0x20,0x20,0x20,0x20,0x20,0xA0,0x7F,0xA0,0x20,0x20,0x20,0x20,0x20,0x20,0x00,
0x00,0x80,0x40,0x20,0x10,0x0C,0x03,0x00,0x01,0x06,0x08,0x30,0x60,0xC0,0x40,0x00,
/*-- 文字: 家 --*/
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
0x00,0x18,0x04,0x14,0x94,0x94,0xD5,0xB6,0x14,0x14,0x94,0x04,0x14,0x0C,0x04,0x00,
0x00,0x29,0x29,0x15,0x14,0x4A,0x89,0x44,0x3F,0x06,0x09,0x09,0x10,0x30,0x10,0x00,
/*-- 文字: 点 --*/
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
0x00,0x00,0x00,0xE0,0x20,0x20,0x20,0x3F,0x24,0x24,0x24,0xF4,0x24,0x00,0x00,0x00,
0x00,0x40,0x30,0x07,0x12,0x62,0x02,0x0A,0x12,0x62,0x02,0x0F,0x10,0x60,0x00,0x00,
/*-- 文字尘敬陆: 击 --*/
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
0x00,0x80,0x88,0x88,0x88,0x88,0x88,0xFF,0x88,0x88,0x88,0x88,0x88,0xC0,0x80,0x00,
0x00,0x00,0x00,0x7E,0x20,0x20,0x20,0x3F,0x20,0x20,0x20,0x20,0x7E,0x00,0x00,0x00,
/*-- 文字: 我 --*/
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
0x20,0x20,0x22,0x22,0xFE,0x21,0x21,0x20,0x20,0xFF,0x20,0x22,0xAC,0x20,0x20,0x00,
0x04,0x04,0x42,0x82,0x7F,0x01,0x01,0x10,0x10,0x08,0x07,0x1A,0x21,0x40,0xF0,0x00,
/*-- 文字: 的 --*/
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
0x00,0xF8,0x8C,0x8B,0x88,0xF8,0x40,0x30,0x8F,0x08,0x08,0x08,0x08,0xF8,0x00,0x00,
0x00,0x7F,0x10,0x10,0x10,0x3F,0x00,0x00,0x00,0x03,0x26,0x40,0x20,0x1F,0x00,0x00,
/*-- 文字: 博 --*/
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
0x20,0x20,0xFF,0x20,0x20,0x04,0xF4,0x54,0x54,0xFF,0x54,0x55,0xF6,0x04,0x00,0x00,
0x00,0x00,0xFF,0x00,0x04,0x04,0x0F,0x35,0x15,0x47,0x85,0x7F,0x07,0x04,0x04,0x00,
/*-- 文字: 客 --*/
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
0x00,0x18,0x04,0x84,0x44,0x7C,0xA5,0x26,0x24,0xA4,0x64,0x24,0x14,0x0C,0x04,0x00,
0x08,0x08,0x05,0x04,0xFC,0x46,0x46,0x45,0x45,0x46,0x46,0xFE,0x04,0x0C,0x04,0x00,
/*-- 文字: 谢 --*/
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
0x40,0x42,0xCC,0x04,0x00,0xFC,0x56,0x55,0xFC,0x50,0x90,0x10,0xFF,0x10,0x10,0x00,
0x00,0x00,0x3F,0x50,0x29,0x11,0x4D,0x83,0x7F,0x00,0x41,0x80,0x7F,0x00,0x00,0x00,
/*-- 文字: 谢 --*/
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
0x40,0x42,0xCC,0x04,0x00,0xFC,0x56,0x55,0xFC,0x50,0x90,0x10,0xFF,0x10,0x10,0x00,
0x00,0x00,0x3F,0x50,0x29,0x11,0x4D,0x83,0x7F,0x00,0x41,0x80,0x7F,0x00,0x00,0x00,
/*-- 文字: 使 --*/
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
0x40,0x20,0xF0,0x1C,0x07,0xF2,0x94,0x94,0x94,0xFF,0x94,0x94,0x94,0xF4,0x04,0x00,
0x00,0x00,0x7F,0x00,0x40,0x41,0x22,0x14,0x0C,0x13,0x10,0x30,0x20,0x61,0x20,0x00,
/*-- 文字: 用 --*/
/*-- 宋体12 此字体下对应的点阵为:宽x高=16x16 --*/
0x00,0x00,0x00,0xFE,0x22,0x22,0x22,0x22,0xFE,0x22,0x22,0x22,0x22,0xFE,0x00,0x00,
0x80,0x40,0x30,0x0F,0x02,0x02,0x02,0x02,0xFF,0x02,0x02,0x42,0x82,0x7F,0x00,0x00,
}
checkstate() //状态检测(检查Busy)
{
unsigned char dat
RS=0//表示DB7~DBO为显示指令数据
RW=1//数据被读到DB7~DBO
do
{
P1=0x00
E=1 //E信号下降沿锁存DB7~DBO
dat=P1 //读入P1的值
E=0 //锁存
dat=0x80 &dat//仅当第7位为0时才可 *** 作(判别busy信号)为0时不忙
//BUSY:1内部在工作,0正常状态
}while(!(dat==0x00))
}
void writecommand(unsigned char command) //写命令
{
checkstate()//检查Busy
RW=0
P1=command
E=1
E=0
}
void writedate(unsigned char date) //写数据
{
checkstate()
RS=1
RW=0
P1=date
E=1
E=0
}
void cleanscreen() //清屏
{
unsigned char page,i
for(page=0xb8page<0xc0page++)//共八页
{
writecommand(page) ///思路基本一样,从第一页写到最后一页
writecommand(0x40) ///数据指针 第一列开始
for(i=0i<64i++)///0~63列
writedate(0x00)
}
}
void choosescreen(unsigned char NO) //选择屏幕 两屏
{
switch (NO)
{
case 0:
CS1=0
CS2=0
break //不选,不显示
case 1:
CS1=0
CS2=1
break
case 2:
CS1=1
CS2=0
break
default:
break
}
}
void lce_init(void)//初始化
{
writecommand(0xc0)//设置显示起始行
writecommand(0x3f)//显示开关控制
}
void display(unsigned char count) //显示
{
unsigned int i,m,page=0xb8//0xb8设置设置页地址为第0页
choosescreen(1)
writecommand(0xb8)选择页面
writecommand(0x40)起始列
for(i=0i<count*16i++)
{
if(i!=0&&i%16==0)
m++
switch (i) //控制显示的页指针与列指针
{
case 64: //显示的列累计求和 得所有左右屏四列的开始为 0.64 128.192 256.320 384.448
choosescreen(2) //右屏
writecommand(page)//字的上半部分 此显示方法与直接控制页显示类似,不过改进之处在于可逐字显示
writecommand(0x40)//设置起始列
break
case 128:
choosescreen(1) //左屏
writecommand(page+2)
writecommand(0x40)
break
case 192:
choosescreen(2)
writecommand(page+2)
writecommand(0x40)
break
case 256:
choosescreen(1)
writecommand(page+4)
writecommand(0x40)
break
case 320:
choosescreen(2)
writecommand(page+4)
writecommand(0x40)
break
case 384:
choosescreen(1)
writecommand(page+6)
writecommand(0x40)
break
case 448:
choosescreen(2)
writecommand(page+6)
writecommand(0x40)
break
default:
break
}
writedate(*(ziku+i+m*16))
}
choosescreen(1)
page=0xb9
writecommand(page)
writecommand(0x40)
m=0
/*
writecmd1(m)//上下循环显示
if(m==0xff)
{
m=0xc0
}
m++
writecmd2(n)
if(n==0xff)
{
n=0xc0
}
n++
*/
for(i=0i<count*16i++)
{
if(i!=0&&i%16==0)
m++
switch (i)//控制显示的页指针与列指针
{
case 64://显示的列累计求和
choosescreen(2)//右屏
writecommand(page)//字的下半部分
writecommand(0x40)
break
case 128:
choosescreen(1)//左屏
writecommand(page+2)
writecommand(0x40)
break
case 192:
choosescreen(2)
writecommand(page+2)
writecommand(0x40)
break
case 256:
choosescreen(1)
writecommand(page+4)
writecommand(0x40)
break
case 320:
choosescreen(2)
writecommand(page+4)
writecommand(0x40)
break
case 384:
choosescreen(1)
writecommand(page+6)
writecommand(0x40)
break
case 448:
choosescreen(2)
writecommand(page+6)
writecommand(0x40)
break
default:
break
}
writedate(*(ziku+i+m*16+16))
}
m=0
}
void t0(void) interrupt 1 using 0
{
mstcnt++
if(mstcnt==2000)
{
mstcnt=0
number++
}
}
main()
{
TMOD=0x02
TH0=0x06 //// 6650us定时中断
TL0=0x06
TR0=1
ET0=1
EA=1
E=1
choosescreen(0)
cleanscreen()
lce_init()
while(1)
{
display(number)
if(number==33)
{
number=0
choosescreen(0)
cleanscreen()
}
}
}
在许多c程序设计中,要用到汉字进行提示或人机交互,而现行的turbo c集成开发环境不是汉化的,如何编制碰腊能显示汉字的c程序呢?下面的方法可以帮你在西文环境下显示汉字。这种方法是调用中文汉字库进行汉字显示。国家标准规定:汉字库分94个区,每个区有94个汉字(以位作区别),每个汉字在汉字库中有确定的区和位编号,这就是汉字的区位码。每个汉字在库中是以点阵字模形式存储的,一般采用16×16点阵(32字节)、24×24点阵(72字节),每个点用一个二进制位(0或1)表示,对应在屏幕上显示出来,就是相应的汉字。
由于在中文环境下,输入的是汉字的内码,我们必须将之转换成区位码,算出偏移量,从字库中找到对应的汉字,将其字模显示即可。
内码转换成区位码方法如下:
qh=c1-0xa0 wh=c2-0xa0
其区位码就是:
qw=qh*0xff+wh
该汉字在字库中离起点的位置是:
offset=(94*(qh-1)+(wh-1))*32l
程序例:
#include 〈graphics.h〉
#include 〈stdio.h〉
#include 〈fcntl.h〉
#include 〈io.h〉
#include 〈stdlib.h〉
#include 〈conio.h〉
#define row 1 //纵坐标放大倍数
#define col 2 //横坐标放大倍数
void main()
{
int x,y
char *s=〃汉字显示程序〃
file *fp
char buffer[32]//buffer用来存储一个汉字
register m,n,i,j,k
unsigned char qh,wh
unsigned long offset
int gd=detect,gm//图形屏幕初始化
initgraph(&gd,&gm,〃 〃)
if ((fp=fopen(〃hzk16〃,〃rb〃))==null)
//打开汉字库,该字库可以在ucdos中找到
{ printf(〃can´t open haz16,please add it〃)
getch()closegraph()exit(0)
}
x=20y=100//显示位置设置
while(*s)
{ qh=*(s)-0xa0//汉字区位码
wh=*(s+1)-0xa0
offset=(94*(qh-1)+(wh-1))*32l//计算该汉字在字库中偏移量
fseek(fp,offset,seek_set)
fread(buffer,32,1,fp)//取出汉字32字节的点阵字模存入buffer中(一个汉字)
for (i=0i〈16i++) //将32位字节的点阵按位在屏幕上打印出来(1:打印,0:不打印),显示汉字
for(n=0n〈rown++)
for(j=0j〈2j++)
for(k=0k〈8k++)
for(m=0m〈colm++)
if (((buffer[i*2+j]〉〉(7-k))&0x1)!=null)
putpixel(x+8*j*col+k*col+m,y+i*row+n,green)
s+=2//因为一个汉字内码占用两个字节,所笑稿滑以s必须加敬塌2
x+=30
}
getch()
closegraph()
}
上述程序在turbo c 2.0编译系统下运行成功,它可以将汉字放大显示,读者可以将它改成函数用在您的程序中显示汉字。
int 汉字的个塌物饥数=this.textBox1.Text.Lengthstring inputStr = this.textBox1.Text
string content = null
int currentcode=-1
for (int i = 0i <inputStr.Lengthi++)
{
currentcode=(int)inputStr[i]
if (currentcode >19968&¤tcode <蚂型 40869)/团返/中文的asc码范围
{
content+=inputStr[i]
}
int 汉字的个数 = content.Length
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)