當(dāng)前位置:首頁 > 醫(yī)療電子 > 醫(yī)療電子
[導(dǎo)讀]電子病歷(Electronic Medical Record,EMR)系統(tǒng)是一個(gè)數(shù)字技術(shù)、計(jì)算機(jī)技術(shù)、通訊技術(shù)、軟件工程、圖形圖像綜合技術(shù)等多學(xué)科的高新科技項(xiàng)目。其完整資料、數(shù)據(jù)處理、網(wǎng)絡(luò)傳輸、診療支援、統(tǒng)計(jì)分析等均是紙質(zhì)病歷無法

電子病歷(Electronic Medical Record,EMR)系統(tǒng)是一個(gè)數(shù)字技術(shù)、計(jì)算機(jī)技術(shù)、通訊技術(shù)、軟件工程、圖形圖像綜合技術(shù)等多學(xué)科的高新科技項(xiàng)目。

其完整資料、數(shù)據(jù)處理、網(wǎng)絡(luò)傳輸、診療支援、統(tǒng)計(jì)分析等均是紙質(zhì)病歷無法比擬的。

體溫是電子病歷系統(tǒng)中一個(gè)重要的數(shù)據(jù),比如某病人體溫升高可以讓臨床醫(yī)生知道該病人有發(fā)熱的癥狀。在電子病歷系統(tǒng)中,體溫單所針對(duì)的用戶是醫(yī)院的護(hù)士。護(hù)士每天記錄病人的體溫等各項(xiàng)信息,錄入到數(shù)據(jù)庫中,系統(tǒng)自動(dòng)生成電子體溫單,并繪制成曲線圖。體溫曲線圖直觀地顯示了病人的體溫等相關(guān)數(shù)據(jù),這些數(shù)據(jù)與有關(guān)疾病和治療的知識(shí)相結(jié)合,可作為進(jìn)一步診斷及確定治療方案的基礎(chǔ)。

筆者參與開發(fā)的電子病歷系統(tǒng)根據(jù)某大型醫(yī)院的實(shí)際需求,在.NET平臺(tái)下全程采用C#語言開發(fā)實(shí)現(xiàn)。本文著重介紹電子病歷系統(tǒng)中體溫曲線圖的設(shè)計(jì)和實(shí)現(xiàn)。

1 電子病歷系統(tǒng)主要功能

本系統(tǒng)根據(jù)醫(yī)院的實(shí)際需求,最主要的目的是采集病人的數(shù)據(jù),使之能為臨床醫(yī)生提供所需要的診斷和決策信息,更進(jìn)一步的目的是這些信息能夠用于臨床科研。系統(tǒng)主要功能如圖1所示。

2 體溫曲線圖的設(shè)計(jì)與實(shí)現(xiàn)

2.1 體溫表的生成

在電子病歷系統(tǒng)中,每個(gè)來院就診的病患在醫(yī)院就診期間會(huì)產(chǎn)生一個(gè)病歷號(hào),這是標(biāo)志病人的確定碼,通常在數(shù)據(jù)庫系統(tǒng)中也作為惟一的對(duì)應(yīng)碼和關(guān)鍵字。病人人院后,護(hù)士對(duì)病人進(jìn)行體溫、脈搏、呼吸等各個(gè)方面的檢測(cè),將這些數(shù)據(jù)錄入到電子病歷系統(tǒng)中,系統(tǒng)則自動(dòng)生成體溫單。

在病人的體溫單中,需要記錄并分析病人的體溫變換情況。體溫單信息的“體溫”、“脈搏”、“呼吸”這三項(xiàng)信息是要每隔4個(gè)小時(shí)記錄1次,分別在4時(shí)、8時(shí)、12時(shí)、16時(shí)、20時(shí)、24時(shí)這幾個(gè)時(shí)間段。而“大便次數(shù)”、“小便次數(shù)或量”、“攝人量”、“排出量”、“血壓”、“體重”等信息是1天記錄1次。根據(jù)體溫單信息,以1天為1個(gè)單位,畫出1天內(nèi)病人在各個(gè)時(shí)間段的“體溫”、“脈搏”、“呼吸”的曲線變化情況,以及記錄的“大便次數(shù)”、“小便次數(shù)或量”、“攝入量”、“排出量”、“血壓”、“體重”等信息。整個(gè)體溫圖1次只顯示7天的情況。在體溫圖中用坐標(biāo)以及曲線描述病人體溫的連續(xù)變化情況,直觀地滿足了護(hù)士對(duì)患者的體溫、呼吸、脈搏等信息的錄入和查詢的需要。圖2是體溫單顯示界面。

 2.2 體溫圖的繪制

體溫圖是根據(jù)體溫單的數(shù)據(jù)自動(dòng)生成的。由于體溫圖每次只顯示病人7天的體溫變化情況,所以設(shè)計(jì)了翻頁的功能,對(duì)住院時(shí)間久的病人通過翻頁每次跳過7天,保證病人的體溫信息完整的顯示。

2.2.1 C#的GDI+繪圖

體溫圖的繪制由.NET基類集組成的GDI+實(shí)現(xiàn),這些基類可用于在屏幕上完成定制繪圖,能把合適的指令發(fā)送到圖形設(shè)備的驅(qū)動(dòng)程序上,確保在顯示器屏幕上顯示正確的輸出。

在GDI中,識(shí)別輸出設(shè)備的方式是使用對(duì)象設(shè)備環(huán)境(DC)。該對(duì)象存儲(chǔ)特定設(shè)備的信息,并能把GDI API函數(shù)調(diào)用轉(zhuǎn)換為要發(fā)送給該設(shè)備的指令。實(shí)現(xiàn)畫圖的功能要使用到GDI+畫圖技術(shù)。通過重寫Form類中的OnPaint(PaintEventArgs e)執(zhí)行畫圖操作。

在OnPaint()中,首先從PaintEventArgs中引用Graphics對(duì)象,繪制圖形。最后調(diào)用基類的OnPaint()方法。

在應(yīng)用程序第一次啟動(dòng),窗口第一次顯示出來時(shí),也調(diào)用了OnPaint(),所以不需要在構(gòu)造函數(shù)中復(fù)制繪圖代碼。

由于整個(gè)體溫圖比較大,而顯示窗口定為800×600,為了能完整顯示體溫圖文檔,需要在文檔超出窗口時(shí),通知窗口在右側(cè)出現(xiàn)滾動(dòng)條。為此,把整個(gè)文檔區(qū)域定為(800,1 886)像素,并在窗體設(shè)計(jì)器的屬性中把AutoScroll屬性設(shè)置為True。這樣,在體溫圖超過窗口時(shí)自動(dòng)出現(xiàn)滾動(dòng)條。

 2.2.2 絕對(duì)坐標(biāo)到相對(duì)坐標(biāo)的變換

在一般的繪圖代碼中,由于所繪制的圖形區(qū)域一般不超過窗口的大小,所以不需要特別的注意。Graphics實(shí)例在默認(rèn)情況下把坐標(biāo)解釋為是相對(duì)于窗口的,它并不知道滾動(dòng)條的情況。當(dāng)用戶滑動(dòng)滾動(dòng)條時(shí),Windows沒有要求應(yīng)用程序重新繪制已經(jīng)顯示在屏幕中的內(nèi)容。Windows只指出屏幕上目前顯示的內(nèi)容可以平滑的移動(dòng),以匹配滾動(dòng)條的位置。對(duì)于多出來的文檔部分,在應(yīng)用程序第一次顯示時(shí),沒有繪制這部分窗口,因?yàn)樵跐L動(dòng)窗口前,這部分在窗口區(qū)域的外部。這表示W(wǎng)indows要求ScrollShapes應(yīng)用程序繪制這個(gè)區(qū)域。它將引發(fā)Paint事件,把這個(gè)區(qū)域作為剪切的矩形,在窗口中和原來的圖形一起顯示出來,這樣會(huì)出現(xiàn)一個(gè)窗口中有多個(gè)圖形重疊,造成圖形的混亂。

解決的方法是把Graphics實(shí)例默認(rèn)的坐標(biāo)表示為相對(duì)坐標(biāo),即坐標(biāo)是相對(duì)于窗口的左上角,而不是文檔開頭的左上角,把絕對(duì)坐標(biāo)轉(zhuǎn)換為相對(duì)坐標(biāo)。這里用圖3說明這一轉(zhuǎn)換。

實(shí)線矩形標(biāo)記了屏幕區(qū)域的邊框和整個(gè)文檔的邊框。虛線矩形標(biāo)記了試圖要繪制的矩形和橢圓。P標(biāo)記要繪制的某個(gè)隨意點(diǎn)。在調(diào)用繪圖方法時(shí),提供Graphics實(shí)例和從A點(diǎn)到P點(diǎn)的矢量,整個(gè)矢量表示為一個(gè)Ponit實(shí)例。而實(shí)際上需要的是從點(diǎn)B到點(diǎn)P的矢量。問題是,這里只知道從A點(diǎn)到P點(diǎn)的矢量,這是P相對(duì)于文檔左上角的坐標(biāo),而要在文檔的P點(diǎn)繪圖。另外還知道從A點(diǎn)到B點(diǎn)的矢量,這是滾動(dòng)的距離,它儲(chǔ)存在Form類的一個(gè)屬性AutoScrollPosition中。要知道從B點(diǎn)到P點(diǎn)的矢量只需要進(jìn)行矢量相減即可。Graphics類的TranslateTransform方法可以進(jìn)行這些矢量的計(jì)算。這里給它傳送水平和垂直坐標(biāo),表示窗口驅(qū)譴、與的左上角相對(duì)于文檔的左上角的矢量(AutoScrollPosition屬性,它是圖中從A到B的矢量),然后Graphics設(shè)備考慮窗口區(qū)域相對(duì)于文檔區(qū)域的位置,處理這些坐標(biāo)。只要在繪圖代碼中加入以下語句:g.TranslateTransform(this.AutoScrollPositiort.X,this.AutoScrollPosition.Y);即可解決坐標(biāo)轉(zhuǎn)換的問題。

2.2.3 體溫圖的繪制技術(shù)

體溫圖的繪制根據(jù)體溫單中病人的相關(guān)信息,利用才C#的GDI+可以繪制出相應(yīng)的體溫曲線圖。在程序中首先進(jìn)行絕對(duì)坐標(biāo)和相對(duì)坐標(biāo)的變換,然后用Pen類定義畫筆,用Brush類定義畫刷顏色,對(duì)于需要填充的地方用畫刷進(jìn)行填充,再調(diào)用Graphics類的DrawLine方法畫出所需的線條。在DrawLine方法中,需要提供畫筆類型,線段起點(diǎn)和終點(diǎn)坐標(biāo)等參數(shù)。

體溫圖初始化之后,根據(jù)從體溫表傳遞的病人編號(hào)作為體溫圖中的全局變量,對(duì)數(shù)據(jù)庫進(jìn)行查詢,并把查詢結(jié)果轉(zhuǎn)換為坐標(biāo),傳遞給畫圖方法DrawLine和FillEllipse,畫出圖形。圖4是一張?bào)w溫圖顯示界面。

2.2.4 體溫圖中翻頁的實(shí)現(xiàn)

由于體溫圖每次只顯示病人1周的體溫變換信息,要顯示1周之前的體溫信息,可以使用翻頁功能。實(shí)現(xiàn)翻頁功能主要利用在讀取數(shù)據(jù)時(shí)使用到的Read()方法的特性。通過Read()方法在讀取數(shù)據(jù)的同時(shí)把當(dāng)前的指針向下移動(dòng)1位。最初它位于數(shù)據(jù)集的第一行之前,因此第一次調(diào)用Read()將把指針置于第一行上,使它成為當(dāng)前行。隨著每次調(diào)用Read()導(dǎo)致指針向下移動(dòng),按照從上至下的次序獲取數(shù)據(jù)集行。代碼如下:

其中變量n為全局變量,由翻頁按鈕對(duì)其進(jìn)行賦值。以當(dāng)前的變量n減1乘7為所需跳過的間隔數(shù),以日期為單位,對(duì)數(shù)據(jù)集中的日期進(jìn)行篩選,選出這一周的日期儲(chǔ)存到數(shù)組array中。

3 結(jié) 語

電子病歷是醫(yī)院信息化發(fā)展的必然趨勢(shì)。根據(jù)HL7的標(biāo)準(zhǔn)化要求,當(dāng)前國內(nèi)電子病歷的研究還很不完善,要制定出比較完善的適應(yīng)國內(nèi)醫(yī)院使用的電子病歷原型系統(tǒng)還需要更深入的研究。本文探討利用C#繪制電子病歷系統(tǒng)體溫圖的技術(shù),試圖對(duì)完善電子病歷系統(tǒng)做有益的嘗試。電子病歷系統(tǒng)相關(guān)的研究內(nèi)容將會(huì)不斷發(fā)展和深入,而電子病歷的技術(shù)構(gòu)架和軟件流程也將會(huì)越來越成熟。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉