- 1、本文档共16页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
.
.
RDA5807m驱动程序 + IIC 程序
/****************************************************************************************
** 介绍 : RD5807M收音机程序 供电3.3v 主控使用51单片机 显示使用 LCD1602
** 作者 : 胖子
** 时间 : 2016-1-5
** 地点 : 桂林电子科技大学
*****************************************************************************************/
#include reg51.h
#include string.h
#include intrins.h
#define uchar unsigned char
#define uint unsigned int
#define ulint unsigned long int
#define lint long int
uchar code xian[4][4]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16};
uchar code hang[]={0xfe,0xfd,0xfb,0xf7}; //矩阵键盘扫描使用
//RDA 的寄存器地址
#define RDA_R00 0X00 //读出16个位的ID =0X5800
#define RDA_R02 0X02 //DHIZ[15],DMUTE[14]静音,MONO[13]声道,BASS[12]重低音,SEEKUP[9],SEEK[8],SKMODE[7],CLK_MODE[6:4]时钟源选择,SOFTRESET[1]软复位,ENABLE[0]电源使能
#define RDA_R03 0X03 //CHAN[15:6],TUNE[4],BAND[3:2],SPACE[1:0] 设置频率 带宽 步长
#define RDA_R04 0X04 //STCIEN[14],DE[11],I2Senable[6],
#define RDA_R05 0X05 //INT_MODE[15],SEEKTH[14:8](设定自动有哪些信誉好的足球投注网站信号强度阀值),LNA_PORT_SEL[7:6]=0b10,LNA_ICSEL_BIT[5:4],VOLUME[3:0]音量;
#define RDA_R0A 0X0A //STC[14]seek complete SF[13]seek fail readchan[9:0]当前频道
#define RDA_R0B 0X0B //RSSI[15:9],FM TRUE[8]当前频道是一个节目台
#define RDA_READ 0X23 //读RDA5807
#define RDA_WRITE 0X22 //写RDA5807
//IO操作函数
sbit SDA=P2^1;
sbit SCL=P2^0;
sbit RW =P1^1;
sbit RS=P1^0;
sbit EN=P2^5;
uchar code a[]=FM: . ;
uchar code b[]=Vol: RSSI: ;
uchar code shu[]=0123456789;
uchar num ;
void delayms(uint x) //延迟程序
{
uint i,j;
for(i=x;i0;i--)
for(j=113;j0;j--);
}
/*********************************************** 矩阵键盘程序 ********************************************************************/
uchar ScanKey() //矩阵键盘扫描 返回值是当前按键数值 如没按下则 返回值为零
{
uint x,y;
for(x=0;x4;x++)
{
uchar temp,gaowei;
P3=hang[x]; //分行置零
temp=P30xf0;
if(temp!=0xf0)
{
delayms(10);
if(temp!=0xf0)
{
gaowei=P3/16; //判断是第
文档评论(0)