WilliamChart图表库
MMM
10年前
介绍:
WilliamChart 是一个为安卓项目提供图表控件的开源库,他实现了数字的可视化,用作者的话说“我者喜欢看起来干净简单的图表,不想要那么多花哨的功能”。代码下载点这里:http://jcodecraeer.com/a/opensource/2014/1011/1738.html
运行效果:

使用说明:
创建一个新的chart需要继承自ChartView的坐标轴,同时实现一些必要的方法。我觉的这些方法足以让你绘制出任何你想要的效果。
xml
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 </td> | <com.db.chart.view.ChartView android:layout_width= "match_parent" android:layout_height= "dp" ... chart:chart_shadowDx= "dp" chart:chart_shadowDy= "dp" chart:chart_shadowRadius= "dp" chart:chart_shadowColor= "color" chart:chart_fontSize= "dp" chart:chart_typeface= "typeface" chart:chart_axisBorderSpacing= "dp" chart:chart_axisThickness= "dp" chart:chart_axisTopSpacing= "dp" chart:chart_axisColor= "color" chart:chart_axisX= "boolean" chart:chart_label= "boolean" chart:chart_labelColor= "color" /> | </tr> </tbody> </table> </div> </div>
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 </td> | // Customize labels chart.setLabels(NONE/OUTSIDE/INSIDE) chart.setLabelColor(color) chart.setFontSize(integer) chart.setTypeface(typeface) // Define grid chart.setGrid(paint) chart.setHorizontalGrid(paint) chart.setVerticalGrid(paint) // Show threshold line chart.setThresholdLine(float, paint) chart.setMaxAxisValue(integer, integer) chart.setStep(integer) chart.setTopSpacing(dimen) chart.setBorderSpacing(dimen) chart.setAxisX(boolean) chart.show() // Update values of a given set chart.updateValues(int, array) // Notify chart about updated values chart.notifyDataUpdate() // Tooltip support chart.showTooltip(view) chart.dismissTooltip(view) | </tr> </tbody> </table> </div> </div>
| 1 2 3 </td> | <com.db.chart.LineChartView ... /> | </tr> </tbody> </table> </div> </div>
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 </td> | LineChartView chartView= new LineChartView() LineSet lineSet = new LineSet() lineSet.addPoint( new Point(string, float) // Style dots lineSet.setDots(boolean) lineSet.setDotsColor(color) lineSet.setDotsRadius(dimen) lineSet.setDotsStrokeThickness(dimen) lineSet.setDotsStrokeColor(color) // Style line lineSet.setLineThickness(dimen) lineSet.setLineColor(color) // Style background fill lineSet.setFill(boolean) lineSet.setFillColor(color) // Style type lineSet.setDashed(boolean) lineSet.setSmooth(boolean) chartView.addData(lineSet) | </tr> </tbody> </table> </div> </div>
| 1 2 3 4 5 </td> | <com.db.chart.BarChartView ... chart:chart_barSpacing= "dp" chart:chart_setSpacing= "dp" /> | </tr> </tbody> </table> </div> </div>
| 1 2 3 4 5 6 7 8 9 10 11 </td> | BarChartView chartView = new BarcChartView() barChart.setBarSpacing(dimen) barChart.setSetSpacing(dimen) barChart.setBarBackground(boolean) barChart.setBarBackgroundColor(color) barChart.setRoundCorners(dimen) BarSet barSet = new BarSet() Bar bar = new Bar(string, float) bar.setColor(color) barSet.addBar(bar) chartView.addData(barSet) | </tr> </tbody> </table> </div> </div>
| 1 2 3 4 5 6 </td> | chart.setOnEntryClickListener( new OnEntryClickListener(){ @Override public void onClick(int setIndex, int entryIndex, Rect entryRect) { //Do things } }); | </tr> </tbody> </table> </div> </div>
| 1 2 3 4 5 6 7 8 9 10 11 12 </td> | Animation anim = new Animation() anim.setDuration(integer) anim.setEasing(easingFunction) anim.setEndAction(runnable) // Animation overlap between entries anim.setOverlap(float) // Animation starting point anim.setStartPoint(float, float) // Include alpha transition anim.setAlpha(int) // Starts animation chart.animate(animation) | </tr> </tbody> </table> </div> </div>