知识点

C++ 中的像素遍历与访问

  • 数组遍历
  • 指针遍历

    Python 中的像素遍历与访问

  • 数组遍历

    C++代码

    ```cpp

    include

    include

using namespace std; using namespace cv;

void day04() {

  1. Mat src = imread("E:\\_Image\\OpenCVTest\\girl.jpg");
  2. if (src.empty()) {
  3. cout << "could not load image.." << endl;
  4. return;
  5. }
  6. // 直接读取图像像素
  7. int height = src.rows;
  8. int width = src.cols;
  9. int ch = src.channels();
  10. for (int row = 0; row < height; row++) {
  11. // 像素取反
  12. for (int col = 0; col < width; col++) {
  13. if (ch == 3) {
  14. Vec3b bgr = src.at<Vec3b>(row, col);
  15. bgr[0] = 255 - bgr[0];
  16. bgr[1] = 255 - bgr[1];
  17. bgr[2] = 255 - bgr[2];
  18. src.at<Vec3b>(row, col) = bgr;
  19. }
  20. else if (ch == 1) {
  21. int gray = src.at<uchar>(row, col);
  22. src.at<uchar>(row, col) = 255 - gray;
  23. }
  24. }
  25. }
  26. imshow("output", src);
  27. // 指针读取
  28. Mat result = Mat::zeros(src.size(), src.type());
  29. int blue = 0, green = 0, red = 0;
  30. int gray;
  31. for (int row = 0; row < height; row++) {
  32. uchar* curr_row = src.ptr<uchar>(row);
  33. uchar* result_row = result.ptr<uchar>(row);
  34. for (int col = 0; col < width; col++) {
  35. if (ch == 3) {
  36. blue = *curr_row++;
  37. green = *curr_row++;
  38. red = *curr_row++;
  39. *result_row++ = blue;
  40. *result_row++ = green;
  41. *result_row++ = red;
  42. }
  43. else if (ch == 1) {
  44. gray = *curr_row++;
  45. *result_row++ = gray;
  46. }
  47. }
  48. }
  49. imshow("result", result);
  50. waitKey(0);

}

  1. <a name="KZEax"></a>
  2. ## Python代码
  3. ```python
  4. import cv2 as cv
  5. import numpy as np
  6. # 查看版本
  7. print(cv.__version__)
  8. # 读取图像
  9. src = cv.imread("E:/_Image/OpenCVTest/girl.jpg")
  10. # 查看属性
  11. h, w, ch = src.shape
  12. print("h, w, ch", h, w, ch)
  13. # 像素取反
  14. for row in range(h):
  15. for col in range(w):
  16. b, g, r = src[row, col]
  17. b = 255 - b
  18. g = 255 - g
  19. r = 255 - r
  20. src[row, col] = [b, g, r]
  21. cv.imshow("output", src)
  22. # 等待键盘输入
  23. cv.waitKey()
  24. # 释放内存
  25. cv.destroyAllWindows()

Javascript代码

<template>
  <div>
    <p>图像像素读写</p>
    <p id="status">OpenCV.js is loading...</p>
    <div class="inputoutput">
      <img id="imageSrc" alt="No Image" />
      <div class="caption">imageSrc <input type="file" id="fileInput" name="file" /></div>
    </div>
    <div class="inputoutput">
      <canvas id="canvasOutput"></canvas>
      <div class="caption">canvasOutput</div>
    </div>
  </div>
</template>

<script>
export default {
  name: "day04",
  mounted() {
    this.init();
  },
  methods: {
    init() {
      setTimeout(() => {
        if (window.cv) {
          this.onOpenCvReady(window.cv);
        } else {
          this.init();
        }
      }, 500);
    },
    onOpenCvReady(cv) {
      document.getElementById("status").innerHTML = "OpenCV.js is ready.";
      let imgElement = document.getElementById("imageSrc");
      let inputElement = document.getElementById("fileInput");
      inputElement.addEventListener(
        "change",
        e => {
          imgElement.src = URL.createObjectURL(e.target.files[0]);
        },
        false
      );
      imgElement.onload = function() {
        let src = cv.imread(imgElement);

        // 1. data 取值,获取适用于连续Mat,需用 isContinous()检测是否连续
        // 取(3,4)这个位置的像素
        let row = 3;
        let col = 4;
        let R, G, B, A;
        if (src.isContinuous()) {
          R = src.data[row * src.cols * src.channels() + col * src.channels()];
          G =
            src.data[
              row * src.cols * src.channels() + col * src.channels() + 1
            ];
          B =
            src.data[
              row * src.cols * src.channels() + col * src.channels() + 2
            ];
          A =
            src.data[
              row * src.cols * src.channels() + col * src.channels() + 3
            ];
          console.log(R, G, B, A);
        }

        // 2. at 限制:不能修改
        R = src.ucharAt(row, col * src.channels());
        G = src.ucharAt(row, col * src.channels() + 1);
        B = src.ucharAt(row, col * src.channels() + 2);
        A = src.ucharAt(row, col * src.channels() + 3);
        console.log(R, G, B, A);

        // 3. ptr 一般使用这个,简单方便
        let pixel = src.ucharPtr(row, col);
        R = pixel[0];
        G = pixel[1];
        B = pixel[2];
        A = pixel[3];
        console.log(R, G, B, A);
        // 修改
        pixel[0] = 0;
        pixel[1] = 0;
        pixel[2] = 0;
        pixel[3] = 255;
        console.log(src.ucharPtr(row, col));
        cv.imshow("canvasOutput", src);

        src.delete();
      };
    }
  }
};
</script>

<style lang="scss" scoped>
</style>