網站首頁 編程語言 正文
場景需求
在做圖像處理時,有時候會需要適當地進行一些裁剪工作,比如我做干涉測量領域,我們所要處理的圖像區域是條紋所在區域,而原圖又遠大于我所想分析的目標區,此時就需要對圖像進行裁剪,這樣做的好處:
1)縮減計算量,提高程序運行速度;
2)裁剪后的圖像尺寸正好是歸一化的圖像尺寸,如果有歸一化的需求,可以直接用裁剪圖像尺寸建立歸一化數據網格圖。
我就是為了計算柱面的擬合系數才寫了這個函數,若要得到同光學領域標準一致的系數,需要先歸一化數據,而歸一化的范圍就正好是裁剪的圖像大小。
函數通俗易懂,就是用掩膜鎖定目標區,再分析掩膜在原圖中的上下左右邊界,用roi提取出來即可。
話不多說,下方為具體實現函數和測試代碼。
功能函數代碼
/**
* @brief ImageCropping 圖像裁剪
* @param phase 所需裁剪的圖像
* @return 裁剪后圖像
*/
cv::Mat ImageCropping(const cv::Mat &phase) {
// 非測量區一般都進行了NaN處理,所以掩膜繪制只需要判斷是否為NaN值即可
cv::Mat mask = cv::Mat::zeros(phase.size(), CV_8UC1);
mask.setTo(255, phase == phase);
int roi_up = 10000;
int roi_down = 0;
int roi_left = 10000;
int roi_right = 0;
int row = phase.rows;
int col = phase.cols;
for (int i = 0; i < row; i++)
{
uchar *m = mask.ptr<uchar>(i);
for (int j = 0; j < col; j++)
{
if (m[j] != 0)
{
if (j < roi_left)roi_left = j;
if (j > roi_right)roi_right = j;
if (i < roi_up)roi_up = i;
if (i > roi_down)roi_down = i;
}
}
}
int w = roi_right - roi_left;
int h = roi_down - roi_up;
// 一般提取奇數尺寸,方便計算
if (w % 2 == 0)w++;
if (h % 2 == 0)h++;
cv::Mat crop_phase = phase(cv::Rect(roi_left, roi_up, w, h)).clone();
return crop_phase;
}
C++測試代碼
#include<iostream>
#include<opencv2/opencv.hpp>
#include<ctime>
using namespace std;
using namespace cv;
cv::Mat ImageCropping(const cv::Mat &phase);
int main(void)
{
cv::Mat phase(100, 100, CV_32FC1, nan(""));
cv::circle(phase, cv::Point(50, 50), 30, 255, -1);
cv::Mat crop = ImageCropping(phase);
imshow("original", phase);
imshow("result", crop);
waitKey(0);
system("pause");
return 0;
}
/**
* @brief ImageCropping 圖像裁剪
* @param phase 所需裁剪的圖像
* @return 裁剪后圖像
*/
cv::Mat ImageCropping(const cv::Mat &phase) {
// 非測量區一般都進行了NaN處理,所以掩膜繪制只需要判斷是否為NaN值即可
cv::Mat mask = cv::Mat::zeros(phase.size(), CV_8UC1);
mask.setTo(255, phase == phase);
int roi_up = 10000;
int roi_down = 0;
int roi_left = 10000;
int roi_right = 0;
int row = phase.rows;
int col = phase.cols;
for (int i = 0; i < row; i++)
{
uchar *m = mask.ptr<uchar>(i);
for (int j = 0; j < col; j++)
{
if (m[j] != 0)
{
if (j < roi_left)roi_left = j;
if (j > roi_right)roi_right = j;
if (i < roi_up)roi_up = i;
if (i > roi_down)roi_down = i;
}
}
}
int w = roi_right - roi_left;
int h = roi_down - roi_up;
// 一般提取奇數尺寸,方便計算
if (w % 2 == 0)w++;
if (h % 2 == 0)h++;
cv::Mat crop_phase = phase(cv::Rect(roi_left, roi_up, w, h)).clone();
return crop_phase;
}
測試效果? ? ?
圖1 裁剪前后對比圖
在測試案例中,隨機生成了一個100*100的數據矩陣,中間一個30半徑的圓,也是我需要的目標區域,運用ImageCropping函數實現了目標區域的提取。
原文鏈接:https://blog.csdn.net/zhaitianbao/article/details/119449561
相關推薦
- 2022-07-18 SQL?Server中實現錯誤處理_MsSql
- 2023-12-11 Mybatis數據庫操作筆記(Mybatis基礎CRUD代碼)
- 2022-04-28 利用shell命令刪除指定的文件的方法_linux shell
- 2022-07-10 springboot 將logback日志根據不同類輸入到不同路徑下
- 2022-12-02 Android?使用?okhttp3和retrofit2?進行單文件和多文件上傳_Android
- 2022-08-16 Docker中部署Redis集群與部署微服務項目的詳細過程_docker
- 2022-05-09 React中的axios模塊及使用方法_React
- 2022-11-25 命令行下執行TypeScript文件的三種方法_基礎知識
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支