2022-09-05 11:29

[轉載] opencv js getPerspectiveTransform,perspectiveTransform 方法使用

轉載自: opencvjs getPerspectiveTransform,perspectiveTransform方法使用

OpenCV JavaScript版本,使用getPerspectiveTransform,PerspectiveTransform方法。

JavaScript和python版本不同的是Mat的创建方法不同,python会在内部自动把数据转换成Mat类,也JavaScript不会,所以刚开始没有找到JavaScript创建Mat方法,走了很多弯路。

这只是测试代码,没有使用项目中真实的数据,所有有一定的偏差。

如果有什么错误,欢迎纠正。

下面上代码:

  1. <!DOCTYPE html> 
  2. <html> 
  3.  
  4. <head> 
  5.  <meta charset="utf-8"> 
  6.  <title>Hello OpenCV.js</title> 
  7. </head> 
  8.  
  9. <body> 
  10.  <h2>Hello OpenCV.js</h2> 
  11.  <h2>getPerspectiveTransform,PerspectiveTransform方法使用</h2> 
  12.  <p id="status">OpenCV.js is loading...</p> 
  13.  <div> 
  14.    <button onClick="myclick()">输出结果</button> 
  15.  </div> 
  16.  <script type="text/javascript"> 
  17.    function myclick() { 
  18.      //代码 getPerspectiveTransform 
  19.      //创建数据 
  20.      let srcTri = cv.matFromArray(4, 1, cv.CV_32FC2, [56, 65, 368, 52, 28, 387, 389, 390]); 
  21.      let dstTri = cv.matFromArray(4, 1, cv.CV_32FC2, [0, 0, 300, 0, 0, 300, 300, 300]); 
  22.      //转换的数据 
  23.      let M = cv.getPerspectiveTransform(srcTri, dstTri); 
  24.      console.log("getPerspectiveTransform M", M); 
  25.  
  26.      //==== PerspectiveTransform ====== 
  27.      //point点的数据一定要是一维的,opencv会自己去处理 
  28.      let points = [ 
  29.        1, 2, 
  30.        3, 4, 
  31.        5, 6, 
  32.        7, 8 
  33.      ]; 
  34.      //原数据 
  35.      points = cv.matFromArray(4,1,cv.CV_32FC2,points); 
  36.      //转换后的数据 
  37.      let points_trans = new cv.Mat(); 
  38.      cv.perspectiveTransform(points, points_trans,M); 
  39.      console.log("points", points); 
  40.      console.log("points_trans", points_trans); 
  41.  
  42.    } 
  43.    function onOpenCvReady() { 
  44.      document.getElementById('status').innerHTML = 'OpenCV.js is ready.'; 
  45.  
  46.    } 
  47.  </script> 
  48.  <script async src="https://docs.opencv.org/4.x/opencv.js" onload="onOpenCvReady();" type="text/javascript"></script> 
  49.  <script src="https://docs.opencv.org/4.x/utils.js" type="text/javascript"></script> 
  50. </body> 
  51.  
  52. </html> 

getPerspectiveTransform结果

perspectiveTransform结果

0 回應: