OpenCV for iOS 學(xué)習(xí)筆記(十三)—— 重映射(把一個(gè)圖像中一個(gè)位置的像素放置到另一個(gè)圖片指定位置的過程)



  • 處理效果

效果展示
  • 函數(shù)介紹 remap

    void remap( InputArray src,    // 預(yù)處理圖像
                OutputArray dst,   // 處理結(jié)果
                InputArray map1,   // x方向的映射參數(shù)
                InputArray map2,   // y方向的映射參數(shù)
                int interpolation, //  插值方法
                int borderMode = BORDER_CONSTANT, // 默認(rèn)
                const Scalar& borderValue = Scalar()); //
    
  • 更新重映射矩陣(來自

    • 圖像寬高縮小一半,并顯示在中間:(i 代表 x 軸,j 代表 y 軸)



      所有成對的參數(shù) (i, j) 處理后都符合:



    • 圖像上下顛倒:


    • 圖像左右顛倒:


    • 同時(shí)執(zhí)行b和c的操作:


  • 主要代碼(源碼

    全局變量,根據(jù)?remap函數(shù)參數(shù)定義
    Mat src_R, dst_R;
    Mat map_x_R, map_y_R;
    int ind_R = 4;
    準(zhǔn)備
    /// Load the image
    UIImage *image = [UIImage imageNamed:@"mm.jpeg"];
    UIImageToMat(image, src_R);
    /// Create dst, map_x and map_y with the same size as src:
    dst_R.create(src_R.size(), src_R.type());
    map_x_R.create(src_R.size(), CV_32FC1);
    map_y_R.create(src_R.size(), CV_32FC1);
    /// Update map_x & map_y. Then apply remap
    update_map();
    remap(src_R, dst_R, map_x_R, map_y_R, CV_INTER_LINEAR, BORDER_CONSTANT, Scalar(0, 0, 0));
    _imageView.image = MatToUIImage(dst_R);
    實(shí)現(xiàn)
    void update_map() {
    ind_R = ind_R % 4;
    for(int j = 0; j < src_R.rows; j++) {
    for(int i = 0; i < src_R.cols; i++) {
    switch(ind_R) {
    /// Zoom Out
    case 0:
    if(i > src_R.cols * 0.25 && i < src_R.cols * 0.75 && j > src_R.rows * 0.25 && j < src_R.rows * 0.75) {
    map_x_R.at<float>(j, i) = 2 * (i - src_R.cols * 0.25) + 0.5;
    map_y_R.at<float>(j, i) = 2 * (j - src_R.rows * 0.25) + 0.5;
    } else { map_x_R.at<float>(j, i) = 0;
    map_y_R.at<float>(j, i) = 0;
    }
    break;
    /// Up, down
    case 1:
    map_x_R.at<float>(j, i) = i;
    map_y_R.at<float>(j, i) = src_R.rows - j;
    break;
    /// left, right
    case 2:
    map_x_R.at<float>(j, i) = src_R.cols - i;
    map_y_R.at<float>(j, i) = j;
    break;
    /// Up, down, left, right
    case 3: Up, down, left, right
    map_x_R.at<float>(j, i) = src_R.cols - i;
    map_y_R.at<float>(j, i) = src_R.rows - j;
    break;
    }
    }
    }
    }
  • 效果展示

效果展示
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容