Android自定義View可以轉(zhuǎn)動的小圓球球

廢話少說 直接上碼:

自定義view部分。

``` java

import android.content.Context;

import android.content.res.TypedArray;

import android.graphics.Canvas;

import android.graphics.Color;

import android.graphics.Paint;

import android.graphics.drawable.Drawable;

import android.os.Handler;

import android.os.Looper;

import android.os.Message;

import android.text.Layout;

import android.text.StaticLayout;

import android.text.TextPaint;

import android.util.AttributeSet;

import android.util.Log;

import android.view.View;

import java.lang.reflect.Method;

/**

* TODO: document your custom view class.

*/

public class CircleView extends View {

//大圓屬性

private boolean mGradientAble = false;//顏色漸變

private int mBigCircleRadius;//大圓半徑

private int mBigCircleColor;//大圓顏色

private boolean mRotationFunction = false;//是否顯示小圈轉(zhuǎn)動

private boolean mBigHollow = false;//是否空心

private int mPaintSize = 4;//大圓畫筆大小

// 小圓屬性

private int mSmallCircleColor;//小圓顏色

private int mSmallCircleRadius;//小圓半徑

private boolean mSmallHollow = false;//是否空心

private int mSmallPaintSize = 2;//小圓畫筆大小

private Paint mSmallCirclePaint;//小圓畫筆

private Paint mBigCirclePaint;//大圓畫筆

private int mBigCircleX, mBigCircleY, mSmallCircleX, mSmallCircleY;

private String mContentStr;//字內(nèi)容

private int mTextColor = Color.GRAY;//字的顏色

private int mTextSize;//字大小

private int mWrapNumber;//換行字數(shù)

private boolean mRunSmallBallLogic = true;

private int mRunDegree = 0;

private int mTimeSleep = 10;

private int mRunDegreeAdd=2;

private final int UPDATE_VIEW_MSG=1;

private TextPaint mTextPaint;

private float mTextWidth;

private float mTextHeight;

private Handler mHandler = new Handler(Looper.getMainLooper()) {

@Override

public void dispatchMessage(Message msg) {

super.dispatchMessage(msg);

if (msg.what == UPDATE_VIEW_MSG) {

calculatCenterPoint();

}

}

};

/**

* 計算圓點中心

*/

private void calculatCenterPoint(){

double cos = Math.cos(mRunDegree * Math.PI / 180);

double sin = Math.sin(mRunDegree * Math.PI / 180);

mSmallCircleX = (int) (mBigCircleX + mBigCircleRadius * cos);

mSmallCircleY = (int) (mBigCircleY - mBigCircleRadius * sin);

mRunDegree += mRunDegreeAdd;

invalidate();

mHandler.sendEmptyMessageDelayed(UPDATE_VIEW_MSG, mTimeSleep);

}

public CircleView(Context context) {

super(context);

init(null, 0);

}

public CircleView(Context context, AttributeSet attrs) {

super(context, attrs);

init(attrs, 0);

}

public CircleView(Context context, AttributeSet attrs, int defStyle) {

super(context, attrs, defStyle);

init(attrs, defStyle);

}

private void init(AttributeSet attrs, int defStyle) {

// Load attributes

final TypedArray a = getContext().obtainStyledAttributes(

attrs, R.styleable.CircleView, defStyle, 0);

mGradientAble = a.getBoolean(R.styleable.CircleView_mGradientAble, false);

mBigCircleRadius = (int) a.getDimension(R.styleable.CircleView_mBigCircleRadius, 0);//大圓半徑

mBigCircleColor = a.getColor(R.styleable.CircleView_mBigCircleColor, Color.GRAY);//大圓顏色

mRotationFunction = a.getBoolean(R.styleable.CircleView_mRotationFunction, false);//是否顯示小圈轉(zhuǎn)動

mBigHollow = a.getBoolean(R.styleable.CircleView_mBigHollow, true);//是否空心

mPaintSize = (int) a.getDimension(R.styleable.CircleView_mPaintSize, 4);//大圓畫筆大小

// 小圓屬性

mSmallCircleColor = a.getColor(R.styleable.CircleView_mSmallCircleColor, Color.GRAY);//大圓顏色;//小圓顏色

mSmallCircleRadius = (int) a.getDimension(R.styleable.CircleView_mSmallCircleRadius, 0);//小圓半徑

mSmallHollow = a.getBoolean(R.styleable.CircleView_mSmallHollow, false);//是否空心

mSmallPaintSize = (int) a.getDimension(R.styleable.CircleView_mSmallPaintSize, 2);//小圓畫筆大小

mContentStr = a.getString(R.styleable.CircleView_mContentStr);//字內(nèi)容

mTextColor = a.getColor(R.styleable.CircleView_mTextColor, Color.GRAY);//字的顏色

mTextSize = (int) a.getDimension(R.styleable.CircleView_mTextSize, 10);//字大小

mWrapNumber = a.getInt(R.styleable.CircleView_mWrapNumber, 2);//字大小

a.recycle();

mSmallCirclePaint = new Paint();

mBigCirclePaint = new Paint();

mTextPaint = new TextPaint();

setPaint();

}

private void logicSmallBall() {

//? ? ? ? mRunSmallBallLogic = true;

//? ? ? ? new Thread() {

//? ? ? ? ? ? @Override

//? ? ? ? ? ? public void run() {

//? ? ? ? ? ? ? ? super.run();

//? ? ? ? ? ? ? ? while (mRunSmallBallLogic) {

//? ? ? ? ? ? ? ? ? ? mSmallCircleX = (int) (mBigCircleX + (mBigCircleRadius + mPaintSize / 2f) * Math.cos(mRunDegree));

//? ? ? ? ? ? ? ? ? ? mSmallCircleY = (int) (mBigCircleY - (mBigCircleRadius + mPaintSize / 2f) * Math.sin(mRunDegree));

//? ? ? ? ? ? ? ? ? ? mRunDegree++;

//? ? ? ? ? ? ? ? ? ? try {

//? ? ? ? ? ? ? ? ? ? ? ? Thread.sleep(mTimeSleep);

//? ? ? ? ? ? ? ? ? ? } catch (InterruptedException e) {

//? ? ? ? ? ? ? ? ? ? ? ? e.printStackTrace();

//? ? ? ? ? ? ? ? ? ? }

//? ? ? ? ? ? ? ? ? ? mHandler.sendEmptyMessage(1);

//? ? ? ? ? ? ? ? }

//? ? ? ? ? ? }

//? ? ? ? }.start();

mHandler.removeMessages(1);

mHandler.sendEmptyMessageDelayed(1, mTimeSleep);

}

@Override

protected void onDetachedFromWindow() {

super.onDetachedFromWindow();

}

//設(shè)置畫筆

public void setPaint() {

mSmallCirclePaint.setAntiAlias(true);//去鋸齒

mSmallCirclePaint.setColor(mSmallCircleColor);

mSmallCirclePaint.setStrokeWidth(mSmallPaintSize);

mBigCirclePaint.setAntiAlias(true);

mBigCirclePaint.setColor(mBigCircleColor);

mBigCirclePaint.setStrokeWidth(mPaintSize);

mTextPaint.setFlags(Paint.ANTI_ALIAS_FLAG);

mTextPaint.setTextAlign(Paint.Align.CENTER);

if (mBigHollow) {

mBigCirclePaint.setStyle(Paint.Style.STROKE);

} else {

mBigCirclePaint.setStyle(Paint.Style.FILL);

}

if (mSmallHollow) {

mSmallCirclePaint.setStyle(Paint.Style.STROKE);

} else {

mSmallCirclePaint.setStyle(Paint.Style.FILL);

}

invalidateTextPaintAndMeasurements();

}

private void invalidateTextPaintAndMeasurements() {

mTextPaint.setTextSize(mTextSize);

mTextPaint.setColor(mTextColor);

mTextWidth = mTextPaint.measureText(mContentStr);

Paint.FontMetrics fontMetrics = mTextPaint.getFontMetrics();

mTextHeight = fontMetrics.bottom;

}

@Override

protected void onDraw(Canvas canvas) {

super.onDraw(canvas);

canvas.save();

StaticLayout layout = new StaticLayout(mContentStr, mTextPaint, 10000, Layout.Alignment.ALIGN_NORMAL, 1, 0, false);

canvas.translate(mBigCircleX, mBigCircleY - 3 * mTextHeight);//從100,100開始畫

layout.draw(canvas);

canvas.restore();

canvas.drawCircle(mBigCircleX, mBigCircleY, mBigCircleRadius, mBigCirclePaint);

if (mRotationFunction) {

canvas.drawCircle(mSmallCircleX, mSmallCircleY, mSmallCircleRadius, mSmallCirclePaint);

}

//? ? ? ? Log.e("TAG", "mBigCircleRadius:" + mBigCircleRadius + " mTextHeight:" + mTextHeight + " mContentStr" + mContentStr.length());

}

@Override

public void onWindowFocusChanged(boolean hasWindowFocus) {

super.onWindowFocusChanged(hasWindowFocus);

if (hasWindowFocus) {

mBigCircleX = this.getWidth() / 2;

mBigCircleY = this.getHeight() / 2;

if (mBigCircleRadius == 0) {

mBigCircleRadius = this.getWidth() / 2 - 2 * mPaintSize;

}

if (mRotationFunction) {//顯示旋轉(zhuǎn)小球

mHandler.removeMessages(UPDATE_VIEW_MSG);

calculatCenterPoint();

}

invalidate();

}

}

public void setmRunDegreeAdd(int mRunDegreeAdd) {

this.mRunDegreeAdd = mRunDegreeAdd;

}

public void setmTimeSleep(int mTimeSleep) {

this.mTimeSleep = mTimeSleep;

}

public void setmTextSize(int mTextSize) {

this.mTextSize = mTextSize;

mTextPaint.setTextSize(mTextSize);

}

public void setmTextColor(int mTextColor) {

this.mTextColor = mTextColor;

mTextPaint.setColor(mTextColor);

}

public void setmContentStr(String mContentStr) {

this.mContentStr = mContentStr;

}

public void setmGradientAble(boolean mGradientAble) {

this.mGradientAble = mGradientAble;

}

public void setmBigCircleRadius(int mBigCircleRadius) {

this.mBigCircleRadius = mBigCircleRadius;

}

public void setmBigCircleColor(int mBigCircleColor) {

this.mBigCircleColor = mBigCircleColor;

mBigCirclePaint.setColor(mBigCircleColor);

}

public void setmRotationFunction(boolean mRotationFunction) {

this.mRotationFunction = mRotationFunction;

}

public void setmBigHollow(boolean mBigHollow) {

this.mBigHollow = mBigHollow;

}

public void setmPaintSize(int mPaintSize) {

this.mPaintSize = mPaintSize;

mBigCirclePaint.setStrokeWidth(mPaintSize);

}

public void setmSmallCircleColor(int mSmallCircleColor) {

this.mSmallCircleColor = mSmallCircleColor;

mSmallCirclePaint.setColor(mSmallCircleColor);

}

public void setmSmallCircleRadius(int mSmallCircleRadius) {

this.mSmallCircleRadius = mSmallCircleRadius;

}

public void setmSmallHollow(boolean mSmallHollow) {

this.mSmallHollow = mSmallHollow;

}

public void setmSmallPaintSize(int mSmallPaintSize) {

this.mSmallPaintSize = mSmallPaintSize;

mSmallCirclePaint.setStrokeWidth(mSmallPaintSize);

}

public void setmTextWidth(float mTextWidth) {

this.mTextWidth = mTextWidth;

}

public void setmTextHeight(float mTextHeight) {

this.mTextHeight = mTextHeight;

}

}```


需要在attrs中定義屬性

為什么粘不了代碼:?????




最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,908評論 6 541
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,324評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,018評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,675評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 72,417評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,783評論 1 329
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,779評論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,960評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,522評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 41,267評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,471評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,009評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,698評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,099評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,386評論 1 294
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,204評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 48,436評論 2 378

推薦閱讀更多精彩內(nèi)容