欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Python實(shí)現(xiàn)計(jì)算DICOM圖像兩點(diǎn)真實(shí)距離

 更新時(shí)間:2023年11月24日 08:43:25   作者:Alex-Leung  
這篇文章主要為大家詳細(xì)介紹了如何使用Python實(shí)現(xiàn)計(jì)算DICOM圖像兩點(diǎn)真實(shí)距離,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下

對(duì)比測(cè)量結(jié)果圖

DICOM閱讀器(小賽看看)測(cè)量結(jié)果

python測(cè)量結(jié)果

代碼

import numpy as np
import cv2
import math
import pydicom
from pydicom.pixel_data_handlers.util import convert_color_space

ds = pydicom.dcmread("./your_dicom_path.dcm")
# 第幾張圖, dtype根據(jù)Bits Allocated定義
img = np.asarray(ds.pixel_array[0], dtype='uint8')
# 獲取色彩空間
color_space = ds.get(0x00280004).value
# 顏色空間轉(zhuǎn)換
img = convert_color_space(img, color_space, 'RGB')
# BGR轉(zhuǎn)RGB
img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

# 像素和真實(shí)空間比例尺
autio_x = ds.get(0x00280030).value[0]
autio_y = ds.get(0x00280030).value[1]

p1 = None
p2 = None

# 歐股定理
def cal_euler(p1, p2):
    a2 = ((p2[1] - p1[1]) * autio_x) ** 2
    b2 = ((p2[0] - p1[0]) * autio_y) ** 2
    res = math.sqrt(a2 + b2)
    return res

# 鼠標(biāo)事件
def mouseHandler(event, x, y, flags, param):
    global p1, p2
    if event == cv2.EVENT_LBUTTONDOWN:
        point = (x, y)
        if p1 == None:
            p1 = point
        else:
            p2 = point
        print(point)
        cv2.destroyAllWindows()

cv2.namedWindow('p1')
cv2.setMouseCallback('p1', mouseHandler)
cv2.imshow('p1', img)
cv2.waitKey()

cv2.namedWindow('p2')
cv2.setMouseCallback('p2', mouseHandler)
cv2.imshow('p2', img)
cv2.waitKey()

res = cal_euler(p1, p2)

img = cv2.line(img, p1, p2, (0, 0, 255), 1, 1)
cv2.putText(img, str(round(res, 2)) + "mm", p2, cv2.FONT_HERSHEY_SIMPLEX, 0.7, (0, 0, 255), 1, cv2.LINE_AA)
cv2.imshow('res', img)
cv2.waitKey()

到此這篇關(guān)于使用Python實(shí)現(xiàn)計(jì)算DICOM圖像兩點(diǎn)真實(shí)距離的文章就介紹到這了,更多相關(guān)Python計(jì)算圖像兩點(diǎn)距離內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論