曲线图与通常的折线图不同的地方是它的线条位置计算有点特别,所以我独立弄了一个类.同样,只需传入数据源给基类,
再加上,你想加的控制,可自动依设置绘出你想要的效果。
代码:
//图基类 chart = new CurveChart(); //图所占范围大小 chart.setChartRange(0, 0, this.mScrWidth , this.mScrHeight ); //标签轴标签集合 LinkedList<String> lables = new LinkedList<String>(); lables.add("2010"); lables.add("2011"); lables.add("2012"); lables.add("2013"); lables.add("2014"); chart.setLineLables(lables); //线1的数据集 LinkedHashMap<Double,Double> linePoint1 = new LinkedHashMap<Double,Double>(); linePoint1.put(10d, 30d); linePoint1.put(25d, 80d); linePoint1.put(60d, 60d); linePoint1.put(75d, 45d); CurveData curveData1 = new CurveData("青菜萝卜够吃", (int)Color.rgb(54, 141, 238) ,linePoint1); //线2的数据集 LinkedHashMap<Double,Double> linePoint2 = new LinkedHashMap<Double,Double>(); linePoint2.put(40d, 40d); linePoint2.put(55d, 85d); linePoint2.put(70d, 65d); linePoint2.put(85d, 55d); CurveData curveData2 = new CurveData("饭管够", (int)Color.rgb(255, 165, 132) ,linePoint2); //设定数据源 LinkedList<CurveData> chartData = new LinkedList<CurveData>(); chartData.add(curveData1); chartData.add(curveData2); chart.setDataSource(chartData); //柱形图标题 chart.setTitle("曲线图(Curve Chart)"); //柱形图图例 chart.setLegend("XCL-Charts"); //数据轴最大值 chart.setDataAxisMax(100); //数据轴刻度间隔 chart.setDataAxisSteps(10); //标签轴最大值 chart.setLablesAxisMax(100); //设置标签轴颜色 chart.getLablesAxisPaint().setColor((int)Color.rgb(68, 136, 187)); //设置数据轴颜色 chart.getDataAxisPaint().setColor((int)Color.rgb(68, 136, 187)); //显示分隔色 chart.isShowInnerLineInterval(false); //设置分隔色 chart.setInnerLineIntervalColor((int)Color.rgb(239, 239, 239)); //显示横向分隔网线 chart.isShowInnerHorizontalLine(true); //显示竖向分隔网线 chart.isShowInnerVerticalLine(true); //显示横向分隔网线粗细及颜色 chart.setInnerHorizontalLineStyle(1,(int)Color.rgb(218, 218, 218)); //显示竖向分隔网线粗细及颜色 chart.setInnerVerticalLineStyle(1,(int)Color.rgb(218, 218, 218)); //线条粗细 chart.setLineStyle(5); //chart.setPointStyle(XTypes.PointType.Circle); //点上显示圆心 chart.setLineDotRadius(8); //点上显示标签 chart.isShowDotLabel(true); //设置标签轴标签 偏移量,旋转角度 chart.setPaintStyle(XTypes.LineTextPaintType.LABLESAXIS_LABLES,10,-45f);
MAIL: [email protected]
BLOG:http://blog.csdn.net/xcl168
XCL-Charts画曲线图(CurveChart)
时间: 2024-10-11 08:47:28