我不知道是不是叫图,无论如何,所以叫它。 图形是今天我这个jQuery 插件上看到的. 认为非常好看。
就想把它实现出来,由于之前画过环形图。且我如今的图表基类基本已成型,所以非常快就画好了。
效果在展示页那有,这里也附上:
图1 图2 图3
附上上面三个图,在我图表库中的调用 代码:
图1:
//生成圆图类 chart = new CircleChart(); //设置图表范围(通过起始X,Y坐标及长。宽指定) chart.setChartRange(0, 0, mScrWidth, mScrHeight); //设置图表数据源 LinkedList图2:lPieData = new LinkedList (); //PieData(标签,百分比,在饼图中相应的颜色) lPieData.add(new PieData("58%",58,(int)Color.rgb(72, 201, 176))); chart.setDataSource(lPieData); //设置标题 chart.setTitle("圆形图(Circle Chart) 01"); //设置外环半径 if(mScrWidth < this.mScrHeight) { chart.setRadius(mScrWidth/3); }else{ chart.setRadius(mScrHeight/3); } //设置半径 int fillRaius = (int) Math.round(mScrWidth * 0.7 - mScrWidth/5); chart.setFillRadius(fillRaius); //设置附加信息 chart.setAttributeInfo("电脑充满活力"); //半圆显示 chart.setCircleDisplayType(XTypes.CircleDisplayType.HALF );
//生成圆图类 chart = new CircleChart(); //设置图表范围(通过起始X,Y坐标及长,宽指定) chart.setChartRange(0, 0, mScrWidth, mScrHeight); //设置图表数据源 LinkedList图3:lPieData = new LinkedList (); //PieData(标签,百分比,在饼图中相应的颜色) lPieData.add(new PieData("80%",80,(int)Color.rgb(243, 75, 125))); chart.setDataSource(lPieData); //设置标题 chart.setTitle("圆形图(Circle Chart) 2"); //设置外环半径 if(mScrWidth < this.mScrHeight) { chart.setRadius(mScrWidth/3); }else{ chart.setRadius(mScrHeight/3); } //设置半径 int fillRaius = (int) Math.round(mScrWidth * 0.7 - mScrWidth/5); chart.setFillRadius(fillRaius); chart.setAttributeInfo("压力山大"); chart.setCircleDisplayType(XTypes.CircleDisplayType.FULL ); chart.getPaintBgCircle().setColor((int)Color.rgb(117, 197, 141)); chart.getPaintFillCircle().setColor((int)Color.rgb(77, 180, 123)); chart.getPaintDataInfo().setColor((int)Color.rgb(243, 75, 125)); chart.getPaintLable().setTextSize(36); chart.getPaintDataInfo().setTextSize(22);
//生成圆图类 chart = new CircleChart(); //设置图表范围(通过起始X,Y坐标及长,宽指定) chart.setChartRange(0, 0, mScrWidth, mScrHeight); //设置图表数据源 LinkedList我把相关的几个画笔都开放出来的,基本上能够任意定制,而不用管图表详细实现的逻辑。lPieData = new LinkedList (); //PieData(标签。百分比。在饼图中相应的颜色) lPieData.add(new PieData("75分",75,(int)Color.rgb(51, 136, 103))); chart.setDataSource(lPieData); //设置标题 chart.setTitle("圆形图(Circle Chart) 3"); //设置外环半径 if(mScrWidth < this.mScrHeight) { chart.setRadius(mScrWidth/3); }else{ chart.setRadius(mScrHeight/3); } //设置半径 int fillRaius = (int) Math.round(mScrWidth * 0.7 - mScrWidth/5); chart.setFillRadius(fillRaius); chart.setCircleDisplayType(XTypes.CircleDisplayType.FULL ); chart.getPaintBgCircle().setColor((int)Color.rgb(117, 197, 141)); chart.getPaintFillCircle().setColor((int)Color.rgb(77, 180, 123)); chart.getPaintLable().setTextSize(36); chart.setInitialAngle(90);
MAIL: xcl_168@aliyun.com
BLOG: http://blog.csdn.net/xcl168
版权声明:本文博客原创文章,博客,未经同意,不得转载。