久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 8547|回復(fù): 4
打印 上一主題 下一主題
收起左側(cè)

STM32F103驅(qū)動TCS3200顏色傳感器例程

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:387457 發(fā)表于 2018-8-26 08:54 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
顏色傳感器驅(qū)動代碼  STM32

單片機源程序如下:
  1. /*************************************************************************************        *                                TCS3200  STM32版                                     
  2. *                                RGB顏色傳感器                 
  3. ****************************************************************************************/
  4. //原子開發(fā)板  
  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(色調(diào))、B指brightness(明度)。


  33.   色相(H)是色彩的基本屬性,就是平常所說的顏色名稱,如紅色、黃色等。
  34.   飽和度(S)是指色彩的純度,越高色彩越純,低則逐漸變灰,取0-100%的數(shù)值。
  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度: 藍(lán)色,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轉(zhuǎn)化到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);  //函數(shù)聲明
  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);//系統(tǒng)時鐘設(shè)置
  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);//初始化(速率調(diào)整)
  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);  //顯示一個數(shù)字
  82.         LCD_ShowNum(50,18,Ggena,5,12);  //顯示一個數(shù)字
  83.         LCD_ShowNum(50,36,Bgena,5,12);  //顯示一個數(shù)字


  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();//色譜調(diào)出

  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轉(zhuǎn)換成0,1.
  101.                 Bhsv = (float) B/25/10;

  102. //=================================================================================
  103.                                                                                                                                          //RGB轉(zhuǎn)HSV算法
  104.                 Max = (Rhsv>Ghsv)?Rhsv:Ghsv;                                                                  //RGB轉(zhuǎn)HSV算法
  105.                 Max = (Max>Bhsv)?Max:Bhsv;                //取RGB最大值                                   //RGB轉(zhuǎn)HSV算法
  106.                 Min = (Rhsv<Ghsv)?Rhsv:Ghsv;                                                                    //RGB轉(zhuǎn)HSV算法
  107.                 Min = (Min<Bhsv)?Min:Bhsv;                //去RGB最小值                                         //RGB轉(zhuǎn)HSV算法
  108.                                                                                                                                                   //RGB轉(zhuǎn)HSV算法                               
  109.                 if(Rhsv==Max) H = (Ghsv-Bhsv)/(Max-Min);                                                   //RGB轉(zhuǎn)HSV算法
  110.                 if(Ghsv==Max) H = 2+(Bhsv-Rhsv)/(Max-Min);                                                          //RGB轉(zhuǎn)HSV算法
  111.                 if(Bhsv==Max) H = 4+(Rhsv-Ghsv)/(Max-Min);                                                         //RGB轉(zhuǎn)HSV算法
  112.                 H =(int) (H*60);                                                                                          //RGB轉(zhuǎn)HSV算法
  113.                 if(H<0) H = H+360;                                                                                                           //RGB轉(zhuǎn)HSV算法
  114.                                                                                                                                                                //RGB轉(zhuǎn)HSV算法
  115.                 V = (Rhsv>Ghsv)?Rhsv:Ghsv;                                                                                                 //RGB轉(zhuǎn)HSV算法
  116.                 V = (V>Bhsv)?V:Bhsv;                //取V的數(shù)值                                                                          //RGB轉(zhuǎn)HSV算法
  117.                                                                                                                                                                    //RGB轉(zhuǎn)HSV算法
  118.                 S = (Max-Min)/Max;                        //取S的數(shù)值                                                                                //RGB轉(zhuǎn)HSV算法
  119.                                                                                                                                                                           //RGB轉(zhuǎn)HSV算法
  120.                 V = (int) (V*100);                                                                                                                          //RGB轉(zhuǎn)HSV算法
  121.                 S = (int) (S*100);                                                                                                                           //RGB轉(zhuǎn)HSV算法
  122. //======================================================================================================
  123.                 LCD_ShowNum(50,50,R,5,12);  //顯示一個數(shù)字
  124.                 LCD_ShowNum(50,70,G,5,12);  //顯示一個數(shù)字
  125.                 LCD_ShowNum(50,90,B,5,12);  //顯示一個數(shù)字
  126.                 LCD_ShowNum(50,110,H,5,12);  //顯示一個數(shù)字
  127.                 LCD_ShowNum(50,130,V,5,12);  //顯示一個數(shù)字
  128.                 LCD_ShowNum(50,150,S,5,12);  //顯示一個數(shù)字
  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;          //轉(zhuǎn)換成屏幕的4W色顯示
  136.                 RGB |=(unsigned long) B*1000/8225;               
  137. //=====================================================
  138.                 LCD_Fill(10,170,80,260,RGB);   //顯示色彩
  139.                 delay_ms(50);                                   //刷新次數(shù)



  140.         }
  141. }


  142. /**********************************************
  143. *函數(shù)名:void chromatogram(void)
  144. *功能:在屏幕上面顯示一張色譜
  145. *參數(shù):木有
  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. }
復(fù)制代碼

所有資料51hei提供下載:
STM32 TCS3200.rar (165.76 KB, 下載次數(shù): 302)


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏2 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

沙發(fā)
ID:486810 發(fā)表于 2019-3-8 12:12 | 只看該作者
謝謝分享!
回復(fù)

使用道具 舉報

板凳
ID:522999 發(fā)表于 2019-4-27 15:52 | 只看該作者
謝謝分想啊啊
回復(fù)

使用道具 舉報

地板
ID:358310 發(fā)表于 2019-10-12 09:43 | 只看該作者
一堆報錯,浪費資源
回復(fù)

使用道具 舉報

5#
ID:640094 發(fā)表于 2019-11-11 22:50 | 只看該作者
你好可以提供一個借口定義嘛
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 一级黄色在线 | 国产精品视频免费看 | 精品成人在线观看 | 国产精品久久久久无码av | 欧美日韩看片 | 久久久精品一区二区 | 国产精品福利一区二区三区 | 国产精品1区 | 精品一区二区三区在线观看国产 | 免费国产视频 | 国产一区二区三区在线视频 | 国产日韩精品一区 | 亚洲综合区 | 国产精品伦理一区 | 亚洲综合五月天婷婷 | 国产精品美女久久久久aⅴ国产馆 | 91精品一区 | 狠狠做六月爱婷婷综合aⅴ 国产精品视频网 | 99成人 | 欧美亚洲另类丝袜综合网动图 | 国产精品精品视频一区二区三区 | 久国产精品 | 亚洲一区二区三区在线播放 | 龙珠z国语版在线观看 | 国产成人精品久久久 | 欧美日韩亚洲成人 | 欧美成人激情 | 国产成人99久久亚洲综合精品 | 国产乱码精品一区二区三区忘忧草 | 国产欧美日韩一区 | 网站黄色在线免费观看 | 国产精品久久av | 成人永久免费视频 | 成人99| 国产中文字幕在线 | 射久久 | 狠狠做六月爱婷婷综合aⅴ 国产精品视频网 | 国产羞羞视频在线观看 | 亚洲午夜在线 | 国产精品久久久久久久午夜片 | 久久精品视频网站 |