国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統(tǒng) > Android > 正文

Android自定義view實現(xiàn)動態(tài)柱狀圖

2019-10-22 18:31:02
字體:
供稿:網(wǎng)友

先看一下動態(tài)柱狀圖效果。

主要功能是可以自定義指定的字體,柱狀圖顏色,動態(tài)效果。

Android,view,柱狀圖

在自定義view

public class Histogram extends View { int MAX = 100;//矩形顯示的最大值 int corner = 0; //矩形的角度。 設置為0 則沒有角度。 double data = 0.0;//顯示的數(shù) double tempData = 0; //初始數(shù)據(jù) int textPadding = 50; //字體與矩形圖的距離  Paint mPaint; int mColor;  Context mContext; //構造函數(shù) public Histogram(Context context) {  super(context);  mContext = context; } public Histogram(Context context, @Nullable AttributeSet attrs) {  super(context, attrs);  mContext = context;  initPaint(); } public Histogram(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {  super(context, attrs, defStyleAttr);  mContext = context;  initPaint(); } //畫筆方法 private void initPaint() {  mPaint = new Paint();  mPaint.setAntiAlias(true);  mColor = mContext.getResources().getColor(R.color.gary);  mPaint.setColor(mColor); } @Override public void draw(Canvas canvas) {  super.draw(canvas);  if (data == 0.0) {   mPaint.setTextSize(getWidth() / 2);   RectF oval3 = new RectF(0, getHeight() - DensityUtils.pxTodip(mContext, 20), getWidth(), getHeight());// 設置個新的長方形   canvas.drawRoundRect(oval3, DensityUtils.pxTodip(mContext, corner), DensityUtils.pxTodip(mContext, corner), mPaint);   canvas.drawText("0",     getWidth() * 0.5f - mPaint.measureText("0") * 0.5f,     getHeight() - DensityUtils.pxTodip(mContext, 20) - 2 * DensityUtils.pxTodip(mContext, textPadding),     mPaint);   return;  }  //防止數(shù)值很大的的時候,動畫時間過長  int step = (int) (data / 100 + 1.0);  if (tempData < data - step) {   tempData = tempData + step;  } else {   tempData = data;  }  //畫圓角矩形  String S = tempData + ""; //如果數(shù)字后面需要加% 則在""中添加%  //設置顯示的字體  Typeface typeface = Typeface.createFromAsset(getContext().getAssets(),"digital-7.ttf");  mPaint.setTypeface(typeface);//  //一個字和兩,三個字的字號相同  if (S.length() < 4) {   mPaint.setTextSize(getWidth()/2 );  } else {   mPaint.setTextSize(50); //可以通過getWidth()/2 改變字體大小 也可以通過設置數(shù)字來改變自己想要的字體大小 當超出矩形圖寬度時不能顯示全部  }//  float textH = mPaint.ascent() + mPaint.descent();  float MaxH = getHeight() - textH - 2 * DensityUtils.pxTodip(mContext, textPadding);//  //圓角矩形的實際高度  float realH = (float) (MaxH / MAX * tempData);  RectF oval3 = new RectF(0, getHeight() - realH, getWidth(), getHeight());// 設置個新的長方形  canvas.drawRoundRect(oval3, DensityUtils.pxTodip(mContext, corner), DensityUtils.pxTodip(mContext, corner), mPaint);  //寫數(shù)字  canvas.drawText(S,    getWidth() * 0.5f - mPaint.measureText(S) * 0.5f,    getHeight() - realH - 2 * DensityUtils.pxTodip(mContext, textPadding),    mPaint);  if (tempData != data) {   postInvalidate();  } } public void setData(double data, int MAX) {  this.data = data;  this.MAX = MAX;  postInvalidate(); } public int getmColor() {  return mColor; } public void setmColor(int mColor) {  this.mColor = mColor; }}

布局

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/activity_main" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_weight="1" > <View  android:layout_width="0dp"  android:layout_height="match_parent"  android:layout_weight="0.2"/> <com.mieasy.myhistogramview.Histogram  android:id="@+id/column_one"  android:layout_width="0dp"  android:layout_height="300dp"  android:layout_weight="0.8"/> <View  android:layout_width="0dp"  android:layout_height="match_parent"  android:layout_weight="2.4"/> <com.mieasy.myhistogramview.Histogram  android:id="@+id/column_two"  android:layout_width="0dp"  android:layout_height="300dp"  android:layout_weight="1"/> <View  android:layout_width="0dp"  android:layout_height="match_parent"  android:layout_weight="2.4"/> <com.mieasy.myhistogramview.Histogram  android:id="@+id/column_three"  android:layout_width="0dp"  android:layout_height="300dp"  android:layout_weight="1"/> <View  android:layout_width="0dp"  android:layout_height="match_parent"  android:layout_weight="0.2"/></LinearLayout>

MainActivity調(diào)用initAllViews()方法

 private void initAllViews() {  column_one = (Histogram) findViewById(R.id.column_one);  column_two = (Histogram) findViewById(R.id.column_two);  column_three = (Histogram) findViewById(R.id.column_three);  column_one.setData( 20.22, 100);  column_two.setData(30.2, 100);  column_three.setData(40, 100);  column_one.mPaint.setColor(getResources().getColor(R.color.colorAccent)); //改變柱狀圖的顏色 }

 

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網(wǎng)。


注:相關教程知識閱讀請移步到Android開發(fā)頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 大余县| 读书| 成安县| 旺苍县| 华阴市| 渝北区| 云梦县| 卢龙县| 松阳县| 萨迦县| 锡林郭勒盟| 南部县| 安塞县| 彭阳县| 旺苍县| 资兴市| 兴宁市| 巫山县| 尖扎县| 大关县| 新田县| 庆阳市| 永川市| 报价| 安福县| 托克逊县| 抚顺县| 静海县| 济源市| 新晃| 溆浦县| 武汉市| 衡阳县| 铜梁县| 衡山县| 尖扎县| 德令哈市| 怀安县| 兴业县| 沧州市| 丰宁|