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

📄 8x10b触摸屏(中断法).txt

📁 D系列触摸屏的程序
💻 TXT
字号:
#include <reg52.h>
#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#include <intrins.h>

#define data_ora   P1              //MCU P1<------> LCM
#define uchar      unsigned char
#define uint       unsigned int

sbit req =P3^0;  //请求信号,H有效
sbit busy=P3^1;  //H:已收到数据并在处理中,L:空闲可接收数据
sbit ip=P3^2;
sbit CS=P3^3;
sbit DIN=P3^4;
sbit STA=P3^5;
sbit DOUT=P3^6;
sbit DCLK=P3^7;  //根据用户自己的定义

uchar taby[4];
uchar tabx[4];
uint y[4];
uint x[4];
uint a,b;

uchar r,q=0;
uchar code tab[]={
"触摸屏功能测试中"
};

void wr_zb(uchar comm,uchar addr_x,uchar addr_y);
void send (uchar dat);
void disp_lat (uchar data1,uchar data2);
void disp_img (uchar code *img);
void disp_chn (uchar code *chn);
void disp_chn1 (uchar code *chn);
void disp_chn2 (uchar code *chn);
void disp_eng (uchar code *eng);

/*--------------显示点阵------------------*/
void disp_lat (uchar data1,uchar data2)
{
  uchar i,j,k;
  for(k=0;k<128;k=k+4)
  {
    for(j=0;j<2;j++)
    {
      for(i=0;i<20;i++)
      {
        wr_zb(0xf3,i,k+j);
        send(data1);
      }
    }
    for(j=2;j<4;j++)
    {
      for(i=0;i<20;i++)
      {
        wr_zb(0xf3,i,k+j);
        send(data2);
      }
    }
  }
}
/*-----------------显示图形-----------------*/
void disp_img (uchar code *img)
{
  uchar i,j;
  for(j=0;j<128;j++)
  {
    for(i=0;i<20;i++)
    {
      wr_zb(0xf3,i,j);
      send(img[j*20+i]);
    }
  }
}
/*--------------显示中文------------------*/
void disp_chn2 (uchar code *chn)
{
  uchar i,j;
  for(j=0;j<8;j++)
  {
    for(i=0;i<10;i++)
    {
      wr_zb(0xf0,i,j);
      send(chn[j*20+i*2]-0xa0);
      send(chn[j*20+i*2+1]-0xa0);
    }
  }
}
/*--------------显示字符------------------*/
void disp_eng (uchar code *eng)
{
  uchar i,j;
  for(j=0;j<8;j++)
  {
    for(i=0;i<20;i++)
    {
      wr_zb(0xf9,i,j*16);
      send(eng[j*20+i]);
    }
  }
}
void disp_chn (uchar code *chn)
{
  uchar i;
 
    for(i=1;i<9;i++)
    {
      wr_zb(0xf0,i,0);
      send(chn[(i-1)*2]-0xa0);
      send(chn[(i-1)*2+1]-0xa0);
    }
  
}
void disp_chn1 (uchar code *chn)
{
 uchar i;
 
    for(i=2;i<10;i++)
    {
      wr_zb(0xf0,i,2);
      send(chn[(i-2)*2]-0xa0);
      send(chn[(i-2)*2+1]-0xa0);
    }
  
	
    for(i=2;i<10;i++)
    {
      wr_zb(0xf0,i,3);
      send(chn[(i+6)*2]-0xa0);
      send(chn[(i+6)*2+1]-0xa0);
    }
  
}

/*---------------延时子程序----------------*/
void delay (uint us)
{
  while(us--);
}
void delay1 (uint ms)
{
  uint i,j;
  for(i=0;i<ms;i++)
  for(j=0;j<1000;j++)
  ;
}
/*------------写命令或数据到LCD--------------*/
void wr_zb (uchar comm,uchar addr_x,uchar addr_y)
{
  send(comm);
  send(addr_x);
  send(addr_y);
}
void send (uchar dat)               //写命令或数据
{
  while(busy==1)
    ;
  data_ora=dat;
  req=1;
  while(busy==0)
    ;
  req=0;
}


WriteCharTo7843(unsigned char num) //SPI写数据
{
unsigned char count=0;
DCLK=0;
for(count=0;count<8;count++)
{
num<<=1;
DIN=CY;
DCLK=0; _nop_();_nop_();_nop_(); //上升沿有效
DCLK=1; _nop_();_nop_();_nop_();
}
}


ReadFromCharFrom7843() //SPI 读数据
{
unsigned char count=0;
unsigned int Num=0;
for(count=0;count<12;count++)
{
Num<<=1;
DCLK=1; _nop_();_nop_();_nop_(); 
DCLK=0; _nop_();_nop_();_nop_();
if(DOUT) Num++;
}

return(Num);

}
void start() //SPI开始
{
DCLK=0;
CS=1;
DIN=1;
DCLK=1;
CS=0;
}

void go() interrupt 0//外部中断0 用来接受键盘发来的数据
{
unsigned int X=0,Y=0;
//uchar e,q;
IE=0;        //关中断
//delay(10000); 
//中断后延时以消除抖动,使得采样数据更准确
start(); //启动SPI
//while(BUSY1); //如果BUSY信号不好使可以删除不用
delay(2);
WriteCharTo7843(0x90); //送控制字 10010000 即用差分方式读X坐标 详细请见有关资料
//while(BUSY1); //如果BUSY信号不好使可以删除不用
delay(2);
DCLK=1; _nop_();_nop_();_nop_();_nop_();
DCLK=0; _nop_();_nop_();_nop_();_nop_();
X=ReadFromCharFrom7843();  //读X轴坐标
WriteCharTo7843(0xD0); //送控制字 11010000 即用差分方式读Y坐标 详细请见有关资料
DCLK=1; _nop_();_nop_();_nop_();_nop_();
DCLK=0; _nop_();_nop_();_nop_();_nop_();
Y=ReadFromCharFrom7843();  //读Y轴坐标
CS=1;
ip=1;

tabx[0]=(Y/1000);
tabx[1]=(Y-tabx[0]*1000)/100;
tabx[2]=(Y-tabx[0]*1000-tabx[1]*100)/10;
tabx[3]=(Y-tabx[0]*1000-tabx[1]*100-tabx[2]*10);
taby[0]=(X/1000);
taby[1]=(X-taby[0]*1000)/100;
taby[2]=(X-taby[0]*1000-taby[1]*100)/10;
taby[3]=(X-taby[0]*1000-taby[1]*100-taby[2]*10);

for(r=6;r<10;r++)
{     wr_zb(0xf9,r,16);
      send(tabx[r-6]+48);
}
for(r=13;r<17;r++)
{      wr_zb(0xf9,r,16);
      send(taby[r-13]+48);
}
delay1(50);
IE=0x81;      //开中断

}
void main ()
{
  SP=0x5f;
  req=0;
  busy=1;
  
  IE=0x81; //1000 0001 EA=1中断允许
  IT0=0;
  //wr_zb(0xf9,2,0);
  disp_chn(tab);
  wr_zb(0xf9,4,16);
  send(0x58);
  wr_zb(0xf9,5,16);
  send(0x3d);
  wr_zb(0xf9,11,16);
  send(0x59);
  wr_zb(0xf9,12,16);
  send(0x3d);
  //IP=0x01;
 while(1)
  {
  ;
  }
}

⌨️ 快捷键说明

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