基于51的tcs3200颜色辨别.doc_第1页
基于51的tcs3200颜色辨别.doc_第2页
基于51的tcs3200颜色辨别.doc_第3页
基于51的tcs3200颜色辨别.doc_第4页
基于51的tcs3200颜色辨别.doc_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

基于51的tcs3200颜色辨别,用lcd1602显示数据,并根据相对数据进行颜色辨别,先用1602查看每种颜色对应的数据,再通过这些数据设定范围,然后通过P22、P23、P24三盏LED灯显示对应的三种颜色,程序复制直接可用,具体调试范围在下面#include /51寄存器文件#include #define uchar unsigned char#define uint unsigned intvoid conversion(uint temp_data) ;void t0_init();/*引脚定义*/ sbit s2=P10; /TCS3200 S2 sbit s3=P11; /TCS3200 S3sbit Rled = P24; sbit Bled = P23;sbit Gled = P22;sbit E0 = P12; /变量、常量定义uchar ge,shi,bai ;uchar rp=3,gp=6,bp=9,tt=0; /定义比例因子,具体环境可以修改 /颜色标志位(0:红 1:绿 2:蓝) uint temp; /显示数组uchar disp_R3=0,0,0; /红uchar disp_G3=0,0,0; /绿uchar disp_B3=0,0,0; /蓝int sumR,sumB,sumG,count=0; typedef unsigned char BYTE;/用BYTE代替unsigned char typedef bit BOOL; / 用BOOL代替bit sbit LCD_RS = P27; /复位端 sbit LCD_RW = P26; /写数据端sbit LCD_EP = P25; /使能端/*延时函数*/void delay(int ms) /延时子程序int i;while(ms-) for(i = 0; i 100; i+) _nop_(); /空执行 _nop_(); _nop_(); _nop_(); /*侧忙函数*/BOOL lcdcm() BOOL result;LCD_RS = 0;LCD_RW = 1;LCD_EP = 1;_nop_();_nop_();_nop_();_nop_();result = (BOOL)(P0 & 0x80); /检测P0最高位是否为1LCD_EP = 0;return result;/返回侧忙结果/*写命令函数*/void lcdcom8(int cmd) / 写入指令数据到LCDwhile(lcdcm();LCD_RS = 0;LCD_RW = 0;LCD_EP = 0;_nop_();_nop_(); P0 = cmd; /将高4位位指令通过P0口传给1602_nop_();_nop_(); /用于产生一个脉冲宽度_nop_();_nop_();LCD_EP = 1;_nop_();_nop_();_nop_();_nop_();LCD_EP = 0; void lcdcom(int cmd) / 写入指令数据到LCDwhile(lcdcm();LCD_RS = 0;LCD_RW = 0;LCD_EP = 0;_nop_();_nop_(); P0 = cmd; /将高4位位指令通过P0口传给1602_nop_();_nop_(); /用于产生一个脉冲宽度_nop_();_nop_();LCD_EP = 1;_nop_();_nop_();_nop_();_nop_();LCD_EP = 0; P0 = (cmd&0x0f)4; /将低4位指令通过P0口传给1602_nop_();_nop_(); /用于产生一个脉冲宽度_nop_();_nop_();LCD_EP = 1;_nop_();_nop_();_nop_();_nop_();LCD_EP = 0; /void lcd_pos(BYTE pos)/ /设定显示位置/lcdcom(pos | 0x80);/*写数据函数*/void lcddat(BYTE dat) /写入字符显示数据到LCDwhile(lcdcm();LCD_RS = 1;LCD_RW = 0;LCD_EP = 0;P0 = dat ; /将高4位数据通过P0口传给1602_nop_();_nop_(); /用于产生一个脉冲宽度_nop_();_nop_();LCD_EP = 1;_nop_();_nop_();_nop_();_nop_();LCD_EP = 0; LCD_RS = 1;LCD_RW = 0;LCD_EP = 0;_nop_();_nop_();_nop_();_nop_();P0 = (dat&0x0f)4; /将低4位位数据通过P0口传给1602_nop_();_nop_(); /用于产生一个脉冲宽度_nop_();_nop_();LCD_EP = 1;_nop_();_nop_();_nop_();_nop_();LCD_EP = 0; void init()/LCD初始化设定 lcdcom8(0x38); /16*2显示,5*7点阵,8位数据delay(1); lcdcom8(0x38); /16*2显示,5*7点阵,8位数据delay(1); lcdcom8(0x28); /16*2显示,5*7点阵,8位数据delay(1); lcdcom(0x28);delay(1); lcdcom(0x0c); /显示开,关光标delay(1); lcdcom(0x02); /显示开,关光标delay(1); lcdcom(0x01); /清除LCD的显示内容delay(1); void t0_init()TMOD=0x51; /T1计数 T0定时 工作方式1TH1=0x00; /计数初值TL1=0x00;TH0=0xE0;TL0=0x00; /11。0592M 晶振10msEA=1; /开中断 ET1=1;ET0=1; TR0=1; /启动TR1=1;/*/数值转换出个十百千的ASCII码/*void conversion(uint temp_data) bai=temp_data/100+0x30 ; temp_data=temp_data%100; /取余运算 shi=temp_data/10+0x30 ; ge=temp_data%10+0x30; /取余运算void c10ms_out() interrupt 1 tt+;TR0=0; /关闭定时TR1=0; /关闭计数if(count=0) count+;s2=1;s3=1; /选择滤波器为绿色 temp=(16TH1)+TL1; /计算这段时间内 TCS230 的输出脉冲数temp/=rp;sumR=temp;conversion(temp);disp_R2 = ge; /因为这次的中断,是上次选择滤波器的数值disp_R1 = shi;disp_R0 = bai; else if(count=1) count+; s2=1;s3=0; /选择滤波器为蓝色temp=(16TH1)+TL1; /计算这段时间内 TCS230 的输出脉冲数temp/=gp;sumG = temp;conversion(temp);disp_G2 = ge; /因为这次的中断,是上次选择滤波器的数值disp_G1 = shi;disp_G0 = bai; else if(2=count) count=0;s2=0;s3=0; /选择滤波器为红色temp=(16TH1)+TL1; /计算这段时间内 TCS230 的输出脉冲数temp/=bp;sumB=temp;conversion(temp);disp_B2 = ge; /因为这次的中断,是上次选择滤波器的数值disp_B1 = shi;disp_B0 = bai;/定时器计数器重赋初值TH0=0xE0;TL0=0x00; /11。0592M 晶振,为10msTL1=0x00;/计数器清零TH1=0x00;/计数器清零TR0=1; /打开定时器TR1=1; /打开计数器 main() P2 = 0xff; P1 = 0xff; E0=0; init(); / 初始化LCD delay(3); s2=0; /初始设定S2引脚 s3=0; /初始设定S3引脚 t0_init(); /定时计数初使while(1) if(tt=30) EA = 0; tt=0;lcdcom(0x80); lcddat(T);lcddat(C);lcddat(S);lcddat(2);lcddat(3);lcddat(0);lcddat( );lcddat(R); lcddat(); lcddat(disp_R0); lcddat(disp_R1); lcddat(disp_R2);lcddat();lcdcom (0x80+0x40);lcddat( G); lcddat( ); lcddat(disp_G0); lcddat(disp_G1); lcddat(disp_G2);lcddat( ); lcddat( );lcddat( B); lcddat( ); lcddat(disp_B0); lcddat(

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论