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

📄 lcd.c

📁 DSP2812 通过GPIO来模拟LCD的控制信号
💻 C
字号:
#include "DSP28_Device.h"


/*************************************************/
/* Delay 1us/unit at 30 MHz DSP crystal clock  */
/*************************************************/
void Delay(long t)
{
  long i;
  int j;
  #ifdef FLASH
  t>>= 1;
  for(i=0;i<t;i++);
  #endif
  for(i=0;i<t;i++)
    for(j=0;j<10;j++);
}

/*------------------初始化-----------------*/
void Init_Lcd (void)
{
  Delay(100);
//  复位LCD
  rst=0;
  Delay(150);
  rst=1;
  //psb=0;
  wr_lcd (comm,0x30);  /*30---基本指令动作*/
  Delay(100);
  wr_lcd (comm,0x0c);  /*开显示,关游标*/
  Delay(100);
  wr_lcd (comm,0x01);  /*清屏,地址指针指向00H,清屏后一定要延时>1000us*/
  Delay(1000);
  wr_lcd (comm,0x06);  /*光标的移动方向*/
  Delay(100);
  
}
/*---------------显示四行汉字或字符-------------ok---*/
void chn_disp (uchar *chn)
{
  uchar i,j;
  wr_lcd (comm,0x30);
  Delay(100);
  wr_lcd (comm,0x80);
  j=0;
  for (i=0;i<16;i++)
 {
  wr_lcd (dat,chn[j*16+i]);
//  Delay(50);
 } 
  wr_lcd (comm,0x90);
//  Delay(50);
  j=1;
  for (i=0;i<16;i++)
 { 
  wr_lcd (dat,chn[j*16+i]);
//  Delay(50);
 } 
  wr_lcd (comm,0x88);
//  Delay(100);
  j=2;
  for (i=0;i<16;i++)
 { 
  wr_lcd (dat,chn[j*16+i]);
//  Delay(50);
 } 
  wr_lcd (comm,0x98);
//  Delay(100);
  j=3;
  for (i=0;i<16;i++)
 { 
  wr_lcd (dat,chn[j*16+i]);
//  Delay(50);
 } 
}

void clrgdram()///
{
  uchar i,j;
 for(j=0;j<32;j++)
  {
    for(i=0;i<16;i++)
    {
	  wr_lcd (comm,0x34);
	  Delay(50);
      wr_lcd (comm,y+j);
//      Delay(40);
      wr_lcd (comm,x+i);
//      Delay(40);
      wr_lcd (comm,0x30);
//      Delay(40);
      wr_lcd (dat,0x00);
//      Delay(40);
      wr_lcd (dat,0x00);
//      Delay(40);
    }
  }
 }
/*----------------显示图形-----------------*/
void img_disp (uchar * img)
{
  uchar i,j;
  clrgdram();
//按照常规的四行显示图象
  for(j=0;j<32;j++) //前两行
  {
    for(i=0;i<8;i++)   
    {
      wr_lcd (comm,0x34);
      Delay(50);
      wr_lcd (comm,y+j);
//      Delay(50);
      wr_lcd (comm,x+i);
//      Delay(50);
      wr_lcd (comm,0x30);
//      Delay(50);
      wr_lcd (dat,img[16*j+i*2]);
//      Delay(50);
      wr_lcd (dat,img[16*j+i*2+1]);
//      Delay(50);
    }
  }
  for(j=0;j<32;j++)//后两行
  {
    for(i=0;i<8;i++)   
    {
      wr_lcd (comm,0x34);
      Delay(50);
      wr_lcd (comm,y+j);
//      Delay(50);
      wr_lcd (comm,x+0x08+i);
//      Delay(50);
      wr_lcd (comm,0x30);
//      Delay(50);
      wr_lcd (dat,img[16*(j+32)+i*2]);
//      Delay(50);
      wr_lcd (dat,img[16*(j+32)+i*2+1]);
//      Delay(50);
    }
  }
  
  wr_lcd (comm,0x36);
  Delay(50);
}
/*--------------显示点阵----------------*/
void lat_disp (uchar data1,uchar data2)
{
  uchar i,j;
  clrgdram();
  for(j=0;j<16;j++)
  {
    for(i=0;i<16;i++)
    {
      wr_lcd (comm,0x34);
      Delay(50);
      wr_lcd (comm,y+j*2);
//      Delay(50);
      wr_lcd (comm,x+i);
//      Delay(50);
      wr_lcd (comm,0x30);
      Delay(50);
      wr_lcd (dat,data1);
//      Delay(50);
      wr_lcd (dat,data1);
//      Delay(50);
    }
    for(i=0;i<16;i++)
    {
      wr_lcd (comm,0x34);
      Delay(50);
      wr_lcd (comm,y+j*2+1);
//      Delay(50);
      wr_lcd (comm,x+i);
//      Delay(50);
      wr_lcd (comm,0x30);
      Delay(50);
      wr_lcd (dat,data2);
//      Delay(50);
      wr_lcd (dat,data2);
//      Delay(50);
    }
  }                       
  wr_lcd (comm,0x36);
  Delay(50);
}
/*-----------------任意位置反白----------------ok-------*/
//当data1=0xff,data2=0xff时,在x0,y0处反白显示16xl*yl.
void con_disp (uchar data1,uchar data2,uchar x0,uchar y0,uchar xl,uchar yl)
{
  uchar i,j;
 //利用绘图RAM和DDRAM同时显示来反白个别字时,首先应将GDRAM清空
  
  clrgdram();

  //显示反白部分
  for(j=0;j<yl;j++)
  {
    for(i=0;i<xl;i++)
    {
      wr_lcd (comm,0x34);
      Delay(50);
      wr_lcd (comm,y0+j);
//      Delay(50);
      wr_lcd (comm,x0+i);
//      Delay(50);
      wr_lcd (comm,0x30);
      Delay(50);
      wr_lcd (dat,data1);
//      Delay(50);
      wr_lcd (dat,data2);
//      Delay(50);
    }
  }
  wr_lcd (comm,0x36);
  Delay(50);
}
/*--------------清DDRAM-----------ok-------*/
void clrddram (void)
{
  wr_lcd (comm,0x30);
  Delay(100);
  wr_lcd (comm,0x01);
  Delay (1000);
}

/*---------------------------------------*/
void wr_lcd (uchar dat_comm,uchar content)///
{
  uchar cont,i,j;
  Delay (10);
  cont=content;
  cs=1;
  Delay (1);
  std=1;
  Delay (1);
  sclk=0;
  Delay (1);
  for(i=0;i<5;i++)
  {
    sclk=1;
    Delay (1);
    sclk=0;
    Delay (1);
  }
  std=0;
  Delay (1);
  sclk=1;
  Delay (1);
  sclk=0;
  Delay (1);
  if(dat_comm)
    std=1;   //data
  else
    std=0;   //command
  Delay (1);
  sclk=1;
  Delay (1);
  sclk=0;
  Delay (1);
  std=0;
  Delay (1);
  sclk=1;
  Delay (1);
  sclk=0;
  Delay (1);
  for(j=0;j<2;j++)
  {
    for(i=0;i<4;i++)
    {
      //bdat=cont&0x80;
      std=(cont&0x80)>>7;
      cont=cont<<1;
      Delay (1);
      sclk=1;
      Delay (1);
      sclk=0;
      Delay (1);
    }
    std=0;
    Delay (1);
    for(i=0;i<4;i++)
    {
      sclk=1;
      Delay (1);
      sclk=0;
      Delay (1);
    }
  }
}


⌨️ 快捷键说明

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