想請問一下,為什麼以下程式碼會錯誤:
import cv2
img_rgb = cv2.imread("image.jpg")[:,:,::-1]
cv2.circle(img_rgb, (616,44),4,[255, 0, 0], thickness=-1)
TypeError: Layout of the output array img is incompatible with cv::Mat
(step[ndims-1] != elemsize or step[1] != elemsize*nchannels)
但是!我只要加入.copy()就對了 即 ....[:,:,::-1].copy()
來龍去脈如下
==========================================================
首先舉個例子釐清一件事情:
a = [1,2]
b = a[::-1]
則 b 就是 [2,1],而且記憶體位置不同! id(a) != id(b)
邏輯就是把 b 指向某個不同於a的記憶體位置,值為a = [1,2][::-1]
因此跟 b = a[::-1].copy() 應該是一樣的
再來,回到原始問題
img_rgb = cv2.imread("image.jpg")[:,:,::-1]
^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
將這變數 值為cv2.imread("image.jpg")[:,:,::-1]
指向 只是cv2.imread載入進來是bgr順序,所以用[:,:,::-1]變成rgb順序而已
cv2.circle(img_rgb, (616,44),4,[255, 0, 0], thickness=-1)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
在img_rgb上某個位置加入某個大小的圓點
但就是錯的!
不過在[:,:,::-1]後面加個.copy()就對了