網(wǎng)站首頁 編程語言 正文
場景需求
在做圖像處理時,有時候會需要適當?shù)剡M行一些裁剪工作,比如我做干涉測量領域,我們所要處理的圖像區(qū)域是條紋所在區(qū)域,而原圖又遠大于我所想分析的目標區(qū),此時就需要對圖像進行裁剪,這樣做的好處:
1)縮減計算量,提高程序運行速度;
2)裁剪后的圖像尺寸正好是歸一化的圖像尺寸,如果有歸一化的需求,可以直接用裁剪圖像尺寸建立歸一化數(shù)據(jù)網(wǎng)格圖。
我就是為了計算柱面的擬合系數(shù)才寫了這個函數(shù),若要得到同光學領域標準一致的系數(shù),需要先歸一化數(shù)據(jù),而歸一化的范圍就正好是裁剪的圖像大小。
函數(shù)通俗易懂,就是用掩膜鎖定目標區(qū),再分析掩膜在原圖中的上下左右邊界,用roi提取出來即可。
話不多說,下方為具體實現(xiàn)函數(shù)和測試代碼。
功能函數(shù)代碼
/**
* @brief ImageCropping 圖像裁剪
* @param phase 所需裁剪的圖像
* @return 裁剪后圖像
*/
cv::Mat ImageCropping(const cv::Mat &phase) {
// 非測量區(qū)一般都進行了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;
// 一般提取奇數(shù)尺寸,方便計算
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) {
// 非測量區(qū)一般都進行了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;
// 一般提取奇數(shù)尺寸,方便計算
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的數(shù)據(jù)矩陣,中間一個30半徑的圓,也是我需要的目標區(qū)域,運用ImageCropping函數(shù)實現(xiàn)了目標區(qū)域的提取。
原文鏈接:https://blog.csdn.net/zhaitianbao/article/details/119449561
相關推薦
- 2022-12-29 python中的多進程的創(chuàng)建與啟動方式_python
- 2022-10-03 Pandas中inf值替換的方法_python
- 2022-03-16 C程序中Ubuntu、stm32的內存分配問題_C 語言
- 2022-06-22 關于Metalama使用Fabric操作項目或命名空間的問題_實用技巧
- 2022-04-04 Python數(shù)據(jù)處理-導入導出excel數(shù)據(jù)_python
- 2023-07-08 SparkMD5獲取不同圖片的md5顯示相同,解決辦法
- 2022-04-17 iOS喚起記住密碼的數(shù)字鍵盤,輸入的時候發(fā)生閃爍的問題
- 2022-08-17 Android?Flutter表格組件Table的使用詳解_Android
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結構-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支