找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 7476|回复: 4
打印 上一主题 下一主题
收起左侧

STM32F103驱动TCS3200颜色传感器例程

[复制链接]
跳转到指定楼层
楼主
ID:387457 发表于 2018-8-26 08:54 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
颜色传感器驱动代码  STM32

单片机源程序如下:
  1. /*************************************************************************************        *                                TCS3200  STM32版                                     
  2. *                                RGB颜色传感器                 
  3. ****************************************************************************************/
  4. //原子开发板  
  5. #include "stm32f10x.h"
  6. #include "sys.h"
  7. #include "usart.h"               
  8. #include "delay.h"       
  9. #include "led.h"
  10. #include "key.h"
  11. #include "exti.h"
  12. #include "wdg.h"
  13. #include "timer.h"
  14. #include "lcd.h"          
  15. #include "rtc.h"
  16. #include "wkup.h"
  17. #include "adc.h"
  18. #include "dma.h"
  19. #include "24cxx.h"
  20. #include "flash.h"
  21. #include "touch.h"
  22. #include "24l01.h"
  23. #include "mmc_sd.h"
  24. #include "remote.h"
  25. #include "ds18b20.h"
  26. #include "mouse.h"
  27. #include "text.h"
  28. #include "fat.h"
  29. #include "fontupd.h"
  30. #include "tcs3200.h"

  31. /*****************************************************************************
  32.    H指hue(色相)、S指saturation(饱和度)、L指lightness(亮度)、V指value(色调)、B指brightness(明度)。


  33.   色相(H)是色彩的基本属性,就是平常所说的颜色名称,如红色、黄色等。
  34.   饱和度(S)是指色彩的纯度,越高色彩越纯,低则逐渐变灰,取0-100%的数值。
  35.   明度(V),亮度(B),取0-100%。        
  36.   
  37.    0度: 红色,RGB:(255, 0, 0), 255:R, 0:B,G+  
  38.    60度: 黄色,RGB:(255,255, 0),255:G, 0:B, R-  
  39.    120度: 绿色,RGB:( 0,255, 0),255:G, 0:R,B+  
  40.    180度: 青色,RGB:( 0,255,255),255:B, 0:R,G-  
  41.    240度: 蓝色,RGB:( 0, 0,255),255:B, 0:G,R+  
  42.    300度: 紫色,RGB:(255, 0,255),255:R, 0:G,B-  
  43.    360度: 红色,RGB:(255, 0, 0),255:R, 0:B,G+       


  44.   RGB转化到HSV的算法                                                
  45.     max=max(R,G,B)
  46.     min=min(R,G,B)
  47.      if R = max, H = (G-B)/(max-min)
  48.     if G = max, H = 2 + (B-R)/(max-min)
  49.     if B = max, H = 4 + (R-G)/(max-min)
  50.     H = H * 60
  51.     if H < 0, H = H + 360
  52.     V=max(R,G,B)
  53.     S=(max-min)/max
  54. ******************************************************************************/
  55. //============================
  56. void chromatogram(void);  //函数声明
  57. //============================

  58. int main(void)
  59. {       
  60.         float Max=0,Min=0;
  61.         float Rhsv=0,Ghsv=0,Bhsv=0;
  62.         float H=0,S=0,V=0;
  63.         u16 i;
  64.         u8 R=0x00,G=0x00,B=0x00;
  65.         u16 RGB=0x0000;
  66.                             
  67.         Stm32_Clock_Init(9);//系统时钟设置
  68.         delay_init(72);                //延时初始化
  69.         uart_init(72,9600); //串口1初始化            
  70.         LCD_Init();                        //初始化液晶                  
  71.         LED_Init();         //LED初始化       

  72.           LCD_Clear(WHITE);

  73.         POINT_COLOR=RED;
  74.         LCD_ShowString(10,180,"TCS3200 init");

  75.         for(i=0;i<50;i++) delay_ms(50);   

  76.         tcs3200_init(1,1);//初始化(速率调整)
  77.         whitebalance();        //白平衡  

  78.         LCD_ShowString(0,0,"Rgena:");
  79.         LCD_ShowString(0,18,"Ggena:");
  80.         LCD_ShowString(0,36,"Bgena:");
  81.         LCD_ShowNum(50,0,Rgena,5,12);  //显示一个数字
  82.         LCD_ShowNum(50,18,Ggena,5,12);  //显示一个数字
  83.         LCD_ShowNum(50,36,Bgena,5,12);  //显示一个数字


  84.         POINT_COLOR=BLACK;
  85.         LCD_ShowString(30,50,"R:");
  86.         LCD_ShowString(30,70,"G:");
  87.         LCD_ShowString(30,90,"B:");
  88.         LCD_ShowString(30,110,"H:");
  89.         LCD_ShowString(30,130,"V:");
  90.         LCD_ShowString(30,150,"S:");
  91.         chromatogram();//色谱调出

  92.         while(1)                                                  
  93.         {
  94. //=================================================================================
  95.                 R = tcs3200_RED();
  96.                 G = tcs3200_GREEN();        //取RGB值
  97.                 B = tcs3200_BLUE();         
  98. //================================================================================
  99.                 Rhsv = (float) R/25/10;
  100.                 Ghsv = (float) G/25/10;         //RGB转换成0,1.
  101.                 Bhsv = (float) B/25/10;

  102. //=================================================================================
  103.                                                                                                                                          //RGB转HSV算法
  104.                 Max = (Rhsv>Ghsv)?Rhsv:Ghsv;                                                                  //RGB转HSV算法
  105.                 Max = (Max>Bhsv)?Max:Bhsv;                //取RGB最大值                                   //RGB转HSV算法
  106.                 Min = (Rhsv<Ghsv)?Rhsv:Ghsv;                                                                    //RGB转HSV算法
  107.                 Min = (Min<Bhsv)?Min:Bhsv;                //去RGB最小值                                         //RGB转HSV算法
  108.                                                                                                                                                   //RGB转HSV算法                               
  109.                 if(Rhsv==Max) H = (Ghsv-Bhsv)/(Max-Min);                                                   //RGB转HSV算法
  110.                 if(Ghsv==Max) H = 2+(Bhsv-Rhsv)/(Max-Min);                                                          //RGB转HSV算法
  111.                 if(Bhsv==Max) H = 4+(Rhsv-Ghsv)/(Max-Min);                                                         //RGB转HSV算法
  112.                 H =(int) (H*60);                                                                                          //RGB转HSV算法
  113.                 if(H<0) H = H+360;                                                                                                           //RGB转HSV算法
  114.                                                                                                                                                                //RGB转HSV算法
  115.                 V = (Rhsv>Ghsv)?Rhsv:Ghsv;                                                                                                 //RGB转HSV算法
  116.                 V = (V>Bhsv)?V:Bhsv;                //取V的数值                                                                          //RGB转HSV算法
  117.                                                                                                                                                                    //RGB转HSV算法
  118.                 S = (Max-Min)/Max;                        //取S的数值                                                                                //RGB转HSV算法
  119.                                                                                                                                                                           //RGB转HSV算法
  120.                 V = (int) (V*100);                                                                                                                          //RGB转HSV算法
  121.                 S = (int) (S*100);                                                                                                                           //RGB转HSV算法
  122. //======================================================================================================
  123.                 LCD_ShowNum(50,50,R,5,12);  //显示一个数字
  124.                 LCD_ShowNum(50,70,G,5,12);  //显示一个数字
  125.                 LCD_ShowNum(50,90,B,5,12);  //显示一个数字
  126.                 LCD_ShowNum(50,110,H,5,12);  //显示一个数字
  127.                 LCD_ShowNum(50,130,V,5,12);  //显示一个数字
  128.                 LCD_ShowNum(50,150,S,5,12);  //显示一个数字
  129. //                R = 0xff;
  130. //                G = 0xff;
  131. //                B = 0xff;
  132. //=====================================================
  133.                 RGB = 0x0000;
  134.                 RGB |=(unsigned long) R*1000/8225<<11;                          
  135.                 RGB |=(unsigned long) G*1000/4047<<5;          //转换成屏幕的4W色显示
  136.                 RGB |=(unsigned long) B*1000/8225;               
  137. //=====================================================
  138.                 LCD_Fill(10,170,80,260,RGB);   //显示色彩
  139.                 delay_ms(50);                                   //刷新次数



  140.         }
  141. }


  142. /**********************************************
  143. *函数名:void chromatogram(void)
  144. *功能:在屏幕上面显示一张色谱
  145. *参数:木有
  146. *返回值:木有
  147. ***********************************************/                                 
  148. void chromatogram(void)
  149. {

  150.         u16 i=0;
  151.         u16 color;
  152.         u16 Ri=0,Gi=0,Bi=0;

  153. //======================================================================               
  154.         Ri = 240;Gi = 0x00;Bi = 0x00;               
  155.         for(i=0;i<60;i++)
  156.         {
  157.                 color  = (unsigned long) Gi*1000/4047<<5;
  158.                 color |= (unsigned long) Ri*1000/8225<<11;        //G加上去                          
  159.                 color |= (unsigned long) Bi*1000/8225;                       
  160.                 LCD_Fill(100,i,230,i,color);       
  161.                
  162.                 Gi = Gi+4;       
  163.         }
  164.         Ri = 240;Gi = 240;Bi = 0x00;
  165.         for(i=60;i<120;i++)
  166.         {
  167.                 color  = (unsigned long) Ri*1000/8225<<11;                                  
  168.                 color |= (unsigned long) Gi*1000/4047<<5;        //R降下来
  169.                 color |= (unsigned long) Bi*1000/8225;       
  170.                 LCD_Fill(100,i,230,i,color);

  171.                 Ri = Ri-4;
  172.         }
  173.         Ri = 0x00;Gi = 240;Bi = 0x00;
  174.         for(i=120;i<180;i++)
  175.         {
  176.                 color  = (unsigned long) Bi*1000/8225;       
  177.                 color |= (unsigned long) Ri*1000/8225<<11;        //B加上去                          
  178.                 color |= (unsigned long) Gi*1000/4047<<5;
  179.                 LCD_Fill(100,i,230,i,color);

  180.                 Bi = Bi+4;
  181.         }
  182.         Ri = 0x00;Gi = 240;Bi = 240;
  183.         for(i=180;i<240;i++)
  184.         {
  185.                 color  = (unsigned long) Gi*1000/4047<<5;
  186.                 color |= (unsigned long) Bi*1000/8225;                //G降下来
  187.                 color |= (unsigned long) Ri*1000/8225<<11;                                  
  188.                 LCD_Fill(100,i,230,i,color);

  189.                 Gi = Gi-4;
  190.         }
  191.         Ri = 0x00;Gi = 0x00;Bi = 240;
  192.         for(i=240;i<300;i++)
  193.         {
  194.                 color = (unsigned long) Ri*1000/8225<<11;                                  
  195.                 color |= (unsigned long) Gi*1000/4047<<5;          //R加上去
  196.                 color |= (unsigned long) Bi*1000/8225;       
  197.                 LCD_Fill(100,i,230,i,color);

  198.                 Ri = Ri+4;
  199.         }
  200.         Ri = 240;Gi = 0x00;Bi = 240;
  201.         for(i=300;i<360;i++)
  202.         {
  203.                 color  = (unsigned long) Bi*1000/8225;       
  204.                 color |= (unsigned long) Ri*1000/8225<<11;                                  
  205.                 color |= (unsigned long) Gi*1000/4047<<5;                //B降下来
  206.                 LCD_Fill(100,i,230,i,color);

  207.                 Bi = Bi-4;
  208.         }
  209. //===========================================================================
  210.        
  211. }
复制代码

所有资料51hei提供下载:
STM32 TCS3200.rar (165.76 KB, 下载次数: 302)


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏2 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:486810 发表于 2019-3-8 12:12 | 只看该作者
谢谢分享!
回复

使用道具 举报

板凳
ID:522999 发表于 2019-4-27 15:52 | 只看该作者
谢谢分想啊啊
回复

使用道具 举报

地板
ID:358310 发表于 2019-10-12 09:43 | 只看该作者
一堆报错,浪费资源
回复

使用道具 举报

5#
ID:640094 发表于 2019-11-11 22:50 | 只看该作者
你好可以提供一个借口定义嘛
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表