欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#使用opencv截取旋轉(zhuǎn)矩形區(qū)域圖像的實現(xiàn)示例

 更新時間:2021年03月08日 11:24:28   作者:網(wǎng)友陳  
這篇文章主要介紹了C#使用opencv截取旋轉(zhuǎn)矩形區(qū)域圖像,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧

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

實現(xiàn)方法

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

在這里插入圖片描述

通過

Point2f[] points=rotatedRect.Points();

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

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

滿足:

設(shè)目標RotatedRect長寬為width height,有

在這里插入圖片描述

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

///<Summary>
///利用向量運算截取一個RotatedRect區(qū)域
///</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;
}

到此這篇關(guān)于C#使用opencv截取旋轉(zhuǎn)矩形區(qū)域圖像的文章就介紹到這了,更多相關(guān)C# opencv截取內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C#實現(xiàn)軟件監(jiān)控外部程序運行狀態(tài)的方法

    C#實現(xiàn)軟件監(jiān)控外部程序運行狀態(tài)的方法

    這篇文章主要介紹了C#實現(xiàn)軟件監(jiān)控外部程序運行狀態(tài)的方法,可實現(xiàn)監(jiān)控另一個程序的運行狀態(tài)及觸發(fā)相應(yīng)事件的功能,是非常實用的技巧,需要的朋友可以參考下
    2014-12-12
  • c#擴展datatable轉(zhuǎn)json示例

    c#擴展datatable轉(zhuǎn)json示例

    這篇文章主要介紹了c#擴展datatable轉(zhuǎn)json示例,需要的朋友可以參考下
    2014-05-05
  • C#批量更新sql實例

    C#批量更新sql實例

    這篇文章主要介紹了C#批量更新sql的方法,詳細講述了其實現(xiàn)步驟與對應(yīng)的核心代碼,非常實用,需要的朋友可以參考下
    2014-10-10
  • C# 圖片格式轉(zhuǎn)換的實例代碼

    C# 圖片格式轉(zhuǎn)換的實例代碼

    這篇文章主要介紹了C# 圖片格式轉(zhuǎn)換的實例代碼,文中講解非常詳細,幫助大家更好的理解和學(xué)習c#,感興趣的朋友可以了解下
    2020-08-08
  • C#全局熱鍵設(shè)置與窗體熱鍵設(shè)置實例

    C#全局熱鍵設(shè)置與窗體熱鍵設(shè)置實例

    這篇文章主要介紹了C#全局熱鍵設(shè)置與窗體熱鍵設(shè)置實例,對C#全局熱鍵設(shè)置與窗體熱鍵設(shè)置的實現(xiàn)方法與具體代碼進行了詳細的介紹,需要的朋友可以參考下
    2014-10-10
  • C#實現(xiàn)簡單的loading提示控件實例代碼

    C#實現(xiàn)簡單的loading提示控件實例代碼

    本文通過實例代碼給大家介紹了C#實現(xiàn)簡單的loading提示控件功能,代碼非常簡單,具有參考借鑒價值,需要的朋友參考下吧
    2017-09-09
  • C#泛型接口的協(xié)變和逆變

    C#泛型接口的協(xié)變和逆變

    本文詳細講解了C#泛型接口的協(xié)變和逆變,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2022-04-04
  • 比較全的一個C#操作word文檔示例

    比較全的一個C#操作word文檔示例

    這篇文章主要介紹了比較全的一個C#操作word文檔示例,本文來自己項目心得總結(jié),本文還給出了一個示例,這個示例里面包括了一些常用的圖、文、表、公式的編輯與排版以及頁面設(shè)置、頁眉、頁碼的操作,需要的朋友可以參考下
    2015-06-06
  • C#權(quán)限管理和設(shè)計淺談

    C#權(quán)限管理和設(shè)計淺談

    權(quán)限管理是很多軟件中相當重要的一個模塊——它的設(shè)計的好壞直接影響到軟件的安全性、權(quán)限管理的可擴展性和易操作性 以及代碼中權(quán)限判斷的復(fù)雜程度和效率等方面
    2012-02-02
  • C#中的程序集和反射介紹

    C#中的程序集和反射介紹

    這篇文章主要介紹了C#中的程序集和反射介紹,程序集包含資源文件,類型元數(shù)據(jù)、IL代碼,每個程序集都有自己的名稱、版本等信息,反射就是動態(tài)獲取程序集中的元數(shù)據(jù)的功能,需要的朋友可以參考下
    2015-01-01

最新評論