大家帮忙看看这个1602的显示程序有什么问题void delay_1ms(uint x)延时 { uchar j; while((x--)!=0) {

大家帮忙看看这个1602的显示程序有什么问题void delay_1ms(uint x)延时 { uchar j; while((x--)!=0) {,第1张

void delay_1ms(uint x)//延时

{ uchar j; //加一变量 uchar i,j;

while((x--)!=0) //改为for(i=0;i<x;i++)

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

}

}

//检查LCD忙状态

bit lcd_busy() //其实大多数都delayms(5)代替的,尤其是仿真时不能用此函数

{

bit result;

rs=0;

rw=0;

e = 1;

delay_1ms(1);

result = (bit)(data&0x80); //不知data是不是已经#define了

e = 0;

return(result);

}

//写指令数据到LCD

void write1602_com(uchar com)

{while(lcd_busy());

rs = 0;

rw = 0;

e = 0;

delay_1ms(1);

data= com;

delay_1ms(1);

e = 1;

delay_1ms(1);

e = 0;

}

//写显示数据到LCD

void write1602_data(uchar dat)

{while(lcd_busy());

rs = 1;

rw = 0;

e = 0;

data = dat;

delay_1ms(1);

e = 1;

delay_1ms(1);

e = 0;

}

void start(void) //LCD初始化

{delay_1ms(15);

write1602_com(0x38);

delay_1ms(5);

write1602_com(0x38);

delay_1ms(5);

write1602_com(0x38);

delay_1ms(5);

write1602_com(0x0F);//显示开,关光标

delay_1ms(5);

write1602_com(0x06);//移动光标

delay_1ms(5);

write1602_com(0x01);//清除LCD的显示内容

delay_1ms(5);

}

/ 设定显示位置 /

/

void lcd_data(uchar dat) //1602两行地址不是连续的,第二行是0xC0开始的

{

write1602_com(dat|0x80); //数据指针=80+地址变量

}

/

void lcd_data(uchar dat)

{

unsigned char p;

if (pos>=0x10)

p=pos+0xb0;

else

p=pos+0x80;

write1602_com(p);

write1602_data(c);

}

void main()

{

start();

delay_1ms(10);

write1602_com(0x01); //已经清屏,不知道这句的意义

delay_1ms(10);

delay_1ms(5);

lcd_data(0x00);

delay_1ms(5);

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

{

if(i==13){ //建议这句话加上大括号,放到后边,放在这影响不好

while(1);}

write1602_data(table2[i]);//应先写地址再写数据,而你这地址是不变的,最终导致数组数据在

//一个地址上陆续显示,不知道会是啥效果,并且希望你的数组不是const的。

//可以写个连续显示的函数,加指针的

delay_1ms(1);

}

}

我这1602的程序及仿真还有很多,可以向我联系的

原来的1602是这样的:

连接到Arduino上需要接好多线,于是买了块IIC的板子改成IIC接口,就是这货:

由于Arduino的I/O口数量有限,如果直接用Arduino的I/O口直接驱动LCD1602/2004这样会占用较多的I/O口资源也不利于连接更多的其他设备。IIC LCD1602/2004转接板可以大大减少需要使用IO接口,原来的1602/2004屏需要7(RS、RW、E、D4~D7)个IO口才能驱动起来,而这个模块可以省去5个IO口。

模块采用PCF8574,它通过两条双向总线(I2C)可使大多数 MCU 实现远程 I/O口扩展。该器件包含一个 8 位准双向口和一个I2C总线接口。PCF8574 电流消耗很低,且口输出锁存具有大电流驱动能力,可直接驱动 LED。它还带有一条中断接线(INT开漏输出)可与 MCU 的中断逻辑相连。通过 INT 发送中断信号, 远端 I/O 口不必经过 I2C 总线通信就可通知 MCU 是否有数据从端口输入。

但是这块板子也是插针,要想连接1602的化,需要通过面包板才行,这个不能忍,于是开始拆拆拆。

将原1602的排针拆除,直接焊接IIC转接板。说起来简单,实际 *** 作时发现拆除排针还是需要一定的技术的,最终拆的一团糟,一度以为板子拆坏了。

焊上转接板发现只有背光灯是亮的,查了半天发现是对比度的问题

使用小螺丝刀调节该电位器,从而调节对比度,1602显示屏显示。

大功告成,焊工依然很烂!

PS:

I2C github库

>

你这是实物开发板吧,而且用的是STC的单片机,内部有A/D转换电路的。

要改成LCD1602,那要看你的开发板上的LCD1602是怎么接的,只要改变后的代码没用的,这代码要与实物要符才行,否则给你代码,在开发板上也不会正常运行的,那个LCD1602也是不会显示的。

你要给出开发板上的LCD1602连接图。

应该不是判断忙碌或者不只是判断忙碌,这个语句应该是送了一串命令进去

//HD44780 LCD DRIVER

#include <AT89X52H>

#include <ctypeh>

//LCD Commands

#define LCD_CLS 1 //Clears entire display and sets DDRAM address 0

#define LCD_HOME 2 //Sets DDRAM address 0 in address counter

#define LCD_SETMODE 4 //Sets cursor move direction and specifies display shift

#define LCD_SETVISIBLE 8 //Sets entire display (D) on/off,cursor on/off (C), and blinking of cursor position character (B)

#define LCD_SHIFT 16 //Moves cursor and shifts display without changing DDRAM contents

#define LCD_SETFUNCTION 32 //Sets interface data length (DL), number of display lines (N), and character font (F)

#define LCD_SETCGADDR 64 //Sets CGRAM addressCGRAM data is sent and received after this setting

#define LCD_SETDDADDR 128 //Sets DDRAM address DDRAM data is sent and received after this setting

#define TURE 1

#define FORSE 0

#define TMH 0xf8 //delay timeh 2ms

#define TML 0xCD //delay timel

//------------------------------------------

#define MAX_DISPLAY_CHAR 2

//-----------------------------------------

unsigned char code text[6]="hellow";

static unsigned char data counter,a;

void wcchar(unsigned char d); //write a command char

void wdchar(unsigned char i); //write a data char

char wtbusy(); //wait busy sign

void clrscr(void); //clear screen

void initime0(void); //initial time0

void delay(unsigned char i); //delay

//-------------------------------

unsigned char crc8(unsigned char pData,unsigned char count);

unsigned char pData[]={0x33,0x12,0x34,0x56,0x78,0x33,0x12,0x23,0x45,0x56};

unsigned char data crc;

static char outputbuffer[MAX_DISPLAY_CHAR];

char calc_decascii(char num);

//-------------------------------

void ISR_Timer0(void) interrupt 1

{

TL0=TML;

TH0=TMH;

counter--;

}

void ISR_Int0(void) interrupt 0

{

wdchar(text[a++]); //display "hellow"

if (a>=6)

{a=0;wdchar(' ');}

}

//main program display "hellow"

main(void)

{

unsigned char data k;

initime0();

wcchar(0x38); //initial lcd

wcchar(LCD_SETVISIBLE+6); //set lcd visible

clrscr(); //clear lcd

while(1)

{

crc8(&pData,10);

calc_decascii(crc);

wdchar (outputbuffer[1]);

wdchar (outputbuffer[2]);

wdchar (' ');

for(k=0;k<=6;k++)

{

// wdchar(text[k]); //display "hellow"

P1_2=0;

delay(55); //delay

P1_2=1;

delay(55); //delay

}

}

}

//sub function || display a char

void wdchar(unsigned char i) //write a char

{

unsigned char xdata j;

P1_0=1;

P1_1=0;

j=0x8000;

j=i;

while (wtbusy())

{}

}

void wcchar(unsigned char d) //write a command char

{

unsigned char xdata j;

P1_0=0;

P1_1=0;

j=0x8000;

j=d;

while (wtbusy())

{}

}

char wtbusy() //wait busy sign

{

unsigned char xdata j;

P1_0=0;

P1_1=1;

j=0x8000;

if(j&0x80)

{

return TURE;

}

else

{

return FORSE;

}

}

//clear screen

void clrscr()

{

wcchar(LCD_CLS);

}

//initial time0

void initime0()

{

TL0=TML;

TH0=TMH;

TR0=TURE;

IE=0x93; //Enable T0 and Serial Port

}

//sub function time delay

void delay(unsigned char i)

{

counter=i;

while (counter)

{}

}

unsigned char crc8(unsigned char pData,unsigned char count)

{

// unsigned char crc;

crc = 0;

while (count-- > 0)

{

crc ^= pData++;

}

return crc;

}

char calc_decascii(char num)

// A rather messy function to convert a floating

// point number into an ASCII string

{ long data temp = num;

char data arrayptr = &outputbuffer[MAX_DISPLAY_CHAR];

long data divisor = 10;

long data result;

char data remainder,asciival;

int data i;

// If the result of the calculation is zero

// insert a zero in the buffer and finish

if (!temp)

{ arrayptr = 48;

goto done;

}

// Handle Negative Numbers

if (temp < 0)

{ outputbuffer[0] = '-';

temp -= 2temp;

}

for (i=0 ; i < sizeof(outputbuffer) ; i++)

{ remainder = temp % divisor;

result = temp / divisor;

// If we run off the end of the number insert a space into

// the buffer

if ((!remainder) && (!result))

{ arrayptr = ' ';}

// We're in business - store the digit offsetting

// by 48 decimal to account for the ascii value

else

{ asciival = remainder + 48;

arrayptr = asciival;

}

temp /= 10;

// Save a place for a negative sign

if (arrayptr != &outputbuffer[1]) arrayptr--;

}

done: return outputbuffer;

}

一,ipad恢复1602错误的发生一般是由于USB接口接触不良,或是安全软件、杀毒软件引起的故障。

二,故障处理方法:

1、首先排除USB接口的问题:尽量使用台式主机后面的USB。建议换个USB数据线再试。

2、右键点击 我的电脑(或 计算机)-管理-服务和应用程序-服务:把Messenger、Telnet和Terminal Services三个服务启动。

3、进入DFU模式恢复,如果出现1602错误,点“好”,保持iPad 的连接状态,关闭并重新打开 iTunes,这时iTunes 应会重新识别恢复模式中的iPad,再次尝试恢复。

4、进入DFU模式恢复,如果出现1602错误, 关闭ITUNES,拔掉IPad,重启电脑,进入系统的服务管理界面,找到“Apple Mobile Devices Service”服务,先停止,再启动,然后打开ITUNES,连上IPad,再次尝试恢复。

5、暂时关闭防火墙及第三方杀毒软件再试。

6、如果有其他电脑可用,换电脑试试。

51单片机对lcd1602一些基础程序

#include <intrinsh>

#define dataport P1

sbit RS=P2^ 6;

sbit RW=P2^5;

sbit EN=P2^4;

//========================

//=========================

void waitfor() //检测忙信号函数

{

dataport=0xff;

RS=0;RW=1;_nop_(); //选择指令寄存器 读 *** 作

EN=1;_nop_(); //使能 *** 作

while(dataport&0x80); //如果最高位是1 表示1602正忙 原地踏步 忙完后芯片会将高位拉低

EN=0;

}

//======================

void writedata(unsigned char dataw) //写数据到lcm

{

waitfor(); //测忙

RS=1;RW=0;_nop_(); //选择数据寄存器 写 *** 作

dataport=dataw;_nop_(); //将数据送到数据口

EN=1;_nop_();_nop_();EN=0; //使能

}

//==========================

void writecmd(unsigned char cmd) //写命令到lcm

{

waitfor();

RS=0;RW=0;_nop_();

dataport=cmd;_nop_();

EN=1;_nop_();_nop_();EN=0;

}

//===========================

void init(void) // 初始化函数

{

writecmd(0x38); //功能设定 8位数据传输 双行显示

writecmd(0x0c);//显示器开关

writecmd(0x01);//清屏

writecmd(0x06);//字符进入模式 每进入一个字符光标向右移动一格 原有字符不动

//我在刚开始学的时候不知道下一个字符显示在哪 是和AC值有关还是和光标位置有关

//最后摸索出来是只和光标定位有关 现在还是不知道Ac值有什么用

}

//=========================

void location(unsigned char x,unsigned char y) //确实坐标函数

{

unsigned char temp;

temp=x&0x0f; //只要x数据的后四位

if(y){temp=temp|0x40;} //第一行为0 第二行为1 如果y=1则地址加0x40

temp|=0x80; //DDRAM地址的命令DB7为一

writecmd(temp);

}

//==============================

void displyonechar(unsigned char x,unsigned char y,unsigned char dataw) //显示一个字符函数

{

location(x,y);

writedata(dataw);

}

//=======================================

void displylistchar(unsigned char x,unsigned char y,unsigned char p) //显示字符串

{

while(p) //当一个字符型数组读完时P指的为零

{

displyonechar(x,y,(p++));

x++;

}

}

//=====================================================

void writecgram(unsigned char address,unsigned char p) //写CGRAM的数据

{

unsigned char i=8;

writecmd(address); //CGRAM里的地址 初始值0x40 每次加0x80

while(i--)

{

writedata(p);

p++;

}

}

//=====================================================

void displyonecharacter(unsigned char x,unsigned char y,unsigned char address,unsigned char p) //显示一个自定义字符

{

unsigned char i=8;

writecmd(address); //CGRAM里的地址 初始值0x40 每次加0x08

while(i--)

{

writedata(p);

p++;

}

//============================================================

location(x,y); //设定要显示的位置

writedata((address&=0x3f)/0x08); //要从CGRAM中读出数据在1602上显示 搞了半天发现CGRAM里的地址

} //和DDRAM里的地址有上面的转换关系

//========================================================

void displynumber(unsigned char x,unsigned char y,unsigned long num) //显示一个整数

{

unsigned int number[8];

int k,gh;

for(k=0;;k++)

{

(number+k)=(unsigned int)(num%10);//强制类型转换

num=num/10;

if(num==0)break;

}

for(gh=k;gh>=0;gh--)

{

displyonechar(x,y,((number+gh)+48));

x++;

}

}

//字型码

uchar code nin[]={0x08,0x0f,0x12,0x0f,0,0x1f,0x02,0x02};// "年"

uchar code yue[]={0x0f,0x09,0x0f,0x09,0x0f,0x09,0x0b,0x11};// "月"

uchar code ri[]={0x1f,0x11,0x11,0x1f,0x11,0x11,0x11,0x1f};// "日"

显示汉字

displyonecharacter(0,0,0x40,nin);

displyonecharacter(1,0,0x80,yue);

displyonecharacter(1,0,0xc0,ri);

这是我写的一个成功的,你仔细对比下就知道了!

#include<reg52h>

#include<intrinsh>

#define U8 unsigned char

#define U16 unsigned int

#define BOOL bit

U8 secondh,secondl,minuteh,minutel,hourh,hourl,second,minute,hour;

U8 monthl,monthh,month,day,datel,dateh,date,year,yearl,yearh;

/定义LCD功能管脚/

sbit LCDRS = P2^6 ; //控制LCD数据或命令的读写

sbit LCDRW = P2^5 ; //控制LCD读写信号

sbit LCDEN = P2^7 ; //使能LCD

//

/定义DS1302功能管脚/

sbit DSRST = P3^5 ; //DS1302复位管脚

sbit DSIO = P3^4 ; //控制DS1302数据传输

sbit DSCLK = P3^6 ; //DS1302时钟

//

/延时函数/

void delay(U16 time)

{

U16 time1,time2;

for(time1=time;time1>0;time1--)

for(time2=110;time2>0;time2--);

}

//

/检测LCD忙碌状态/

BOOL judge_lcd()

{

BOOL flag;

LCDEN = 0;

LCDRS = 0;

LCDRW = 1;

LCDEN = 1;

delay(1);

flag=(BOOL)(P0&0x80); //状态位第7位为1时禁止读写,为0时可读写

LCDEN = 0;

return flag;

}

//

/实现LCD写指令/

void write_lcd_command(U16 command)

{

while(judge_lcd()); //检测LCD是否为忙碌状态

P0 = command ;

LCDRS = 0 ;

LCDRW = 0 ;

LCDEN = 1 ;

delay(1);

LCDEN = 0 ;

}

//

/实现LCD写数据/

void write_lcd_date(U16 date)

{

while(judge_lcd()); //检测LCD是否为忙碌状态

P0 = date ;

LCDRS = 1 ;

LCDRW = 0 ;

LCDEN = 1 ;

delay(1);

LCDEN = 0 ;

}

//

/实现LCD写指令及数据/

void write_lcd_com_date(U16 addr,U16 date)

{

write_lcd_command(addr);

delay(1);

write_lcd_date(date);

}

//

/初始化LCD/

void init_lcd()

{

write_lcd_command(0x38); //设置16x2显示,5x7点阵,8位数据口

delay(1);

write_lcd_command(0x0c); //开显示,不显示光标,光标不闪烁

delay(1);

write_lcd_command(0x06); //读写一个字符后,地址自动加1,不移动屏幕

delay(1);

write_lcd_command(0x01); //清屏

delay(1);

}

//

/读DS1302/

U8 read_ds1302(U8 addr)

{

U8 i,temp=0x00;

DSRST=0;

DSIO=1;

DSCLK=0;

DSRST=1;

for (i=0;i<8;i++) //循环8次 写入地址数据

{

DSCLK=0;

DSIO=addr&0x01; //每次传输低字节

addr>>=1; //右移一位

DSCLK=1;

}

delay(1);

if(DSIO)

temp|=0x80; //每次传输低字节

DSCLK=0;

temp>>=1;

for (i=0;i<7;i++) //循环8次 读取数据

{

DSCLK=0;

if(DSIO)

temp|=0x80; //每次传输低字节

DSCLK=1;

temp>>=1; //右移一位

}

DSCLK=1;

DSRST=0;

DSIO=0;

return temp; //返回

}

//

/写DS1302/

void write_ds1302(U8 addr, U8 date)

{

U8 i;

DSRST=0;

DSCLK=0;

DSRST=1;

for (i=0;i<8;i++) //循环8次 写入地址数据

{

DSCLK=0;

_nop_();

DSIO=addr&0x01; //每次传输低字节

addr>>=1; //右移一位

DSCLK=1;

_nop_();

}

for (i=0;i<8;i++) //循环8次 写入数据

{

DSCLK=0;

_nop_();

DSIO=date&0x01; //每次传输低字节

date>>=1; //右移一位 DSCLK=1

DSCLK=1;

_nop_();

}

DSRST=0;

delay(1);

}

//

/初始化DS1302/

void init_ds1302()

{

//读秒

if((((second=read_ds1302(0x81))>>7)&&0x01)==1)

{

write_ds1302(0x8e,0x00); //关闭写保护

write_ds1302(0x80,0x00); //00秒

write_ds1302(0x82,0x54); //54分

write_ds1302(0x84,0x17); //17点

write_ds1302(0x86,0x14); //14日

write_ds1302(0x88,0x10); //10月

write_ds1302(0x8a,0x05); //星期五

write_ds1302(0x8c,0x11); //2011年

write_ds1302(0x8e,0x80); //允许写保护

}

}

//

/主函数/

void main()

{

init_lcd();

delay(2);

write_lcd_com_date(0x81,'2');

write_lcd_com_date(0x82,'0');

delay(1);

init_ds1302();

delay(1);

while(1)

{

second=read_ds1302(0x81);

secondl=second&0x0f;

secondh=second>>4;

minute=read_ds1302(0x83);

minutel=minute&0x0f;

minuteh=minute>>4;

hour=read_ds1302(0x85);

hourl=hour&0x0f;

hourh=hour>>4;

month=read_ds1302(0x89);

monthl=month&0x0f;

monthh=month>>4;

year=read_ds1302(0x8d);

yearl=year&0x0f;

yearh=year>>4;

date=read_ds1302(0x87);

datel=date&0x0f;

dateh=date>>4;

day=read_ds1302(0x8b);

day=day&0x0f;

delay(15);

write_lcd_com_date(0xca,0x30+secondl);

write_lcd_com_date(0xc9,0x30+secondh);

write_lcd_com_date(0xc8,':');

write_lcd_com_date(0xc7,0x30+minutel);

write_lcd_com_date(0xc6,0x30+minuteh);

write_lcd_com_date(0xc5,':');

write_lcd_com_date(0xc4,0x30+hourl);

write_lcd_com_date(0xc3,0x30+hourh);

write_lcd_com_date(0x84,0x30+yearl);

write_lcd_com_date(0x83,0x30+yearh);

write_lcd_com_date(0x85,'-');

write_lcd_com_date(0x87,0x30+monthl);

write_lcd_com_date(0x86,0x30+monthh);

write_lcd_com_date(0x88,'-');

write_lcd_com_date(0x8a,0x30+datel);

write_lcd_com_date(0x89,0x30+dateh);

write_lcd_com_date(0x8c,0x30+day);

}

}

以上就是关于大家帮忙看看这个1602的显示程序有什么问题void delay_1ms(uint x)//延时 { uchar j; while((x--)!=0) {全部的内容,包括:大家帮忙看看这个1602的显示程序有什么问题void delay_1ms(uint x)//延时 { uchar j; while((x--)!=0) {、Arduino 将1602液晶显示屏改造为IIC接口、C51数码管显示改为1602LCD显示,求改变后的代码,原代码如下等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zz/10108376.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-05
下一篇2023-05-05

发表评论

登录后才能评论

评论列表(0条)

    保存