曙海教育集團論壇DSP專區DSP系統和硬件開發討論區 → 李現路:DSP6000圖像位置移動與變形的典型算法(三)


  共有8363人關注過本帖樹形打印

主題:李現路:DSP6000圖像位置移動與變形的典型算法(三)

客人(124.78.*.*)
  1樓


李現路:DSP6000圖像位置移動與變形的典型算法(三)  發帖心情 Post By:2009-12-3 13:48:22

李現路:DSP6000圖像位置移動與變形的典型算法(三)

 

三、圖像的水平鏡像變換算法

數學表達式原理:


設圖像高度為IHeight,寬度為IWidth,原圖中(x0,y0)經過水平鏡像后從未將變為

(IWidth-x0,y0),其表達式為:

X0=IWidth-y1; y0=y1


算法的C語言代碼:


/*水平鏡像變換處理*/

void horizTranspose()

{

         int i,j;

         for(i=0;i<numLines;i++)

         {            

              /*前半部分為原始圖像*/

              //傳送臨時Y緩沖區

                   DAT_copy((void *)(capYbuffer + i * numPixels),

                      (void *)(tempYbuffer + i * numPixels),

                      numPixels>>1);                                                       

             //傳送臨時Cb緩沖區

             DAT_copy((void *)(capCbbuffer + i * (numPixels >> 1)),

                      (void *)(tempCbbuffer + i * (numPixels >> 1)),

                      numPixels>>2);        

             //傳送臨時Cr緩沖區

             DAT_copy((void *)(capCrbuffer + i * (numPixels >> 1)),

                      (void *)(tempCrbuffer + i * (numPixels >> 1)),

                      numPixels>>2);                                                                          

                  

                   /*后半部分為水平鏡像圖像*/

                   for(j=numPixels/2;j<numPixels;j++)

                   {

                            //傳送臨時Y緩沖區               

                            *(Uint8 *)(tempYbuffer + i*numPixels + j) = *(Uint8 *)(capYbuffer + i*numPixels + numPixels-1-j);             

                   }

                               

             for(j=(numPixels>>2);j<(numPixels>>1);j++)

                   {

                            //傳送臨時Cb緩沖區

                            *(Uint8 *)(tempCbbuffer + i*(numPixels>>1) + j) = *(Uint8 *)(capCbbuffer + i*(numPixels>>1) + (numPixels>>1)-1-j);                   

                            //傳送臨時Cr緩沖區

                            *(Uint8 *)(tempCrbuffer + i*(numPixels>>1) + j) = *(Uint8 *)(capCrbuffer + i*(numPixels>>1) + (numPixels>>1)-1-j);                   

                   }

                                      

          }

}



四、圖像的縮放算法

數學表達式原理:

假設圖像x軸方向縮放比率fx,y軸方向縮放比率是fy,那么原圖中點(x0,y0)對應

于新圖中的點(x1,y1)的轉換表達式為:

X0=x1/fx; y0=y1/fy


算法的C語言代碼:

 

/*圖像縮放參數*/

Float fXZoomRatio=0.5; //水平縮放比率

Float fYZoomRatio=0.5; //垂直縮放比率

/*縮放處理函數*/


/*縮放處理*/

void zoom()

{

         int i,j;

         int intCapX,intCapY;

         for(i=0;i<numLines;i++)

         {

             for(j=0;j<numPixels;j++)

             {                    

            intCapX = (int)(j/fYZoomRatio+0.5);

            intCapY = (int)(i/fXZoomRatio+0.5);          

            

            //判斷是否在原圖范圍內

            if((intCapX>=0) && (intCapX<numPixels))  

            {  

                     if((i<numLines/2) && (intCapY>=0) && (intCapY<numLines/2))

                     {

                                         //傳送亮度信號

                                         *(Uint8 *)(tempYbuffer + i*numPixels + j) = *(Uint8 *)(capYbuffer + intCapY*numPixels + intCapX); 

                                }

                                else if((i>=numLines/2) && (i<numLines) && (intCapY>=numLines/2) && (intCapY<numLines))

                                {

                                             //傳送亮度信號

                                         *(Uint8 *)(tempYbuffer + i*numPixels + j) = *(Uint8 *)(capYbuffer + intCapY*numPixels + intCapX);                        

                                }

                                else

                                {

                                    *(Uint8 *)(tempYbuffer + i*numPixels + j) = 0xFF;

                                }                                                                                  

                 }

            else

            {

                      *(Uint8 *)(tempYbuffer + i*numPixels + j) = 0xFF;

            }                                             

                   }       

         }

}


[此貼子已經被作者于2009-12-3 13:54:26編輯過]

支持(0中立(0反對(0單帖管理 | 引用 | 回復 回到頂部

返回版面帖子列表

李現路:DSP6000圖像位置移動與變形的典型算法(三)








簽名
主站蜘蛛池模板: 波多野结衣教师诱惑| 麻豆安全免费网址入口| 欧洲亚洲国产精华液| 国产成人精品一区二区三区免费 | 中文字幕av无码不卡免费| 练瑜伽的时候进入| 天天天天天天天操| 亚洲成人www| 高级秘密俱乐部的娇妻| 手机看片一区二区| 人妻大战黑人白浆狂泄| 18videosex性欧美69免费播放| 晓青老师的丝袜系列txt下载| 国产99久久久久久免费看| www.日本在线视频| 欧美成人家庭影院| 国产乱码精品一区二区三区四川人| 一区视频在线播放| 欧美日韩在线视频一区| 国产又爽又黄无码无遮挡在线观看| 两个人看的www视频免费完整版 | 无码人妻精品一区二区三区不卡 | 国产又粗又猛又大的视频 | 精品国产乱码久久久久软件| 国产麻豆成av人片在线观看| 久久精品视频亚洲| 精品精品国产自在97香蕉| 国产草草影院ccyycom| 久久精品国产99国产精偷| 精品久久久久香蕉网| 国产精品制服丝袜一区| 中文字幕日韩丝袜一区| 欧美边吃奶边爱边做视频| 国产午夜福利精品一区二区三区 | 男人j桶进女人免费视频| 国产男女无遮挡猛进猛出| 两对夫妇交换野营| 欧美人与物videos另类xxxxx | 国产真实乱xxxav| 三上悠亚一区二区观看| 欧美叉叉叉BBB网站|