91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C#如何實現opencv截取旋轉矩形區域圖像

發布時間:2021-03-08 15:22:46 來源:億速云 閱讀:610 作者:TREX 欄目:開發技術

本篇內容主要講解“C#如何實現opencv截取旋轉矩形區域圖像”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“C#如何實現opencv截取旋轉矩形區域圖像”吧!

前言:最近在工程中需要用到截取RotatedRect中的圖形,保存為Mat做后續處理。發現opencv文檔中沒有這個api,最開始想到的方案是將整張圖片進行相應的旋轉,然后再從中截取正矩形,但是我們要獲取的是部分區域,將整張圖片進行旋轉會造成很多的資源浪費。所以需要自行實現一個旋轉矩形的方案。

實現方法

原理是利用向量空間變換,如圖

C#如何實現opencv截取旋轉矩形區域圖像

通過

Point2f[] points=rotatedRect.Points();

可獲取RotatedRect四個端點的坐標。先選定一個點為輸出Mat左上端點,這里采取的是離原圖左上角最近的端點(即x2+y2最小)。然后再選取相鄰的2個端點,作向量Vx及Vy。這里可以根據需求來選定Vx和Vy的方向,比如要求輸出Mat的Width大于Height,那就選定長的一邊為Vx。這里直接選定左上端點到順時針方向的端點的向量為Vx,即如圖所示。

在選定好Vx和Vy后,進行向量空間的變換。設在輸出的Mat中任一一個坐標點(i,j),對應在輸出Mat中的任一坐標點(x,y)。設左上端點坐標(x0,y0) (即圖中點2),

滿足:

設目標RotatedRect長寬為width height,有

C#如何實現opencv截取旋轉矩形區域圖像

然后做一個二重循環,將j從0循環到height,i從0循環到width,就可以得到輸出Mat所有像素的信息。
下面為一個截取BGR類型的Mat的RotatedRect的代碼

///<Summary>
///利用向量運算截取一個RotatedRect區域
///</Summary>
///<param name="img">類型為CV_U8C3的Mat</param>
///<param name="rotatedRect">RotatedRect</param>
public static Mat sliceRotetedImg8UC3(Mat img,RotatedRect rotatedRect){
 // Rect bounding=rotatedRect.BoundingRect();
 Point2f[] points=rotatedRect.Points();
 int topLeftIndex=0;
 double topLeftR=points[0].X*points[0].X+points[0].Y*points[0].Y;
 for(int i=1;i<4;i++){
  double r=points[i].X*points[i].X+points[i].Y*points[i].Y;
  if(r<topLeftR){
   topLeftIndex=i;
   topLeftR=r;
  }
 }
 double x1=points[(topLeftIndex+1)%4].X-points[topLeftIndex].X,y1=points[(topLeftIndex+1)%4].Y-points[topLeftIndex].Y;
 double x2=points[(topLeftIndex+3)%4].X-points[topLeftIndex].X,y2=points[(topLeftIndex+3)%4].Y-points[topLeftIndex].Y;
 double vX1=x1,vY1=y1,vX2=x2,vY2=y2;
 int width=(int)Math.Sqrt(vX1*vX1+vY1*vY1),height=(int)Math.Sqrt(vX2*vX2+vY2*vY2);
 Mat ret=new Mat(new Size(width,height),MatType.CV_8UC3);
 // Console.WriteLine($"width={width},height={height}");
 var indexer1=img.GetGenericIndexer<Vec3b>();
 var indexer2=ret.GetGenericIndexer<Vec3b>();
 for(int j=0;j<ret.Height;j++){
  for(int i=0;i<ret.Width;i++){
   double kx=(double)i/width,ky=(double)j/height;
   int x=(int)(points[topLeftIndex].X+kx*vX1+ky*vX2),y=(int)(points[topLeftIndex].Y+kx*vY1+ky*vY2);
   indexer2[j,i]=indexer1[y,x];
  }
 }
 return ret;
}

到此,相信大家對“C#如何實現opencv截取旋轉矩形區域圖像”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

长海县| 苏尼特左旗| 盐亭县| 雷波县| 满城县| 五大连池市| 神农架林区| 呈贡县| 县级市| 乳源| 彰化县| 油尖旺区| 深泽县| 灵山县| 鸡西市| 湖州市| 灵武市| 建德市| 武隆县| 鄂尔多斯市| 周至县| 土默特左旗| 绥滨县| 邵东县| 山阳县| 广河县| 牙克石市| 五华县| 安康市| 北川| 阿瓦提县| 吐鲁番市| 类乌齐县| 阜康市| 栾城县| 榆社县| 沙河市| 叶城县| 湖南省| 林甸县| 故城县|