19264液晶屏与单片机驱动

发布者:快乐旅行最新更新时间:2017-11-22 来源: eefocus关键字:19264液晶屏  单片机驱动 手机看文章 扫描二维码
随时随地手机看文章

首先说下19264屏

1926屏是由3个64*64 组成   64行     192列     其中192列 是64+64+64 =192  

它们分别有CS1  CS2  CS3 控制  让那个屏显示 所以  每个屏最多只能显示64行64列    切结8行 等于1页。

每页只能最多写8行 64列,8*64 =512位   512/8 =64字节最多写64字节 。。以上就是19264液晶屏的基本原理,虽然各个厂商硬件有所差异但原理基本相同。

以下给之前项目中使用的AT-C19264的驱动部分代码仅供参考!

 C++ Code 


#include "main.h"

#define  __LCD_C__


const uchar code jie[]={

0x08,0x08,0x08,0xFF,0x88,0x68,0x24,0x2C,0xB4,0x25,0x26,0x34,0x2C,0x24,0x20,0x00,

0x02,0x42,0x81,0x7F,0x02,0x82,0x8A,0x4E,0x53,0x32,0x12,0x2E,0x42,0xC2,0x02,0x00   //"接",0

};

const uchar code di[]={


0x10,0x10,0x10,0xFE,0x10,0x50,0x40,0xFE,0x20,0x20,0xFF,0x10,0x10,0xF8,0x10,0x00,

0x20,0x20,0x10,0x1F,0x08,0x08,0x00,0x3F,0x40,0x40,0x4F,0x42,0x44,0x43,0x70,0x00//"地",1

};

const uchar code zu[]={

0x00,0xFF,0x11,0x29,0xC7,0x01,0xFE,0x22,0x22,0x22,0x22,0x22,0xFE,0x00,0x00,0x00,

0x00,0xFF,0x02,0x04,0x43,0x40,0x7F,0x42,0x42,0x42,0x42,0x42,0x7F,0x40,0x40,0x00//"阻",3

};

const uchar code ce[]={

0x08,0x31,0x86,0x60,0x00,0xFE,0x02,0xF2,0x02,0xFE,0x00,0xF8,0x00,0x00,0xFF,0x00,

0x04,0xFC,0x03,0x00,0x80,0x47,0x30,0x0F,0x10,0x67,0x00,0x07,0x40,0x80,0x7F,0x00//"测",0


};

const uchar code shi[]={

0x40,0x42,0xDC,0x08,0x00,0x90,0x90,0x90,0x90,0x90,0xFF,0x10,0x12,0x1C,0x10,0x00,

0x00,0x00,0x7F,0x20,0x10,0x20,0x20,0x1F,0x10,0x10,0x01,0x06,0x18,0x20,0x78,0x00//"试",1


};

const uchar code dian[]={

0x00,0x00,0xF8,0x48,0x48,0x48,0x48,0xFF,0x48,0x48,0x48,0x48,0xF8,0x00,0x00,0x00,

0x00,0x00,0x0F,0x04,0x04,0x04,0x04,0x3F,0x44,0x44,0x44,0x44,0x4F,0x40,0x70,0x00,//"电",2

};

const uchar code liu[]={


0x10,0x60,0x01,0x86,0x60,0x04,0x44,0x64,0x55,0x4E,0x44,0x64,0xC4,0x04,0x04,0x00,

0x04,0x04,0xFC,0x03,0x40,0x30,0x0F,0x00,0x00,0x7F,0x00,0x3F,0x40,0x40,0x70,0x00//"流",3


};


const uchar code si[]={

0x00, 0xFC, 0x44, 0x44, 0x44, 0xFC, 0x10, 0x90, 0x10, 0x10, 0x10, 0xFF, 0x10, 0x10, 0x10, 0x00,

0x00, 0x07, 0x04, 0x04, 0x04, 0x07, 0x00, 0x00, 0x03, 0x40, 0x80, 0x7F, 0x00, 0x00, 0x00, 0x00//"时",0

};

const uchar code jian[]={


0x00, 0xF8, 0x01, 0x06, 0x00, 0xF0, 0x92, 0x92, 0x92, 0x92, 0xF2, 0x02, 0x02, 0xFE, 0x00, 0x00,

0x00, 0xFF, 0x00, 0x00, 0x00, 0x07, 0x04, 0x04, 0x04, 0x04, 0x07, 0x40, 0x80, 0x7F, 0x00, 0x00//"间",1

};

const uchar code bao[]={

0x08,0x08,0x88,0xFF,0x48,0x28,0x00,0xFF,0xC1,0x41,0x41,0x49,0x51,0xCF,0x00,0x00,

0x01,0x41,0x80,0x7F,0x00,0x00,0x00,0xFF,0x40,0x23,0x14,0x1C,0x33,0x60,0x20,0x00    

};

const uchar code jing[]={

0x20,0x1A,0xFA,0xAF,0xAA,0xEF,0x0A,0xFA,0x10,0x8F,0x54,0x24,0x5C,0x84,0x04,0x00,

0x02,0x02,0x02,0xEA,0xAA,0xAA,0xAB,0xAA,0xAB,0xAA,0xAA,0xEA,0x02,0x02,0x03,0x00    

};

const uchar code bu[]={

0x08,0x08,0x89,0xCE,0x2A,0x98,0x48,0x00,0x00,0x00,0xFF,0x20,0x40,0x80,0x00,0x00,

0x02,0x01,0x00,0xFF,0x01,0x02,0x04,0x00,0x00,0x00,0xFF,0x00,0x00,0x00,0x03,0x00   

};

const uchar code cang[]={


0x40,0x20,0xF8,0x27,0x02,0x30,0x92,0x9C,0x90,0x9F,0x90,0x98,0x96,0x34,0x10,0x00,

0x00,0x00,0x7F,0x00,0x00,0x22,0x72,0x2A,0x2E,0x22,0x22,0x2A,0x72,0x22,0x02,0x00   


};


const uchar code zero[]={


0x00,0xE0,0x10,0x08,0x08,0x10,0xE0,0x00,0x00,0x0F,0x10,0x20,0x20,0x10,0x0F,0x00,   //"0",

0x00,0x10,0x10,0xF8,0x00,0x00,0x00,0x00,0x00,0x20,0x20,0x3F,0x20,0x20,0x00,0x00,   //"1",

0x00,0x70,0x08,0x08,0x08,0x88,0x70,0x00,0x00,0x30,0x28,0x24,0x22,0x21,0x30,0x00,   //"2",

0x00,0x30,0x08,0x88,0x88,0x48,0x30,0x00,0x00,0x18,0x20,0x20,0x20,0x11,0x0E,0x00,   //"3",

0x00,0x00,0xC0,0x20,0x10,0xF8,0x00,0x00,0x00,0x07,0x04,0x24,0x24,0x3F,0x24,0x00,   //"4",

0x00,0xF8,0x08,0x88,0x88,0x08,0x08,0x00,0x00,0x19,0x21,0x20,0x20,0x11,0x0E,0x00,   //"5",

0x00,0xE0,0x10,0x88,0x88,0x18,0x00,0x00,0x00,0x0F,0x11,0x20,0x20,0x11,0x0E,0x00,   //"6",

0x00,0x38,0x08,0x08,0xC8,0x38,0x08,0x00,0x00,0x00,0x00,0x3F,0x00,0x00,0x00,0x00,   //"7",

0x00,0x70,0x88,0x08,0x08,0x88,0x70,0x00,0x00,0x1C,0x22,0x21,0x21,0x22,0x1C,0x00,   //"8",

0x00,0xE0,0x10,0x08,0x08,0x10,0xE0,0x00,0x00,0x00,0x31,0x22,0x22,0x11,0x0F,0x00,    //"9",


0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x30,0x30,0x00,0x00,0x00,0x00,0x00     //"."



};

const uchar code m[]={


0x80,0x80,0x80,0x80,0x80,0x80,0x80,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,

0x20,0x3F,0x20,0x00,0x3F,0x20,0x00,0x3F,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00



};

const uchar code R[]={  

0x00,0x00,0xC0,0x20,0x10,0x08,0x08,0x08,0x08,0x08,0x10,0x20,0xC0,0x00,0x00,0x00,


0x00,0x38,0x23,0x24,0x28,0x30,0x00,0x00,0x00,0x30,0x28,0x24,0x23,0x38,0x00,0x00  

};



const uchar code A[]={

0x00,0x00,0xC0,0x38,0xE0,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,

0x20,0x3C,0x23,0x02,0x02,0x27,0x38,0x20,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00   

};

const uchar code S[]={


0x00,0x70,0x88,0x08,0x08,0x08,0x38,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,

0x00,0x38,0x20,0x21,0x21,0x22,0x1C,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00   

};



 

void delay_ms(uint dly)     //@6MHz

{

    unsigned char i, j;

    while(dly!=0){

        //_nop_();

        //_nop_();

        dly--;

        i = 6;

        j = 210;

        do

        {

            while (--j);

        } while (--i);

     }

}


void send_bt(uint bty){

    uchar i;

    for (i=0;i<8;i++){

        clk164 =0;

        if (bty & 0x80)

            dat164 = 1;

        else 

            dat164 = 0;

        clk164 = 1;

        bty = bty << 1;

    }

}




void lcd_write_command(uchar cmd){

    //while(busy()); //返回1  死循环  测试忙

    

    lcd_di =0;

    lcd_rw =0;

    send_bt(cmd); 

    lcd_e =1;

    //delay(1);

    _nop_();

    lcd_e =0;

}


void lcd_write_data(uchar dat){

    //while(busy()); //返回1  死循环  测试忙


    lcd_di =1;

    lcd_rw =0;

    send_bt(dat);

    lcd_e =1;

    //delay(1);//防止  写数据 与写指令频率太快

    _nop_();


    lcd_e =0;

}


void set_line(uchar line){

    lcd_di =0;

    lcd_rw =0;

    line = 0xc0 | line;

    lcd_write_command(line);

}


void set_page(uchar page){

    lcd_di = 0;

    lcd_rw = 0;

    page = 0xb8 | page;

    lcd_write_command(page);

}


void set_column(uchar col){

    lcd_di = 0;

    lcd_rw = 0;

    col = col & 0x3f;

    col = 0x40 | col;

    lcd_write_command(col);

}


void select_screen(uchar swich){

    //swich = 0x07 & swich;

    switch(swich)

    {

        case 0:

            {lcd_cs1=lcd_cs2=lcd_cs3 =0;

            break;}

        case 1:

            {lcd_cs1=lcd_cs2 =0;

            lcd_cs3 = 1;

            break;}

        case 2:

            {lcd_cs1=lcd_cs3 = 0;

            lcd_cs2 =1;

            break;}

        case 3:

            {lcd_cs1=0;

            lcd_cs2=lcd_cs3 = 1;

            break;}

        case 4:

            {lcd_cs1=1;

            lcd_cs2=lcd_cs3=1;

            break;}

        case 5:

            {lcd_cs1=lcd_cs3=1;

            lcd_cs2 =0;

            break;}

        case 6:

            {lcd_cs1=lcd_cs2=1;

            lcd_cs3=0;

            break;}

        case 7:

            {lcd_cs1=lcd_cs2=lcd_cs3=1;

            break;}

        default:

                break;

            

    }

}


void set_on_off(uchar swich){

    lcd_di = 0;

    lcd_rw = 0;

    swich = 0x3e | swich;

    lcd_write_command(swich);

}


void lcd_scr_clr(void){

    uchar i,j;

    lcd_cs1 =lcd_cs2 = lcd_cs3 =0;

    set_line(0);

    set_on_off(1);

    set_column(0);

    for (i=0;i<8;i++){

        set_page(i);

        for (j=0;j<64;j++){

            lcd_write_data(0x00);

        }

    }


  

}


void lcd_init(void){

    //while(busy()); //返回1  死循环  防止更改PO口继电器

    clr164=1;

    lcd_rst=1;

    lcd_scr_clr();

    set_line(0);//这里是设置起始行


}


void display(uchar screen ,uchar page,uchar col,uchar *p){

    uchar i;

    select_screen(screen);

    set_page(page);

    set_column(col);

    for (i=0;i<16;i++){

        lcd_write_data(p[i]);

    }

    set_page(page +1);

    set_column(col);

    for (i=0;i<16;i++){

        lcd_write_data(p[i+16]);

    }

}


void display_word(void){



    display(3,0,0,jie);

    display(3,0,16,di);

    display(3,0,32,dian);

    display(3,0,48,zu);

    

    display(3,3,0,ce);

    display(3,3,16,shi);

    display(3,3,32,dian);

    display(3,3,48,liu);


    display(3,6,0,ce);

    display(3,6,16,shi);

    display(3,6,32,si);

    display(3,6,48,jian);


    display(6,0,32,m);

    display(6,0,41,R);

    display(6,3,32,A);

    display(6,6,32,S);


}

void display_word_current(void)

{

    display(3,3,0,ce);

    display(3,3,16,shi);

    display(3,3,32,dian);

    display(3,3,48,liu);

    display(6,3,32,A);  

}

void display_word_time(void)

{

    display(3,6,0,ce);

    display(3,6,16,shi);

    display(3,6,32,si);

    display(3,6,48,jian);

    display(6,6,32,S);


}

void display_word_offset(void)

{

    display(3,6,0,bu);

    display(3,6,16,cang);

    display(3,6,32,dian);

    display(3,6,48,zu);

    display(6,6,32,m);

    display(6,6,41,R);


}

void display_word_alarm(void)

{

    display(3,3,0,bao);

    display(3,3,16,jing);

    display(3,3,32,dian);

    display(3,3,48,zu);

    display(6,3,32,m);

    display(6,3,41,R);


}



void show_sit(uchar screen,uchar row,uchar x_sit,uchar y_sit)reentrant{


    select_screen(screen);

    set_line(row);

    set_page(x_sit);

    set_column(y_sit);


}


void display_current(uint test_current ){

    uint timh1,timh2,timh3;

    uint i;

    //10    25    100

    timh1 = test_current/100%10;  //百位         

    timh2 = test_current/10%10; //取出10位

    timh3 = test_current% 10;//个位  

    show_sit(5,63,3,40);

    for (i=0;i<8;i++)

        lcd_write_data(zero[timh1*16+i]);

    show_sit(5,63,4,40);

    for(i=0;i<8;i++)    

        lcd_write_data(zero[timh1*16+i+8]);

    show_sit(5,63,3,48);

    for (i=0;i<8;i++)

        lcd_write_data(zero[timh2*16+i]);

    show_sit(5,63,4,48);

    for(i=0;i<8;i++)    

        lcd_write_data(zero[timh2*16+i+8]);

    show_sit(5,63,3,56);

    for (i=0;i<8;i++)

        lcd_write_data(zero[timh3*16+i]);

    show_sit(5,63,4,56);

    for(i=0;i<8;i++)    

        lcd_write_data(zero[timh3*16+i+8]);

}



 void display_time(uint test_time) reentrant {

    uint timh1,timh2;

    uint i;


    timh1 = test_time/10%10;//取出 十位

    timh2 = test_time%10;//取出 个位

    show_sit(5,63,6,40);

    for (i=0;i<8;i++)

        lcd_write_data(zero[ timh1*16+i]);

    show_sit(5,63,7,40);

    for(i=0;i<8;i++)    

        lcd_write_data(zero[timh1*16+i+8]);

    show_sit(5,63,6,48);

    for (i=0;i<8;i++)

        lcd_write_data(zero[timh2*16+i]);

    show_sit(5,63,7,48);

    for(i=0;i<8;i++)    

        lcd_write_data(zero[timh2*16+i+8]);


    

}



void display_offset(uchar offset_R)

{

    uint timh1,timh2;

    uint i;

    timh1 = offset_R/10%10;//取出 十位

    timh2 = offset_R%10;//取出 个位

    show_sit(5,63,6,40);

    for (i=0;i<8;i++)

        lcd_write_data(zero[timh1*16+i]);

    show_sit(5,63,7,40);

    for(i=0;i<8;i++)    

        lcd_write_data(zero[timh1*16+i+8]);

    show_sit(5,63,6,48);

    for (i=0;i<8;i++)

        lcd_write_data(zero[timh2*16+i]);

    show_sit(5,63,7,48);

    for(i=0;i<8;i++)    

        lcd_write_data(zero[timh2*16+i+8]);         

}


void display_alarm(uchar alarm_R)

{

    uint timh1,timh2,timh3;

    uint i;

    timh1 = alarm_R/100%10;//取出 百位位

    timh2 = alarm_R/10%10;//取出 十位位

    timh3 = alarm_R%10;//取出个位

    show_sit(5,63,3,32);

    for (i=0;i<8;i++)

        lcd_write_data(zero[timh1*16+i]);

    show_sit(5,63,4,32);

    for(i=0;i<8;i++)    

        lcd_write_data(zero[timh1*16+i+8]);


    show_sit(5,63,3,40);

    for (i=0;i<8;i++)

        lcd_write_data(zero[timh2*16+i]);

    show_sit(5,63,4,40);

    for(i=0;i<8;i++)    

        lcd_write_data(zero[timh2*16+i+8]);

    show_sit(5,63,3,48);

    for (i=0;i<8;i++)

        lcd_write_data(zero[timh3*16+i]);

    show_sit(5,63,4,48);

    for(i=0;i<8;i++)    

        lcd_write_data(zero[timh3*16+i+8]);         

}


void display_result(uint jd_dz){

    uchar timh1,timh2,timh3,timh4;

    uchar row;

    timh1 = jd_dz/1000;

    timh2 = jd_dz%1000/100;

    timh3 = jd_dz %1000%100/10;

    timh4 = jd_dz%1000%100%10;


    show_sit(5,63,0,40);

    for(row=0;row<8;row++)

        lcd_write_data(zero[timh1*16+row]);

    show_sit(5,63,1,40);

    for(row=0;row<8;row++)

        lcd_write_data(zero[timh1*16+row+8]);   //zero这个数组拆开的

    show_sit(5,63,0,48);

    for(row=0;row<8;row++)  

            lcd_write_data(zero[timh2*16+row]);

    show_sit(5,63,1,48);

    for(row=0;row<10;row++) 

            lcd_write_data(zero[timh2*16+row+8]);   //高2位

    

    

    show_sit(5,63,0,56);

    for(row=0;row<8;row++)

            lcd_write_data(zero[timh3*16+row]);

    show_sit(5,63,1,56);

    for(row=0;row<8;row++)

            lcd_write_data(zero[timh3*16+row+8]);

    

    show_sit(6,63,0,0);

    for(row=0;row<8;row++)

            lcd_write_data(zero[timh4*16+row]);

    show_sit(6,63,1,0);

    for(row=0;row<8;row++)

            lcd_write_data(zero[timh4*16+row+8]);//后2位

    //难道是共阴共阳极点阵 发 10列数据? 2页   10*16 发得都是列数据



}


关键字:19264液晶屏  单片机驱动 引用地址:19264液晶屏与单片机驱动

上一篇:温湿度传感器DHT11的驱动程序
下一篇:谈PIC和AVR的自身抗干扰性能

推荐阅读最新更新时间:2024-03-16 15:46

51单片机驱动CT1642数码管显示源程序
拆解电视机顶盒找到带CT1642控制的数码管 在网上找到代码修改了一下 没有解决按键检测的问题 可根据自己的需求修改对应引脚 制作出来的实物图如下: 单片机源程序如下: sbit DAT=P2^2; sbit CLK=P2^1; sbit KEY=P2^0; u8 NixieTable ={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F}; u8 NixieTablepos ={0,0x02,0x04,0x08}; void CT1642_Write(u8 Pos, u8 Val) { u8 i,Posn; // 1、移18位:对应C1--C4、6位空、Q2--Q9 P
[单片机]
51<font color='red'>单片机</font><font color='red'>驱动</font>CT1642数码管显示源程序
STM8单片机串口驱动的深度解析
串口是单片机最重要的外设之一,在很多项目开发中都有应用,Lora模块的外部通讯方式就是串口。 本节简单的和大家解析一下串口通讯及驱动代码的编程。 STM8L101F3单片机支持一路串口通讯。我们先看一下Lora模块的硬件接口,如下图所示: 串口的硬件接口是PC2 和PC3两个脚位。 下面开始讲解软件部分,这块我们无际单片机编程也有这个项目全部视频教程,下面是文字版。 软件驱动 STM8打开标准库文件夹,打开串口USART例程: 2.如上图所示,是标准库中串口通讯的的例程,并选择第一个例程。 3.我们按照之前的方式,把USART_HyperTerminalInterrupt文件复制到ProjectSTM8
[单片机]
STM8<font color='red'>单片机</font>串口<font color='red'>驱动</font>的深度解析
51单片机驱动1602程序
sbit LCD_RS=P3^4; // 定义IO口,具体1602的读控制线 sbit LCD_RW=P3^3; // 定义IO口,具体1602的写控制线 sbit LCD_EN=P2^0; // 定义IO口,具体1602的使能控制线 sbit Light=P3^7; // 定义IO口,具体1602的背光控制线(0:开通,1关闭) sbit D0 = P1^0; // 定义IO口,P1.0数据口1602LCD的D0口 sbit D1 = P1^1; // 定义IO口,P1.1数据口1602LCD的D1口 sbit D2 = P1^2; // 定义IO口,P1.2数据
[单片机]
手把手教你使用PIC单片机驱动继电器
在现代自动控制设备中,都存在一个电子电路(弱电)与电气电路(强电)的互相连接问题,一方面要使电子电路的控制信号能够控制电气电路的执行元件(如电动机、电磁铁、电灯等),另一方面又要为电子线路的电气电路提供良好的电隔离,以保护电子电路和人身的安全。继电器便能完成这一桥梁作用。 继电器的工作原理与分类 继电器是一种电子控制器件,它具有控制系统(又称输入回路)和被控制系统(又称输出回路),通常应用于自动控制电路中,它实际上是用较小的电流去控制较大电流的一种“自动开关”。故在电路中起着自动调节、安全保护、转换电路等作用。在大多数的情况下,继电器就是一个电磁铁,这个电磁铁的衔铁可以闭合或断开一个或数个接触点。当电磁铁的绕组中有电流通过
[单片机]
手把手教你使用PIC<font color='red'>单片机</font><font color='red'>驱动</font>继电器
STC15单片机驱动WS2812B七彩LED(汇编混合编程)
WS2812B七彩LED具有集成度高、使用方便等特点,但是800K的数据速率(IO变化速率高达2.4M),对单片机提出了较高的要求,通常是采用SPI+DMA方式驱动, 也有人采用汇编实现,但是要预先把数据转换为按bit存放,在LED级连数量较多的情况下,需要占用极多的存储空间。 在驱动WS2812B上花费了太多的时间,走了不少弯路,记录下来: 简易数字分析仪采样频率最高只有4M,即测量精度为250ns,而信号宽度要求为400ns和850ns,这样测量的结果存在较大的误差,让人误以为信号跳变无规律, 迷失了方向;解决的办法就是利用STC单片机主时钟的内分频功能,语句:CLK_DIV |= 0x07; 将主频降低128倍,
[单片机]
STC15<font color='red'>单片机</font><font color='red'>驱动</font>WS2812B七彩LED(汇编混合编程)
基于ADC081S051与51单片机的接口电路及驱动程序
  引言   自然界存在的信号通常为模拟信号,在测控系统中通常将采集到的模拟信号数字化,然后交给微处理器或微控制器进行处理。因此模数转换器成为测控系统中不可缺少的部分。ADC081S051 模数转换器是国家半导体公司生产的低功率单通道CMOS 8位A/D转换器,它采用串行外设接口方式进行数据输出。与传统的器件不同的是,传统器件的采样速率是固定的,而ADC081S051 的采样速率可以在200~500 KSPS 范围内可变。   ADC081S051 的数据输出是串行数据输出,它与SPI、QSPI 等一些标准相兼容。它的工作电压范围在2.7~5.25 V,因此可以采用3 V或者5 V电源供电。它可以应用于便携式系统、远程数据采集
[单片机]
基于ADC081S051与51<font color='red'>单片机</font>的接口电路及<font color='red'>驱动</font>程序
自制单片机之七……LCD12864的驱动之源代码
今天将LCD12864的源代码发上来。 //LCD12864 //********************************************************** //连线表: CPU=89C51 SysClock=12MHz * //RS=P1.0 R/W=P1.1 E=P1.2 CS1=P1.3 CS2=P1.4 * //DB0-DB7=P0.0-P0.7 /Reset=InBoard * //********************************************************** #include #include
[单片机]
自制<font color='red'>单片机</font>之七……LCD12864的<font color='red'>驱动</font>之源代码
基于K9F5608A的MCS-51单片机驱动程序
K9F5608A的MCS-51单片机驱动程序主要包括函数声明管脚定义部分、命令操作函数以及数据输出函数。 (1)函数声明管脚定义部分主要完成程序所涉及的库函数的声明及有关引脚的定义,一般置于程序的开头部分,代码如下: (2)命令操作函数NFCommand()。 NfCommand()函数实现向K9F5608发送操作命令,程序代码如下: (3)地址发送函数NfAddre()。 NfAddre()函数完成向K9F5608发送3字节地址数据,程序代码如下: (4)页读函数。 页读函数实现对K9F5608数据的页读功能,主要包括ReadPageF()、ReadPage()和ReadPageS()等3种函数,相关程序
[单片机]
基于K9F5608A的MCS-51<font color='red'>单片机</font><font color='red'>驱动</font>程序
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved