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

📄 main.c

📁 点阵式液晶屏
💻 C
字号:
/****************************************Copyright (c)**************************************************
**                               Guangzou ZLG-MCU Development Co.,LTD.
**                                      graduate school
**                                 http://www.zlgmcu.com
**
**--------------File Info-------------------------------------------------------------------------------
** File name:			main.c
** Last modified Date:  2004-09-16
** Last Version:		1.0
** Descriptions:		The main() function example template
**
**------------------------------------------------------------------------------------------------------
** Created by:			Chenmingji
** Created date:		2004-09-16
** Version:				1.0
** Descriptions:		The original version
**
**------------------------------------------------------------------------------------------------------
** Modified by:
** Modified date:
** Version:
** Descriptions:
**
********************************************************************************************************/
#include "config.h"


#define GUI_LCM_xMAX   128
#define GUI_LCM_yMAX   64

uint8 gui_disp_buf1[GUI_LCM_yMAX>>3][GUI_LCM_xMAX>>1];                   //定义左屏显示缓冲区
uint8 gui_disp_buf2[GUI_LCM_yMAX>>3][GUI_LCM_xMAX>>1];                   //定义右屏显示缓冲区
uint8 const DEC_HEX_TAB[8]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};      //定义转换表(根据液晶设置)
/**********************************************************************/
/*********************************************************************************************************
**                          有关点的函数 
********************************************************************************************************/
/* 更新左半屏的点 */
void buf_UpdatePoint1(uint8 x,uint8 y,uint8 color)
{   
  uint8 point_dat;                                                 
  point_dat=gui_disp_buf1[y>>8][x];
  if((color&0x01)!=0)   point_dat=point_dat| DEC_HEX_TAB[y&0x07];      //显示该点
    else  point_dat=point_dat& (~DEC_HEX_TAB[y&0x07]);

  gui_disp_buf1[y>>8][x]=point_dat;
}


/* 更新右半屏的点 */
void buf_UpdatePoint2(uint8 x,uint8 y,uint8 color)
{   
  uint8 point_dat;                                                 
  point_dat=gui_disp_buf2[y>>8][x-64];
  if((color&0x01)!=0)   point_dat=point_dat| DEC_HEX_TAB[y&0x07];      //显示该点
    else  point_dat=point_dat& (~DEC_HEX_TAB[y&0x07]);

  gui_disp_buf1[y>>8][x-64]=point_dat;
}




/* 显示缓冲区内画点 */

uint8 buf_Point(uint8 x,uint8 y,uint8 color)
{
   /* 参数过滤 */
   if(x>=GUI_LCM_xMAX)   return(0);
   if(y>=GUI_LCM_yMAX)   return(0);
   
   if(x<64)  buf_UpdatePoint1(x,y,color);
     else    buf_UpdatePoint2(x,y,color);
   return(1);
}


/* 显示缓冲区内画线,(注意考虑画点时参数过滤的返回值?)*/

        /* 画水平线 */
 void buf_HLine(uint8 x0,uint8 y0,uint8 x1,uint8 color)
 {
    uint8 bak;
    
    if(x0>x1)              //对x0、x1大小进行排列
    {
      bak=x1;
      x1=x0;
      x0=bak;
    }
    
    do 
    {
      buf_Point(x0,y0,color);      //逐点描出水平线
      x0++;
    }while(x1>=x0);
 }

        /* 画垂直线 */
 void buf_RLine(uint8 x0,uint8 y0,uint8 y1,uint8 color)
 {
    uint8 bak;
    
    if(y0>y1)              //对y0、y1大小进行排列
    {
      bak=y1;
      y1=y0;
      y0=bak;
    }
    
    do 
    {
      buf_Point(x0,y0,color);      //逐点描出垂直线
      y0++;
    }while(y1>=y0);
 }


    /* 画任意走向直线,page544软件开发实例 */
 
void buf_Line(uint8 x0,uint8 y0,uint8 x1,uint8 y1,uint8 color)
{
  int dx;
  int dy;
  int8 dx_sym;
  int8 dy_sym;
  int dx_x2;
  int dy_x2;
  int di;
  
  dx=x1-x0;
  dy=y1-y0;
  
  if(dx>0)    dx_sym=1;
  else 
   {
     if(dx<0)  dx_sym=-1;
     else {buf_RLine(x0,y0,y1,color);
           return;
          }
   }
   
  if(dy>0)   dy_sym=1;
  else 
   {
     if(dy<0)  dy_sym=-1;
     else {buf_HLine(x0,y0,x1,color);
           return;
          }
   }  
  
  dx=dx_sym*dx;
  dy=dy_sym*dy;
  
  
  dx_x2=dx*2;
  dy_x2=dy*2;
  
  
  if(dx>=dy)
  {
     di=dy_x2-dx;
     while(x0!=x1)
     {
        buf_Point(x0,y0,color);
        x0 +=dx_sym;
        if(di<0)   di+=dy_x2;
        else
        {
           di+=dy_x2-dx_x2;
           y0+=dy_sym;
        }
     }
     buf_Point(x0,y0,color);
     
  }
  
  else
  {
     di=dx_x2-dy;
     while(y0!=y1)
     {  buf_Point(x0,y0,color);
        y0 +=dy_sym;
        if(di<0)   di+=dx_x2;
        else
        {
           di+=dx_x2-dy_x2;
           x0+=dx_sym;
        }
        
     }
     buf_Point(x0,y0,color);
  }  
 
  
}


/**********************************************************************/

        int main (void)
{// add user source code 
    return 0;
}
/********************************************************************************************************* 
**                            End Of File
********************************************************************************************************/

⌨️ 快捷键说明

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