原創(chuàng)|其它|編輯:郝浩|2012-10-17 15:33:31.000|閱讀 1434 次
概述:想使用ChartDirector繪制自己的儀表盤,得到了文章里面的源碼
# 界面/圖表報(bào)表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
相關(guān)鏈接:
在ChartDirector的文檔里面有一個(gè)儀表盤的實(shí)例,但是這個(gè)不符合自己的要求,需要做相應(yīng)的修改,為了達(dá)到我想要的效果,我做了一下修改。
下面就是我修改的代碼,后面給出了相應(yīng)的中文注釋,實(shí)現(xiàn)了儀表盤的制作:
public void createChart(ChartViewer viewer,int index){
double value = 30.5;
//創(chuàng)建一個(gè)AngularMeter對象,大小為200*115
//并設(shè)置背影顏色,后面的兩個(gè)參數(shù)是用來設(shè)置邊框顏色和大小的,這里不要邊框,所以去掉
AngularMeter m = new AngularMeter(200,115,0xffffff);
m.setDefaultFonts("simsun.ttc"); //設(shè)置字體,不然中文出現(xiàn)亂碼
m.setRoundedFrame();
//設(shè)置儀表盤中心在(100,100),半徑為85像素,并且跨度在-90到+90
m.setMeter(100, 100, 85, -90, 90);
//儀表盤的界限0到100,每個(gè)刻度以20為單位,較小的刻度以10為單位,最小的以5為刻度。
m.setScale(0, 100,20,10,5);
//設(shè)置0-60為綠色(0X66FF66)區(qū)域,70到85為空白區(qū)域
m.addZone(0, 60,70,85,0x00aa00);
// m.setBackground(0x333333,0x66ff66,4);//第一個(gè)參數(shù)設(shè)置背景顏色,第二個(gè)設(shè)置背景邊緣顏色,第三個(gè)設(shè)置陰影
//設(shè)置60-80為黃色(ffff33)區(qū)域
m.addZone(60, 80,70,85,0xcccc00);
//設(shè)置80-100為紅色區(qū)域(ff6666)
m.addZone(80, 100,70,85,0xaa0000);
m.addZone(0, 100,70,70,0x000000);//在內(nèi)部顏色緣加一條黑色的線
//添加一個(gè)文本標(biāo)簽,使用12號(hào),Arial Bold字體
m.addText(100, 60,"中文","宋體",12,Chart.TextColor, Chart.Center);
//添加一個(gè)文本標(biāo)簽在右上角用來顯示值,字體為Arial,字號(hào)為8,顏色為0xffffff
//格式化為2位小數(shù),并使用黑色背景,1像素的3D陰影
m.addText(156,8, m.formatValue(value, "2"), "Arial",8,0xffffff).setBackground(0x000000, 0, -1);
//添加指針,第一個(gè)參數(shù)是所在指向的位置,第二個(gè)和第三個(gè)是指針邊緣顏色和填充顏色,后面是設(shè)置指針在顏色的下方
//這里還可以設(shè)置指針的形狀,具體可以參考文檔里面的Multi-Pointer Angular Meter實(shí)例
m.addPointer(value, 0xffffff,0x000000).setZOrder(0x100);
//輸出圖形
// String chart1URL = m.makeSession(request, "chart1");
viewer.setImage(m.makeImage());
}
本站文章除注明轉(zhuǎn)載外,均為本站原創(chuàng)或翻譯。歡迎任何形式的轉(zhuǎn)載,但請務(wù)必注明出處、不得修改原文相關(guān)鏈接,如果存在內(nèi)容上的異議請郵件反饋至chenjj@ke049m.cn
文章轉(zhuǎn)載自:qiyeku