LT8920能做到每次开机不匹配吗

LT8920能做到每次开机不匹配吗,第1张

不能

芯片会自动过滤同步每次的开机都会匹配。

芯片相当于计算机中得主板,可以控制计算机得整个系统,一旦芯片坏掉了,计算机就瘫痪了。其实不如把芯片当成人得大脑思维,人受大脑控制获取信息然后执行,而芯片同样得道理。芯片是一个比较薄,布满密密麻麻得金属线,这些金属线得作用就是帮助芯片和外界线路连在一起,如果您不明白得话,可以把这些金属线当成人得神经或者经脉,通常我们生活中经常接触到得电子产品都是有芯片存在的。

这颗RF晶片性价比高外围器件,我滴神呀,真少,我在航模上使用过,每个月提货140K左右,硬件性能十分稳定,天线要求一点不高,调试比较容易。数据手册资料写的很清楚,在网上找吧,程序有一个C代码参考的,模仿下就可以调通,收发注意启动模式,频道,和同步字一致,就可以简单通信。

#include <AT89C51XD2.H>

#include <ABSACC.H>

#include <INTRINS.H>

#include "common.h"

#define SCREEN_WIDTH 0x20

extern struct Pic *point_pic1

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

#define COMMAND_PORT XBYTE[0x8001] //定义命令端口地址

#define DATA_PORT XBYTE[0x8000]//定义数据端口地址

#define CODESTATE 0x01 //定义检测位

#define DATASTATE 0x02

#define DATAAUTOREAD 0x04

#define DATAAUTOWRITE 0x08

#define CONTROLLER 0x20

#define SCREENCOPY 0x40

#define BLINKCONTITION 0x80

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

//检查状态

volatile bit check_state(uchar check_bit)

{

uchar state

state=COMMAND_PORT

switch(check_bit)

{

case CODESTATE:

{

if(state&0x01)

return 1

else

return 0

}

case DATASTATE:

{

if(state&0x02)

return 1

else

return 0

}

case DATAAUTOREAD:

{

if(state&0x04)

return 1

else

return 0

}

case DATAAUTOWRITE:

{

if(state&0x08)

return 1

else

return 0

}

case CONTROLLER:

{

if(state&0x02)

return 1

else

return 0

}

case SCREENCOPY:

{

if(state&0x40)

return 0

else

return 1

}

case BLINKCONTITION:

{

if(state&0x80)

return 1

else

return 0

}

}

}

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

//判断自动写

void check_auto_write(void) reentrant

{

while(!(check_state(DATAAUTOWRITE)))

}

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

volatile void check_code_data(void) reentrant

{

while(!(check_state(CODESTATE)))

while(!(check_state(DATASTATE)))

}

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

//指针设置

#define SET_CURSOR_POINTER 0x01 //设置光标位置

#define SET_CGRAM_POINTER 0X02 //设置CGRAM

#define SET_ADDRESS_POINTER 0x04

void set_point(uchar i,uchar data dat1,uchar data dat2) //向外部输出的数要定义在 data 区中

{

check_code_data()

DATA_PORT=dat1

check_code_data()

DATA_PORT=dat2

check_code_data()

COMMAND_PORT=(0x20|i)

}

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

//设置显示模式

#define LOGIC_OR 0x00

#define LOGIC_XOR 0x01

#define LOGIC_AND 0x02

#define TEXT_CHAR 0x04

void set_display_mode(uchar dat)

{

check_code_data()

COMMAND_PORT=(0x80|dat)

}

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

//显示区域设置

#define TEXT_ADDRESS 0x00 //设置文本区首址

#define TEXT_WIDTH 0x01 //设置文本区宽度

#define GRAPHIC_ADDRESS 0x02//设置图形区首址

#define GRAPHIC_WIDTH 0x03 //设置图形区宽度

void set_display_area(uchar i,uchar dat1,uchar dat2)

{

if((i==0x01)||(i==0x03))

dat2=0

check_code_data()

DATA_PORT=dat1

check_code_data()

DATA_PORT=dat2

check_code_data()

COMMAND_PORT=(0x40|i)

}

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

//显示开关设置

#define CURSORBLINK 0x01

#define CURSORON 0x02

#define TEXTON 0x04

#define GRAPHICON 0x08

void set_display(uchar displaymode)

{

check_code_data()

COMMAND_PORT=(displaymode|0x90)

}

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

//光标形状设置

//参数0-7

void set_cursor(uchar i)

{

check_code_data()

COMMAND_PORT=(0xa0|i)

}

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

//自动读写定义

#define AUTOWRITE 0x00

#define AUTOREAD 0x01

#define AUTOSTOP 0x02

void set_autoreadwrite(uchar i) //reentrant

{

check_code_data()

COMMAND_PORT=(0xb0|i)

}

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

//一次读写定义

#define write_address_add 0x00

#define read_address_add 0x01

#define write_address_sub 0x02

#define read_address_sub 0x03

#define write_address_nochange 0x04

#define read_address_nochange 0x05

/*&void set_once_read_write(uchar i,uchar letter)

{

check_code_data()

DATA_PORT=letter

check_code_data()

COMMAND_PORT=(0xc0|i)

}*/

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

//屏读

/*void screen_read(void)

{

check_code_data()

COMMAND_PORT=0xe0

}*/

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

//屏拷贝

/*void screen_copy(void)

{

check_code_data()

COMMAND_PORT=0xe8

}*/

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

//位 *** 作

//#define set_bit 0x08

//#define clear_bit 0x00

/*void bit_operation(uchar op,uchar i)

{

check_code_data()

COMMAND_PORT=(0xf0|op|i)

}*/

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

/*void print_lcd(uchar str,uchar x,uchar y)

{

unsigned int addr

addr=y*16+x

check_code_data()

DATA_PORT=addr

check_code_data()

DATA_PORT=addr>>8

check_code_data()

COMMAND_PORT=0x24

check_code_data()

DATA_PORT=str

check_code_data()

COMMAND_PORT=0xc4

}*/

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

//显示字符

void text_display(uchar str) //reentrant

{

//set_point(SET_ADDRESS_POINTER,lowaddr,highaddr)

//set_once_read_write(write_address_add,str-0x20)

set_autoreadwrite(AUTOWRITE)

check_auto_write()

DATA_PORT=str-0x20

set_autoreadwrite(AUTOSTOP)

}

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

//显示字符串

void string_display(uchar data *str,uchar lowaddr,uchar highaddr) //reentrant

{

set_point(SET_ADDRESS_POINTER,lowaddr,highaddr)

set_autoreadwrite(AUTOWRITE)

while(*str!='\0')

//set_once_read_write(write_address_add,str[i]-0x20)

{check_auto_write()

DATA_PORT=*str-0x20

str++

}

set_autoreadwrite(AUTOSTOP)

}

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

//显示代码区中的字符串

void string_display_code(uchar num,uchar code *str,uchar lowaddr,uchar highaddr) //reentrant

{

uchar i

set_point(SET_ADDRESS_POINTER,lowaddr,highaddr)

set_autoreadwrite(AUTOWRITE)

if(num==0)

{

while(*str!='\0')

{

check_auto_write()

DATA_PORT=*str-0x20

str++

}

}

else

for(i=0i<NUMI++) if(lowaddr f0 0x1f #if(SCREEN_WIDTH="=0x20)" e0 ... haddr="0addr=0caddr=0" lowaddr="lowaddr+2" 3f 0x10 20 0x00 caddr="lowaddr" 1f .............0x10 10 0f ..............0x10 01 00 256*256液晶的地址 { 显示多少字因为一个字是16*16点阵,所以占32字节空间 for(k="0k<(num/32)k++)" data i,j,k,haddr,addr,caddruchar highaddr) lowaddr,uchar num,uchar *str,uint hanzi_display(uchar void 显示汉字 ******************************************************************************************** } set_autoreadwrite(AUTOSTOP)str++DATA_PORT="*str-0x20" check_auto_write()>0x1e) //换行

{

lowaddr=0x00 //低地址

highaddr=highaddr+2 //高位地址

}

#else

if(SCREEN_WIDTH==0x10) //注意不要和#else在一行

if(lowaddr>0x0e) //换行

{

lowaddr=0x00 //低地址

highaddr=highaddr+1 //高位地址

}

#endif

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

{

#if(SCREEN_WIDTH==0x20)

addr=caddr+32*i

if(i==8)

haddr++

#else

if(SCREEN_WIDTH==0x10)

addr=caddr+16*i

#endif

set_point(SET_ADDRESS_POINTER,addr,haddr)

set_autoreadwrite(AUTOWRITE)

for(j=0j<2j++)

{

check_auto_write()

DATA_PORT=*str

str++

}

set_autoreadwrite(AUTOSTOP)

}

}

}

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

//清图形显示缓冲区

void clrgraphic(void)

{

uint j

set_point(SET_ADDRESS_POINTER,0x00,0x04)

set_autoreadwrite(AUTOWRITE)

for(j=0j<4096j++)

{

check_auto_write()

DATA_PORT=0x00

}

set_autoreadwrite(AUTOSTOP)

}

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

//清字符显示缓冲区

void clrtext(void)

{

uint j

set_point(SET_ADDRESS_POINTER,0x00,0x30)

set_autoreadwrite(AUTOWRITE)

for(j=0j<1024j++)

{

check_auto_write()

DATA_PORT=0x00

}

set_autoreadwrite(AUTOSTOP)

}

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

//图片显示

volatile void picture_display(Picture *point1,uchar lowaddr,uchar highaddr,bit inverse)

{

uchar data i,j,laddr

Picture *point

point=point1

laddr=lowaddr

CY=0

for(i=0i<(point->length)i++)

{

CY=0

if(i)

laddr=laddr+32

if(CY)

highaddr=highaddr+1

set_point(SET_ADDRESS_POINTER,laddr,highaddr)

set_autoreadwrite(AUTOWRITE)

for(j=0j<(point->width/8)j++)

{

if((laddr!=0x00)&&(j!=0)) //如果没j!=0,当laddr=0x20、0x40..时,显示不正常

if((laddr+j)%32==0)

{

(point->picturecode)=(point->picturecode)+(point->width/8-j)

break

}

check_auto_write()

if(!inverse)

DATA_PORT=*(point->picturecode)

else

DATA_PORT=~*(point->picturecode)

(point->picturecode)++

}

set_autoreadwrite(AUTOSTOP)

}

}

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

//初始化lcd

void init_lcd(void)

{

//uint i,j

set_display_area(TEXT_ADDRESS,0x00,0x30)

set_display_area(TEXT_WIDTH,SCREEN_WIDTH,0x00)//因为3228是128*64,显示的字符为8*8,所以字符宽度为16

set_display_area(GRAPHIC_ADDRESS,0x00,0x00)

set_display_area(GRAPHIC_WIDTH,SCREEN_WIDTH,0x00)

set_display(TEXTON|GRAPHICON) //CURSORBLINK|CURSORON|

set_point(SET_ADDRESS_POINTER,0x00,0x00)

//set_point(SET_CURSOR_POINTER,0x4e,0x30)

set_display_mode(LOGIC_OR)

//set_point(SET_ADDRESS_POINTER,0x1c,0x2e)

}

顺便说几句,液晶的现实其实原理都是一样的,只是说带字库的编程要简单一些,一般来说,对lcd的编程包括以下几个步骤

1.读状态

2.读数据

3.写状态

4,写数据

5.初始化

只是说不带字库的点阵式lcd送数据的时候需要将数据的位置找出来再往里面送数据。

多看几个例子就可以了。很容易理解的


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

原文地址: http://outofmemory.cn/yw/8113409.html

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

发表评论

登录后才能评论

评论列表(0条)

保存