亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

Android中使用Canvas繪制南丁格爾玫瑰圖(Nightingale rose diagram)

2020-04-11 11:38:32
字體:
來源:轉載
供稿:網友

南丁格爾玫瑰圖 在常規圖表中實在很驚艷,但我初看沒看懂,一查原來南丁格爾這么偉大,確實值得尊敬。

再仔細研究了下這種圖的構成,發現原來就是把柱形圖的柱形換成了扇形圖的半徑來表示,當然,變種有好多,我這只是說我理解的這種。

知道了其構成方式后就好實現了,依傳入參數個數決定其扇形角度,依百分比決定其扇形的半徑長度,然后就一切都水到渠成了。

漂亮的美圖獻上:

附上實現代碼:

package com.xcl.chart;/** * Canvas練習  * 	 自已畫南丁格爾玫瑰圖(Nightingale rose diagram) *    * author:xiongchuanliang * date:2014-4-12 */import android.content.Context;import android.graphics.Canvas;import android.graphics.Color;import android.graphics.Paint;import android.graphics.Paint.Style;import android.graphics.RectF;import android.util.DisplayMetrics;import android.view.View;public class PanelRoseChart extends View{		private int ScrWidth,ScrHeight;			 //演示用的百分比例,實際使用中,即為外部傳入的比例參數 	private final float arrPer[] = new float[]{40f,50f,60f,35f,70f,80f,90f}; 	//演示用標簽	private final String arrPerLabel[] = new String[]{"PostgreSQL","Sybase","DB2","國產及其它","MySQL","Ms Sql","Oracle"}; 	//RGB顏色數組	private final int arrColorRgb[][] = { {77, 83, 97}, 							       {148, 159, 181}, 							       {253, 180, 90},							       {52, 194, 188},							       {39, 51, 72},							       {255, 135, 195},							       {215, 124, 124}} ;		public PanelRoseChart(Context context) {		super(context);		// TODO Auto-generated constructor stub				//屏幕信息		DisplayMetrics dm = getResources().getDisplayMetrics();		ScrHeight = dm.heightPixels;		ScrWidth = dm.widthPixels;	}		public void onDraw(Canvas canvas){		//畫布背景		canvas.drawColor(Color.BLACK);		              float cirX = ScrWidth / 2;     float cirY = ScrHeight / 3 ;     float radius = ScrHeight / 5 ;//150;                      float arcLeft = cirX - radius;     float arcTop = cirY - radius ;     float arcRight = cirX + radius ;     float arcBottom = cirY + radius ;     RectF arcRF0 = new RectF(arcLeft ,arcTop,arcRight,arcBottom);          //畫筆初始化		Paint PaintArc = new Paint(); 				Paint PaintLabel = new Paint(); 		PaintLabel.setColor(Color.WHITE);		PaintLabel.setTextSize(16);     				PaintLabel.setAntiAlias(true);		PaintArc.setAntiAlias(true);    //位置計算類     XChartCalc xcalc = new XChartCalc();			    float Percentage = 0.0f; 		float CurrPer = 0.0f; 		float NewRaidus = 0.0f;		int i= 0; 				 //將百分比轉換為扇形半徑長度		Percentage = 360 / arrPer.length;		Percentage = (float)(Math.round(Percentage *100))/100; 		    for(i=0; i<arrPer.length; i++)      {       //將百分比轉換為新扇區的半徑       NewRaidus = radius * (arrPer[i]/ 100);       NewRaidus = (float)(Math.round(NewRaidus *100))/100;             float NewarcLeft = cirX - NewRaidus;       float NewarcTop = cirY - NewRaidus ;       float NewarcRight = cirX + NewRaidus ;       float NewarcBottom = cirY + NewRaidus ;       RectF NewarcRF = new RectF(NewarcLeft ,NewarcTop,NewarcRight,NewarcBottom);                    //分配顏色            PaintArc.setARGB(255,arrColorRgb[i][0], arrColorRgb[i][1], arrColorRgb[i][2]);              //在餅圖中顯示所占比例       canvas.drawArc(NewarcRF, CurrPer, Percentage, true, PaintArc);               //計算百分比標簽      xcalc.CalcArcEndPointXY(cirX, cirY, radius - radius/2/2, CurrPer + Percentage/2); 				//標識		  canvas.drawText(arrPerLabel[i],xcalc.getPosX(), xcalc.getPosY() ,PaintLabel);		        //下次的起始角度       CurrPer += Percentage;     }     //外環    PaintLabel.setStyle(Style.STROKE);    PaintLabel.setColor(Color.GREEN);    canvas.drawCircle(cirX,cirY,radius,PaintLabel);     canvas.drawText("author:xiongchuanliang", 10, ScrHeight - 200, PaintLabel);    			}}

代碼實現起來很容易,但這種圖的設計創意確實非常好。 嘆服。

一定要附上南丁格爾維基百科的鏈接:      http://zh.wikipedia.org/wiki/%E5%BC%97%E7%BE%85%E5%80%AB%E6%96%AF%C2%B7%E5%8D%97%E4%B8%81%E6%A0%BC%E7%88%BE

感興趣的可以看看。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
大量国产精品视频| 精品国产美女在线| 精品国产91久久久| 91av福利视频| 久久精视频免费在线久久完整在线看| 国产精品高潮视频| 日本不卡免费高清视频| 久久综合网hezyo| 欧美精品免费在线观看| 日韩精品中文在线观看| 欧美性在线视频| 欧美成人三级视频网站| 91精品综合视频| 日本免费一区二区三区视频观看| 亚洲欧美制服丝袜| 日韩经典中文字幕| 日韩欧美aⅴ综合网站发布| 久久精品国产v日韩v亚洲| 琪琪亚洲精品午夜在线| 91色视频在线观看| 91精品综合久久久久久五月天| 精品国产一区久久久| 午夜精品一区二区三区视频免费看| 欧美三级xxx| 亚洲高清免费观看高清完整版| 国产亚洲精品高潮| 国产成人精品亚洲精品| 成人性生交大片免费观看嘿嘿视频| 不卡在线观看电视剧完整版| 亚洲欧美日韩精品久久亚洲区| 久久伊人精品天天| 亚洲国产精彩中文乱码av| 97精品伊人久久久大香线蕉| 久久69精品久久久久久久电影好| 91精品国产色综合久久不卡98| 日韩中文字幕国产| 国产亚洲成av人片在线观看桃| 亚洲国产精久久久久久久| 国产视频亚洲视频| 国产精品aaaa| 91精品在线观| 欧美性生交xxxxxdddd| 中文字幕亚洲在线| 欧美激情精品久久久久久黑人| 国产精品免费一区| 午夜精品久久久久久久99热浪潮| 亚洲国产精品va在线看黑人动漫| 久久久精品久久久| 欧美老肥婆性猛交视频| 热久久99这里有精品| 亚洲精品小视频| 亚洲人成在线一二| 欧美亚洲国产日韩2020| 成人国产精品色哟哟| 国产专区欧美专区| 国产日韩专区在线| 精品亚洲国产成av人片传媒| 亚洲欧美日韩国产中文专区| 欧美激情视频三区| 国内揄拍国内精品少妇国语| 国产999在线观看| 久久精品国产亚洲精品2020| 日韩中文字幕在线视频播放| 日韩av成人在线观看| 国产69久久精品成人看| 久久久久久久久爱| 亚洲精品99久久久久| 亚洲美女又黄又爽在线观看| 97免费视频在线播放| 日韩在线www| 国产99久久精品一区二区永久免费| 日韩av影院在线观看| 伊人亚洲福利一区二区三区| 7m第一福利500精品视频| 日本亚洲欧美成人| 91豆花精品一区| 国产精品劲爆视频| 国产精品视频久| 一区二区在线视频播放| 国产日韩欧美另类| 在线电影欧美日韩一区二区私密| 欧美日韩性视频在线| 91成品人片a无限观看| 国产精品亚洲美女av网站| 欧美激情视频网站| 日韩av在线不卡| 日韩av电影免费观看高清| 欧美激情在线观看视频| 欧美xxxx综合视频| 亚洲国产精品yw在线观看| 国产精品欧美日韩一区二区| 欧美在线播放视频| 国产精品黄页免费高清在线观看| 欧美黄色成人网| 91色精品视频在线| 精品久久久久久久久中文字幕| 国产精品久久久久久久久久久久久| 欧美在线一区二区三区四| 久久久中精品2020中文| 青青青国产精品一区二区| 日韩成人性视频| 成人国产精品免费视频| 欧美另类交人妖| 91福利视频在线观看| 热久久这里只有| 欧美性xxxxhd| 欧美野外wwwxxx| 久久久在线视频| 中文字幕精品av| 久久91亚洲精品中文字幕| 欧美激情a∨在线视频播放| 韩剧1988在线观看免费完整版| 欧美日韩一区二区免费在线观看| 国产精品国产亚洲伊人久久| 亚洲free性xxxx护士白浆| 日韩电影第一页| 久久久999国产精品| 欧美成人精品在线视频| 久久琪琪电影院| 久久久欧美一区二区| 久热精品视频在线观看一区| 自拍偷拍亚洲在线| 国产精品入口日韩视频大尺度| 久久久亚洲网站| 国产人妖伪娘一区91| 国产精品久久久久999| 成人亚洲欧美一区二区三区| 午夜精品一区二区三区av| 欧美高清自拍一区| 性视频1819p久久| www.亚洲免费视频| 伊人伊成久久人综合网小说| 成人午夜激情免费视频| 黑人狂躁日本妞一区二区三区| 亚洲人免费视频| 欧美日韩人人澡狠狠躁视频| 成人免费直播live| 精品国偷自产在线视频| 久久精品美女视频网站| 美日韩精品视频免费看| 性色av一区二区三区红粉影视| 亚洲成人久久电影| 91精品久久久久久久久久另类| 色伦专区97中文字幕| 亚洲毛茸茸少妇高潮呻吟| 国产精品96久久久久久| 欧美国产日本在线| 欧美色xxxx| 亚洲欧美另类在线观看| 久久99国产精品自在自在app| 成人写真视频福利网| 亚洲香蕉伊综合在人在线视看| 国产伊人精品在线| 日韩精品久久久久久久玫瑰园| 欧美性高跟鞋xxxxhd| 亚洲国产日韩欧美在线图片| 亚洲视频网站在线观看| 亚洲国产又黄又爽女人高潮的| 国产精品尤物福利片在线观看| 美女视频久久黄| 国产精自产拍久久久久久蜜| 国产精品v片在线观看不卡| 免费成人高清视频| 国产+成+人+亚洲欧洲|