找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 8173|回復: 9
打印 上一主題 下一主題
收起左側(cè)

基于stm32的攝像頭ov7670顏色識別源碼

  [復制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:371148 發(fā)表于 2018-7-13 20:32 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
//讀取某點的顏色
static void ReadColor( uint16_t usX, uint16_t usY, COLOR_RGB* color_rgb )
{
        unsigned short rgb;
        
        rgb = LCD_ReadPoint( usX, usY );                                        //獲取顏色數(shù)據(jù)
        
        //轉(zhuǎn)換成值域為[0,255]的三原色值
        color_rgb->Red                 = (unsigned char)( ( rgb & 0xF800 ) >> 8 );
        color_rgb->Green  = (unsigned char)( ( rgb & 0x07E0 ) >> 3 );
        color_rgb->Blue         = (unsigned char)( ( rgb & 0x001F ) << 3 );        
}
/*************************************/
//RGB轉(zhuǎn)換為HLS
//H:色度
//L:亮度
//S:飽和度
static void RGB2HSL( const COLOR_RGB* color_rgb, COLOR_HLS* color_hls )
{
        int r, g, b;
        int h, l, s;
        int max, min, dif;
        
        r = color_rgb->Red;
        g = color_rgb->Green;
        b = color_rgb->Blue;
        
        max = maxOf3Values( r, g, b );
        min = minOf3Values( r, g, b );
        dif = max - min;
        
        //計算l,亮度
        l = ( max + min ) * 240 / 255 / 2;
        
        //計算h,色度
        if( max == min )//無定義
        {
                s = 0;
                h = 0;
        }
        else
{
                //計算色度
                if( max == r )
                {
                        if( min == b )//h介于0到40
                        {
                                h = 40 * ( g - b ) / dif;
                        }
                        else if( min == g )//h介于200到240
                        {
                                h = 40 * ( g - b ) / dif + 240;
                        }
                        
                }
                else if( max == g )
                {
                        h = 40 * ( b - r ) / dif + 80;
                }
                else if( max == b )
                {
                        h = 40 * ( r - g ) / dif + 160;
                }
               
                //計算飽和度
                if( l == 0 )
                {
                        s = 0;
                }
                else if( l <= 120 )
                {
                        s = dif * 240 / ( max + min );
                }
                else

{
                        s = dif * 240 / ( 480 - ( max + min ) );
                }                 
        }   
    color_hls->Hue = h;                                                        //色度
        color_hls->Lightness = l;                                //亮度
        color_hls->Saturation = s;                        //飽和度
}


攝像頭(顏色捕捉).rar

395.78 KB, 下載次數(shù): 236, 下載積分: 黑幣 -5

評分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

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

使用道具 舉報

沙發(fā)
ID:249033 發(fā)表于 2018-9-9 22:59 | 只看該作者
東西很好,值得學習
回復

使用道具 舉報

板凳
ID:406408 發(fā)表于 2018-10-11 17:57 來自觸屏版 | 只看該作者
學習了
回復

使用道具 舉報

地板
ID:408914 發(fā)表于 2018-10-13 11:35 | 只看該作者
附件里哪有文件???
回復

使用道具 舉報

5#
ID:138247 發(fā)表于 2019-5-14 10:38 | 只看該作者

感謝樓主分享。。。
回復

使用道具 舉報

6#
ID:352616 發(fā)表于 2019-5-18 22:07 | 只看該作者
敢問使用stm32f1還是f4
回復

使用道具 舉報

7#
ID:499932 發(fā)表于 2019-7-11 11:23 | 只看該作者
怎么更改識別的顏色,現(xiàn)在只能識別綠色
回復

使用道具 舉報

8#
ID:324282 發(fā)表于 2019-7-28 13:30 | 只看該作者
非常好用
回復

使用道具 舉報

9#
ID:322437 發(fā)表于 2019-8-1 21:01 | 只看該作者
樓主有沒有一些原理的簡單介紹
回復

使用道具 舉報

10#
ID:290226 發(fā)表于 2019-8-3 19:28 | 只看該作者
柏禺 發(fā)表于 2019-7-11 11:23
怎么更改識別的顏色,現(xiàn)在只能識別綠色

我的能識別藍色,哥,換下代碼嘛。
回復

使用道具 舉報

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

本版積分規(guī)則

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

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

快速回復 返回頂部 返回列表