Android-6步教會(huì)你自定義View,自定義View就是這么簡(jiǎn)單

如果你打算完全定制一個(gè)View,那么你需要實(shí)現(xiàn)View類(lèi)(所有的Android View都實(shí)現(xiàn)于這個(gè)類(lèi))错邦,并且實(shí)現(xiàn)確定尺寸的onMeasure(…))方法和確認(rèn)繪圖的onDraw(…))方法。
自定義View一共分為6步
第一步
public class SmileyView extends View { private Paint mCirclePaint; private Paint mEyeAndMouthPaint; private float mCenterX; private float mCenterY; private float mRadius; private RectF mArcBounds = new RectF(); public SmileyView(Context context) { this(context, null); } public SmileyView(Context context, AttributeSet attrs) { this(context, attrs, 0); } public SmileyView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); initPaints(); } private void initPaints() {/* ... /} @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {/ ... /} @Override protected void onDraw(Canvas canvas) {/ ... */} }
2.實(shí)現(xiàn)畫(huà)筆paint類(lèi)

本文一共兩只畫(huà)筆
private void initPaints() {
mCirclePaint = new Paint(Paint.ANTI_ALIAS_FLAG);
mCirclePaint.setStyle(Paint.Style.FILL);
mCirclePaint.setColor(Color.YELLOW);
mEyeAndMouthPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
mEyeAndMouthPaint.setStyle(Paint.Style.STROKE);
mEyeAndMouthPaint.setStrokeWidth(16 * getResources().getDisplayMetrics().density);
mEyeAndMouthPaint.setStrokeCap(Paint.Cap.ROUND);
mEyeAndMouthPaint.setColor(Color.BLACK);
}
3.覆寫(xiě)onMeasure(…)方法

實(shí)現(xiàn)這個(gè)方法告訴了母容器如何放棄自定義View型宙,可以通過(guò)提供的measureSpecs來(lái)決定你的View的高和寬撬呢,以下是一個(gè)正方形,確認(rèn)它的寬和高是一樣的妆兑。
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
int w = MeasureSpec.getSize(widthMeasureSpec);
int h = MeasureSpec.getSize(heightMeasureSpec);

int size = Math.min(w, h);
setMeasuredDimension(size, size);

}
注意:
這個(gè)方法需要至少保證一個(gè)setMeasuredDimension(..)調(diào)用魂拦,否則會(huì)報(bào)IllegalStateException錯(cuò)誤毛仪。
4.實(shí)現(xiàn)onSizeChanged(…)方法

這個(gè)方法是你獲取View現(xiàn)在的寬和高. 這里我們計(jì)算的是中心和半徑。
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
mCenterX = w / 2f;
mCenterY = h / 2f;
mRadius = Math.min(w, h) / 2f;
}
5.實(shí)現(xiàn)onDraw(…)方法
這個(gè)方法提供了如何繪制view芯勘,它提供的Canvas類(lèi)可以進(jìn)行繪制箱靴。
@Override
protected void onDraw(Canvas canvas) {
// draw face
canvas.drawCircle(mCenterX, mCenterY, mRadius, mCirclePaint);
// draw eyes
float eyeRadius = mRadius / 5f;
float eyeOffsetX = mRadius / 3f;
float eyeOffsetY = mRadius / 3f; canvas.drawCircle(mCenterX - eyeOffsetX, mCenterY - eyeOffsetY, eyeRadius, mEyeAndMouthPaint); canvas.drawCircle(mCenterX + eyeOffsetX, mCenterY - eyeOffsetY, eyeRadius, mEyeAndMouthPaint);
// draw mouth
float mouthInset = mRadius /3f;
mArcBounds.set(mouthInset, mouthInset, mRadius * 2 - mouthInset, mRadius * 2 - mouthInset);
canvas.drawArc(mArcBounds, 45f, 90f, false, mEyeAndMouthPaint);
}
6.添加你的View
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <com.example.app.SmileyView android:layout_width="match_parent" android:layout_height="match_parent" /> </FrameLayout>

到此就結(jié)束了,自定義View沒(méi)你想的那么難

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末荷愕,一起剝皮案震驚了整個(gè)濱河市衡怀,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌安疗,老刑警劉巖抛杨,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異荐类,居然都是意外死亡怖现,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)掉冶,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人脐雪,你說(shuō)我怎么就攤上這事厌小。” “怎么了战秋?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵璧亚,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我脂信,道長(zhǎng)癣蟋,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任狰闪,我火速辦了婚禮疯搅,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘埋泵。我一直安慰自己幔欧,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布丽声。 她就那樣靜靜地躺著礁蔗,像睡著了一般。 火紅的嫁衣襯著肌膚如雪雁社。 梳的紋絲不亂的頭發(fā)上浴井,一...
    開(kāi)封第一講書(shū)人閱讀 51,692評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音霉撵,去河邊找鬼磺浙。 笑死洪囤,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的屠缭。 我是一名探鬼主播箍鼓,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼呵曹!你這毒婦竟也來(lái)了款咖?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤奄喂,失蹤者是張志新(化名)和其女友劉穎铐殃,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體跨新,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡富腊,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了域帐。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赘被。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖肖揣,靈堂內(nèi)的尸體忽然破棺而出民假,到底是詐尸還是另有隱情,我是刑警寧澤龙优,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布羊异,位于F島的核電站,受9級(jí)特大地震影響彤断,放射性物質(zhì)發(fā)生泄漏野舶。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一宰衙、第九天 我趴在偏房一處隱蔽的房頂上張望平道。 院中可真熱鬧,春花似錦供炼、人聲如沸巢掺。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)陆淀。三九已至,卻和暖如春先嬉,著一層夾襖步出監(jiān)牢的瞬間轧苫,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留含懊,地道東北人身冬。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像岔乔,于是被迫代替她去往敵國(guó)和親酥筝。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355

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

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,167評(píng)論 25 707
  • 一雏门、Android開(kāi)發(fā)初體驗(yàn) 二嘿歌、Android與MVC設(shè)計(jì)模式模型對(duì)象存儲(chǔ)著應(yīng)用的數(shù)據(jù)和業(yè)務(wù)邏輯。模型類(lèi)通常用來(lái)...
    為夢(mèng)想戰(zhàn)斗閱讀 887評(píng)論 0 3
  • 前言: 在接觸Android這么長(zhǎng)時(shí)間茁影,看到很多大牛都在和大家分享自己的知識(shí)宙帝,深有體會(huì),剛好前段時(shí)間寫(xiě)了一個(gè)Dem...
    楊艷偉閱讀 1,275評(píng)論 0 5
  • 一募闲、概述 1. 四線格與基線 小時(shí)候步脓,我們?cè)趧傞_(kāi)始學(xué)習(xí)寫(xiě)字母時(shí),用的本子是四線格的浩螺,我們必須把字母按照規(guī)則寫(xiě)在四線...
    addapp閱讀 7,663評(píng)論 2 17
  • 修行靴患,大概就是該在日常中的。 今天在筆記本上輕輕寫(xiě)下一句話要出,把靈性帶入生活的每時(shí)每刻鸳君。就像現(xiàn)在打字一樣,眼疾手快的...
    欣喜邇閱讀 183評(píng)論 0 0