Android-MPAndroidChart:RadarChart(雷达蜘蛛图)绘制圆点
生活随笔
收集整理的這篇文章主要介紹了
Android-MPAndroidChart:RadarChart(雷达蜘蛛图)绘制圆点
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
目錄
?
思路
實(shí)現(xiàn)
思路來源于Homilier,感謝博主!
效果是這樣子的:
思路
從RadarChart類中我們可以看到init()方法中的內(nèi)容,可以看出來自定義了繪制類。僅從字面我們就可以看出RadarChartRenderer是繪制雷達(dá)的,YAxisRendererRadarChart和XAxisRendererRadarChart是繪制x軸/y軸相關(guān)內(nèi)容的,既然這樣那我們就清楚了,進(jìn)RadarChartRenderer看看里面的實(shí)現(xiàn);
?從方法名上就可以看出端倪,drawValues(Canvas c) 是咱重點(diǎn)關(guān)注的內(nèi)容。所以在這開造。
實(shí)現(xiàn)
?直接貼代碼,很基礎(chǔ)的繪制代碼,就不做介紹了。代碼過長(zhǎng),沒必要的就直接用省略號(hào)了,對(duì)比下RadarChartRenderer即可
public class RadarChartRenderer extends LineRadarRenderer {protected RadarChart mChart;/*** paint for drawing the web*/protected Paint mWebPaint;protected Paint mHighlightCirclePaint;public RadarChartRenderer(RadarChart chart, ChartAnimator animator,ViewPortHandler viewPortHandler) {super(animator, viewPortHandler);mChart = chart;mHighlightPaint = new Paint(Paint.ANTI_ALIAS_FLAG);mHighlightPaint.setStyle(Paint.Style.STROKE);mHighlightPaint.setStrokeWidth(2f);mHighlightPaint.setColor(Color.rgb(255, 187, 115));mWebPaint = new Paint(Paint.ANTI_ALIAS_FLAG);mWebPaint.setStyle(Paint.Style.STROKE);mHighlightCirclePaint = new Paint(Paint.ANTI_ALIAS_FLAG);mValueCirclePaint = new Paint();}protected Path mDrawDataSetSurfacePathBuffer = new Path();........./*** 繪制RadarDataSet** @param c* @param dataSet* @param mostEntries 條目最多的數(shù)據(jù)集的條目計(jì)數(shù)*/protected void drawDataSet(Canvas c, IRadarDataSet dataSet, int mostEntries) {float phaseX = mAnimator.getPhaseX();float phaseY = mAnimator.getPhaseY();float sliceangle = mChart.getSliceAngle();// 計(jì)算將值轉(zhuǎn)換為像素所需的因子float factor = mChart.getFactor();MPPointF center = mChart.getCenterOffsets();MPPointF pOut = MPPointF.getInstance(0, 0);Path surface = mDrawDataSetSurfacePathBuffer;surface.reset();boolean hasMovedToPoint = false;for (int j = 0; j < dataSet.getEntryCount(); j++) {mRenderPaint.setColor(dataSet.getColor(j));RadarEntry e = dataSet.getEntryForIndex(j);Utils.getPosition(center, (e.getY() - mChart.getYChartMin()) * factor * phaseY, sliceangle * j * phaseX + mChart.getRotationAngle(), pOut);if (Float.isNaN(pOut.x)) {continue;}if (!hasMovedToPoint) {surface.moveTo(pOut.x, pOut.y);hasMovedToPoint = true;} else {surface.lineTo(pOut.x, pOut.y);}}if (dataSet.getEntryCount() > mostEntries) {// if this is not the largest set, draw a line to the center before closingsurface.lineTo(center.x, center.y);}surface.close();if (dataSet.isDrawFilledEnabled()) {final Drawable drawable = dataSet.getFillDrawable();if (drawable != null) {drawFilledPath(c, surface, drawable);} else {drawFilledPath(c, surface, dataSet.getFillColor(), dataSet.getFillAlpha());}}mRenderPaint.setStrokeWidth(dataSet.getLineWidth());mRenderPaint.setStyle(Paint.Style.STROKE);// 畫線(僅當(dāng)禁用填充或alpha小于255時(shí))if (!dataSet.isDrawFilledEnabled() || dataSet.getFillAlpha() < 255) {c.drawPath(surface, mRenderPaint);}MPPointF.recycleInstance(center);MPPointF.recycleInstance(pOut);}private Paint mValueCirclePaint;private float mValueCircleRadius = Utils.convertDpToPixel(5f);private int[] mValueCircleColors;private boolean mDrawValueCircle = false;private float mValueCircleRadiusUp = Utils.convertDpToPixel(3f);private int[] mValueCircleColorsUp;private boolean mDrawValueCircleUp = false;/*** 繪制數(shù)值-也就是和數(shù)值相關(guān)的位置** @param c*/@Overridepublic void drawValues(Canvas c) {float phaseX = mAnimator.getPhaseX();float phaseY = mAnimator.getPhaseY();float sliceangle = mChart.getSliceAngle();// 計(jì)算將值轉(zhuǎn)換為像素所需的因子float factor = mChart.getFactor();MPPointF center = mChart.getCenterOffsets();MPPointF pOut = MPPointF.getInstance(0, 0);MPPointF pIcon = MPPointF.getInstance(0, 0);float yoffset = Utils.convertDpToPixel(5f);for (int i = 0; i < mChart.getData().getDataSetCount(); i++) {IRadarDataSet dataSet = mChart.getData().getDataSetByIndex(i);if (!shouldDrawValues(dataSet)) {continue;}// 應(yīng)用數(shù)據(jù)集定義的文本樣式applyValueTextStyle(dataSet);ValueFormatter formatter = dataSet.getValueFormatter();MPPointF iconsOffset = MPPointF.getInstance(dataSet.getIconsOffset());iconsOffset.x = Utils.convertDpToPixel(iconsOffset.x);iconsOffset.y = Utils.convertDpToPixel(iconsOffset.y);for (int j = 0; j < dataSet.getEntryCount(); j++) {RadarEntry entry = dataSet.getEntryForIndex(j);Utils.getPosition(center, (entry.getY() - mChart.getYChartMin()) * factor * phaseY,sliceangle * j * phaseX + mChart.getRotationAngle(), pOut);if (dataSet.isDrawValuesEnabled()) {drawValue(c, formatter.getRadarLabel(entry), pOut.x, pOut.y - yoffset, dataSet.getValueTextColor(j));}if (entry.getIcon() != null && dataSet.isDrawIconsEnabled()) {Drawable icon = entry.getIcon();Utils.getPosition(center, (entry.getY()) * factor * phaseY + iconsOffset.y, sliceangle * j * phaseX + mChart.getRotationAngle(), pIcon);//無檢查SuspiciousNameCombinationpIcon.y += iconsOffset.x;Utils.drawImage(c, icon, (int) pIcon.x, (int) pIcon.y, icon.getIntrinsicWidth(), icon.getIntrinsicHeight());}if (mDrawValueCircle) {mValueCirclePaint.setColor(mValueCircleColors == null || mValueCircleColors.length == 0 ? Color.BLACK : this.mValueCircleColors[i % mValueCircleColors.length]);c.drawCircle(pOut.x, pOut.y, mValueCircleRadius, mValueCirclePaint);}if (mDrawValueCircleUp) {mValueCirclePaint.setColor(mValueCircleColorsUp == null || mValueCircleColorsUp.length == 0 ? Color.BLACK : this.mValueCircleColorsUp[i % mValueCircleColorsUp.length]);c.drawCircle(pOut.x, pOut.y, mValueCircleRadiusUp, mValueCirclePaint);} // c.drawCircle(center.x, center.y, 8, mWebPaint);}MPPointF.recycleInstance(iconsOffset);}MPPointF.recycleInstance(center);MPPointF.recycleInstance(pOut);MPPointF.recycleInstance(pIcon);}/*** 數(shù)值圓點(diǎn)顏色** @param colors 顏色*/public void setValueCircleColor(int[] colors, int[] colorsUp) {this.mValueCircleColors = colors;this.mValueCircleColorsUp = colorsUp;}/*** 數(shù)值圓點(diǎn)半徑** @param radius 半徑*/public void setValueCircleRadius(float radius, float radiusUp) {this.mValueCircleRadius = Utils.convertDpToPixel(radius);this.mValueCircleRadiusUp = Utils.convertDpToPixel(radiusUp);}/*** 是否繪制數(shù)值圓點(diǎn)** @param draw*/public void setDrawValueCircle(boolean draw, boolean drawUp) {this.mDrawValueCircleUp = drawUp;this.mDrawValueCircle = draw;}......... }RadarChart添加三個(gè)方法
public class RadarChart extends PieRadarChartBase<RadarData> {......../*** 頂角圓點(diǎn)顏色* @param colors 顏色*/public void setValueCircleColor(int[] colors,int[] colorsUp){((RadarChartRenderer) this.mRenderer).setValueCircleColor(colors,colorsUp);}/*** 頂角圓點(diǎn)半徑* @param radius 半徑*/public void setValueCircleRadius(float radius,float radiusUp){((RadarChartRenderer) this.mRenderer).setValueCircleRadius(radius,radiusUp);}/*** 是否繪制頂角圓點(diǎn)* @param draw*/public void setDrawValueCircle(boolean draw,boolean drawUp){((RadarChartRenderer) this.mRenderer).setDrawValueCircle(draw,drawUp);}........ }自己項(xiàng)目中應(yīng)用:
@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,WindowManager.LayoutParams.FLAG_FULLSCREEN);setContentView(R.layout.activity_radarchart);RadarChart chart = findViewById(R.id.chart1);chart.setWebLineWidth(1f);chart.setWebColor(Color.LTGRAY);chart.setWebLineWidthInner(1f);chart.setWebColorInner(Color.LTGRAY);chart.setWebAlpha(100);// 創(chuàng)建一個(gè)自定義MarkerView(擴(kuò)展MarkerView)并指定布局用它MarkerView mv = new RadarMarkerView(this, R.layout.radar_markerview);//重點(diǎn)在這//設(shè)置數(shù)據(jù)圓點(diǎn) 第一個(gè)true表示繪制下層圓 第二個(gè)true繪制上層圓 形成圓環(huán)形式的圓chart.setDrawValueCircle(true, true);//設(shè)置半徑 第一個(gè)參數(shù)大于第二個(gè)參數(shù) 才會(huì)有圓環(huán)的那種樣子chart.setValueCircleRadius(6, 4);//可以設(shè)置多個(gè)顏色,第一個(gè)數(shù)組是下層圓 第二個(gè)數(shù)組是下層圓chart.setValueCircleColor(new int[]{Color.parseColor("#36a9ce"),Color.parseColor("#33ff66"),}, new int[]{Color.parseColor("#ffffff"),Color.parseColor("#000000")});}總結(jié)
以上是生活随笔為你收集整理的Android-MPAndroidChart:RadarChart(雷达蜘蛛图)绘制圆点的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 以计算机写一篇作文500字,有关电脑作文
- 下一篇: iOS状态栏重叠问题以及如何隐藏状态栏