⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dzshowmode2.c

📁 该工程的开发环境为Keil uVision2,实现的功能是在16×64的点阵屏上以逐行向上移动的方式显示汉字.
💻 C
字号:
//************************************************
//在16×64的点阵显示屏上逐行向上移动显示中文汉字
//点阵码由串口输入,接收点阵码采用中断方式
//************************************************
#include "reg52.h"
#include "intrins.h"
#include "absacc.h"
#include <stdio.h>
#define nop _nop_()
#define uchar unsigned char
#define DELAY_VALUE 300

sbit h_clk=P1^3;	//行 clk
sbit h_data=P1^6;	//行 data
sbit h_str=P1^7;	//行 str
sbit l_clk=P1^4;	//列 clk
sbit l_data=P1^2;	//列 data
sbit l_str=P1^5;	//列 str
sbit h_oe=P1^0;		//行 oe
int flag=0;
int EvRcv=0;
unsigned char rcvdata=0;	//从串口存储解手的变量
int  data_count=129;
int xdata xdata_count ;
uchar xdata word[2000] _at_ 0x0000;
int index=0;

uchar xdata * data pword; //指向字的指针

uchar xdata * data ptext;

void init()	   //清屏
{
	int i;
	P1=0xff;
	P0=0x00;
	h_data=1;
	h_str=1;
	h_clk=0;

	for(i=0;i<32;i++)
	{
		nop;nop;
		h_clk=!h_clk;	
	}

	h_clk=0;
	l_clk=0;
}

void initial()	//系统初始化
{
	IP=0x10; // 串行口定义为高优先级中断
	IE=0x97; //CPU开放中断,允许串行口中断
	TCON=0x05; //置中断触发方式为跳变触发
	TMOD=0x20; //T1工作,8位定时器/计数器
	PCON=0; //波特率选择 
	SCON=0x50;//串行口工作方式1,异步通信
	TH1=0xFD; //定时时间为1ms
	TL1=0xFD;
	TR1=1; //允许T1启动计数
	EA=1; //开中断

}
void delay(int i)
{
	int j=0;
	i=i*DELAY_VALUE;
	while(j<i)j++;
}

void savedata(unsigned char a)
{
	ptext[index]=a; //index=0
	index++;
    delay(150);
}

void input()  //取点阵码
{
 uchar t;
 t=*pword;
 if(t&0x01)
 l_data=1;
 else l_data=0;
 l_clk=1;
 l_clk=0;
 if(t&0x02)
 l_data=1;
 else l_data=0;
 l_clk=1;
 l_clk=0;
 if(t&0x04)
 l_data=1;
 else l_data=0;
 l_clk=1;
 l_clk=0;
 if(t&0x08)
 l_data=1;
 else l_data=0;
 l_clk=1;
 l_clk=0;
 if(t&0x10)
 l_data=1;
 else l_data=0;
 l_clk=1;
 l_clk=0;
 if(t&0x20)
 l_data=1;
 else l_data=0;
 l_clk=1;
 l_clk=0;
 if(t&0x40)
 l_data=1;
 else l_data=0;
 l_clk=1;
 l_clk=0;
 if(t&0x80)
 l_data=1;
 else l_data=0;
 l_clk=1;
 l_clk=0;
}

void main()
{
	int j=0,k=0;
	int count=0;
	int num;
	int i=0,i1,i2,i3,i4;
	int temp=384,temp1=1;
    int flag1=0;
	ptext = word;
	initial();
	init();
	while(1)
	{
		if(flag==0)
	    {//if(flag)
                   for(num=0;num<((temp-1)/128+1)*16;num++)
 				   {
                    pword=word;
                   for(i2=0;i2<16;i2++)
				   {//延时
				   for(i=0;i<16;i++)
                   {
                     h_data=0;
                     nop;
                     h_clk=!h_clk;
                     nop;
                     h_clk=!h_clk;
                   }
				   if(num<16)
				   {
				    for(j=0;j<=num;j++)
                   {
				    if(flag==1)
					   break;
                    h_oe=0;
				    pword=word+2*j;		           
                    for(i1=0;i1<4;i1++)
				    {
				        l_clk=0;
				        input();
					    pword++;
					    input();
					    pword=pword+31;
                    }
				   	if(j==0) 
                    {
                     h_clk=0;
				     h_data=1; 
					 h_clk=!h_clk;
					 nop;nop;
					 h_clk=!h_clk;
					 h_data=0;
				     for(i3=0;i3<(30-2*num);i3++)
			         {    
				       nop;nop;
				       h_clk=!h_clk;
				     }
                    }
                    else
                    {
                      h_data=0;
                      h_clk=!h_clk;
                      nop;nop;
                      h_clk=!h_clk;
                    } 
				   h_oe=1;
				 
				  for(i4=0;i4<100;i4++)
					   nop;
                     }//for j
					}
				   else
				   {
                     for(j=0;j<=15;j++)
                   {
				    if(flag==1)
					   break;
                    h_oe=0;
					if(num<32)
					{
					 if(j<=15-(num-15))
				        pword=word+2*(j+num-15);
		             else
					    pword=word+128+2*(j-30+num);
					}
					else
					{
					 if(j<=15-(num-31))
					    pword=word+128+2*(j+num-31);
					 else
					    pword=word+256+2*(j-46+num);
					}
                    for(i1=0;i1<4;i1++)
				    {
				        l_clk=0;
				        input();
					    pword++;
					    input();
					    pword=pword+31;
                    }
				   	if(j==0) 
                    {
                     h_clk=0;
				     h_data=1; 
					 h_clk=!h_clk;
					 nop;nop;
					 h_clk=!h_clk;
                    }
                    else
                    {
                      h_data=0;
                      h_clk=!h_clk;
                      nop;nop;
                      h_clk=!h_clk;
                    } 
				   h_oe=1;
				 
				  for(i4=0;i4<100;i4++)
					   nop;
                     }//for j
					}
					}//for i2
				   }//for num
                  break;
	   }//if(flag)
	   if(EvRcv) //是否收到串行数据的标志位
			{
				EvRcv=0;
                flag1++;
				if(count==0)
					temp=rcvdata;
				else if(count==1)
                    temp=rcvdata+temp*256;
                else if(count==2)
                    temp1=rcvdata;
                else
					savedata(rcvdata);
				count++;

				if (count==temp+2)
				{
					flag=0;
					count=0;
					index=0;
					h_oe=1;
				}
			}
	}
}

void Rcv_INT (void) interrupt 4 using 0
{
	
	if(RI)
	{
		h_oe=0;
	    ACC=SBUF;
		rcvdata=ACC;
		h_oe=0;
		EvRcv=1;
		RI=0;
		flag=1;
	}
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -