使用Python實(shí)現(xiàn)計(jì)算DICOM圖像兩點(diǎn)真實(shí)距離
對(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)文章
python如何獲取tensor()數(shù)據(jù)類型中的值
這篇文章主要介紹了python如何獲取tensor()數(shù)據(jù)類型中的值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07關(guān)于pip install uwsgi安裝失敗問題的解決方案
這篇文章主要介紹了關(guān)于pip install uwsgi安裝失敗問題的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06python 如何利用chinese_calendar 獲取上一個(gè)工作日日期
這篇文章主要介紹了python 利用chinese_calendar 獲取上一個(gè)工作日日期,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03Python中字符串String的基本內(nèi)置函數(shù)與過濾字符模塊函數(shù)的基本用法
這篇文章主要介紹了Python中字符串String的基本內(nèi)置函數(shù)與過濾字符模塊函數(shù)的基本用法 ,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05Python實(shí)現(xiàn)Harbor私有鏡像倉庫垃圾自動(dòng)化清理詳情
這篇文章主要介紹了Python實(shí)現(xiàn)Harbor私有鏡像倉庫垃圾自動(dòng)化清理詳情,文章圍繞主題分享相關(guān)詳細(xì)代碼,需要的小伙伴可以參考一下2022-05-05python實(shí)現(xiàn)opencv+scoket網(wǎng)絡(luò)實(shí)時(shí)圖傳
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)opencv+scoket網(wǎng)絡(luò)實(shí)時(shí)圖傳,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03Python zip函數(shù)打包元素實(shí)例解析
這篇文章主要介紹了Python zip函數(shù)打包元素實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12從零學(xué)Python之入門(二)基本數(shù)據(jù)類型
這是繼“hello world”之后的第二篇入門級(jí)基礎(chǔ)知識(shí),以后這個(gè)系列會(huì)按照入門、進(jìn)階、精通三個(gè)分類進(jìn)行下去,歡迎高手們來拍磚2014-05-05