.NET示波器控件的實(shí)例代碼分析
緣起
同事負(fù)責(zé)的項(xiàng)目中,會掃描硬件中的某個(gè)東西是否存在,因此老板希望對這些掃描結(jié)果,能有個(gè)圖像畫的介面可以查看
因此做了個(gè)小工具,可讀取同事提供的數(shù)據(jù),并將其視覺化顯示
那顯示掃描結(jié)果最容易的就是示波器了,但第三方控件的示波器功能又太繁瑣,最終就決定自己做個(gè)簡單的
反正對我來說用GDI來繪制,跟花時(shí)間去研究沒用過的第三方控件,時(shí)間也不會差太多
思路
如圖所示,示波器其實(shí)就是這樣簡單的圖
整體思路其實(shí)很單純,就把一個(gè)示波器分成三個(gè)部分來繪制.
首先是上面那塊橫線,通常表示高值
第二塊是下面那塊橫線,表示低直
第三部分就是連結(jié)垂直的線
高度的運(yùn)算,我是用最簡單的方式,將一個(gè)UC的高度直接除2,當(dāng)做中心y座標(biāo)
表示高點(diǎn)的則是中心y座標(biāo)往上,高度/5的位置
表示低點(diǎn)的則是中心y座標(biāo)往下,高度/5的位置
示波器的部份,則是先把頭尾的線去掉,然后再將數(shù)據(jù)拆分成兩個(gè)部分
一個(gè)部分是高點(diǎn)要繪制的座標(biāo),另一部分是低點(diǎn)要繪制的座標(biāo)
有了這兩個(gè)座標(biāo),就同時(shí)可以繪制垂直的線了
比例上則是使用示波器的值,以及這個(gè)控件的寬度做比例上的調(diào)整
代碼
int max = m_mappingDatas[m_mappingDatas.Count - 1];
m_Ratio = (max + m_mappingDatas[0]*2) / m_width;
// Draw Wafer data
for (int i = 1, j = 0; i < m_mappingDatas.Count; i+=2 ,j++)
{
float xStart = m_mappingDatas[i - 1];
float xEnd = m_mappingDatas[i];
graphics.DrawLine(pen, xStart / m_Ratio, m_yPositionOfWafer,
xEnd / m_Ratio, m_yPositionOfWafer);
graphics.DrawString((j+1).ToString(), Control.DefaultFont, brush,
(xStart / m_Ratio) - 2, m_yPositionOfNoWafer + 1);
}
// Draw No Wafer data
graphics.DrawLine(pen, 0, m_yPositionOfNoWafer,
m_mappingDatas[0] / m_Ratio, m_yPositionOfNoWafer);
for (int i = 2; i < m_mappingDatas.Count; i += 2)
{
float xStart = m_mappingDatas[i - 1];
float xEnd = m_mappingDatas[i];
graphics.DrawLine(pen, xStart / m_Ratio, m_yPositionOfNoWafer,
xEnd / m_Ratio, m_yPositionOfNoWafer);
}
graphics.DrawLine(pen, m_mappingDatas[m_mappingDatas.Count - 1] / m_Ratio, m_yPositionOfNoWafer,
m_width, m_yPositionOfNoWafer);
// Draw vertical line
for (int i = 1; i < m_mappingDatas.Count; i += 2)
{
float X1 = m_mappingDatas[i - 1];
float X2 = m_mappingDatas[i];
graphics.DrawLine(pen, X1 / m_Ratio, m_yPositionOfWafer,
X1 / m_Ratio, m_yPositionOfNoWafer);
graphics.DrawLine(pen, X2 / m_Ratio, m_yPositionOfWafer,
X2 / m_Ratio, m_yPositionOfNoWafer);
}
在我的代碼中,是要掃描半導(dǎo)體晶圓,所以高點(diǎn)是表示有晶圓,低點(diǎn)則是表示沒有晶圓
項(xiàng)目下載
相關(guān)文章
Asp.Net MVC 分頁、檢索、排序整體實(shí)現(xiàn)代碼
很多時(shí)候需要這樣的功能,對表格進(jìn)行分頁、排序和檢索。本篇文章主要介紹了Asp.Net MVC 分頁、檢索、排序整體實(shí)現(xiàn),有興趣的可以了解一下。2017-01-01asp.net 參數(shù)不同共用一個(gè)頁面的實(shí)現(xiàn)方法
本文為大家介紹下asp.net參數(shù)不同如何共用一個(gè)頁面,感興趣的朋友不要錯(cuò)過2013-12-12ASP.NET Gridview與checkbox全選、全不選實(shí)現(xiàn)代碼
ASP.NET Gridview checkbox全選與全不選實(shí)現(xiàn)代碼,其實(shí)原理就是利用js來實(shí)現(xiàn)的,但需要簡單的設(shè)置下回傳。2010-04-04asp.net中一個(gè)linq分頁實(shí)現(xiàn)代碼
asp.net中一個(gè)linq分頁實(shí)現(xiàn)代碼,需要的朋友可以參考下。2011-12-12用戶控件(ASCX)向網(wǎng)頁(ASPX)傳值使用反射實(shí)現(xiàn)
用戶控件向網(wǎng)頁傳遞值,網(wǎng)上的方法有很多,本文嘗試一下使用反射來實(shí)現(xiàn),感興趣的朋友可以參考下哈,希望可以幫助到你2013-03-03asp.net(C#)使用QRCode生成圖片中心加Logo或圖像的二維碼實(shí)例
這篇文章主要介紹了asp.net(C#)使用QRCode生成圖片中心加Logo或圖像的二維碼,結(jié)合實(shí)例形式詳細(xì)分析了asp.net基于QRCode生成二維碼的具體實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-06-06