Android開發(fā)之自定義UI組件詳解
Android開發(fā)自定義UI組件實(shí)現(xiàn)紅色小球跟隨手指移動(dòng)
要寫實(shí)現(xiàn)自定義UI組件,要?jiǎng)?chuàng)建一個(gè)BallView類,繼承View類,在BallView類中創(chuàng)建畫筆,然后重寫OnDraw()方法和OnTouchEvent()方法。
/** * Created by nuist__NJUPT on 2021/5/9. * 自定義UI組件 * View組件在布局中是一個(gè)矩形的空白區(qū)域,沒有任何內(nèi)容 * 而UI組件之所以有內(nèi)容,是因?yàn)槔^承了View組件之后在其提供的空白區(qū)域上重新繪制外觀,這就是UI組件的實(shí)現(xiàn)原理 * 利用UI組件的實(shí)現(xiàn)原理,可以開發(fā)出一些特殊的UI組件, * 這些自定義UI組件創(chuàng)建時(shí)需要定義一個(gè)繼承View類的子類 * 然后重寫View類的一個(gè)或者多個(gè)方法 * */ public class BallView extends View { public BallView(Context context) { //重寫構(gòu)造方法 super(context); } public BallView(Context context, AttributeSet attrs) { //重寫構(gòu)造方法 super(context, attrs); } //定義圓形的圓形坐標(biāo) public float currentX = 60 ; public float currentY = 60 ; //創(chuàng)建畫筆 Paint paint = new Paint() ; @Override protected void onDraw(Canvas canvas) {//重寫OnDraw()方法:當(dāng)組件要繪制內(nèi)容時(shí)候回調(diào)該方法 super.onDraw(canvas); //設(shè)置畫筆的顏色為紅色 paint.setColor(Color.RED); //畫一個(gè)圓心坐標(biāo)為(60,60),半徑為20的圓形 canvas.drawCircle(currentX,currentY,20,paint); } @Override public boolean onTouchEvent(MotionEvent event) { //重寫OnTouchEvent()方法:當(dāng)觸摸屏幕時(shí)候回調(diào)該方法 //得到觸摸后圓心坐標(biāo)所在位置 currentX = event.getX() ; currentY = event.getY() ; //通知當(dāng)前組件繪制 invalidate() ; return true ; //表明處理方法已經(jīng)處理該事件 } }
在自定義組件完成后,需要在java代碼中把該組件添加到容器中,才能看到想要的效果。
代碼如下:
ublic class CodeUiActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_code_ui); LinearLayout rootView = (LinearLayout) findViewById(R.id.root_view);//實(shí)例化布局對(duì)象 BallView ballView = new BallView(this) ; //實(shí)例自定義的UI組件 rootView.addView(ballView) ;//將自定義組件添加到容器中 } }
布局文件需要設(shè)置布局的id,需要在Java代碼中綁定。
XML文件如下:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:id="@+id/root_view" tools:context="com.example.nuist__njupt.uidesign.CodeUiActivity"> </LinearLayout>
實(shí)現(xiàn)效果如下:
總結(jié)
到此這篇關(guān)于Android開發(fā)之自定義UI組件的文章就介紹到這了,更多相關(guān)Android自定義UI組件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android下使用TCPDUMP實(shí)現(xiàn)數(shù)據(jù)抓包教程
這篇文章主要介紹了Android下使用TCPDUMP實(shí)現(xiàn)數(shù)據(jù)抓包教程,本文講解使用抓包工具tcpdump抓取數(shù)據(jù),然后使用Wireshark來(lái)分析數(shù)據(jù),需要的朋友可以參考下2015-02-02android上一個(gè)可追蹤代碼具體到函數(shù)某行的日志類
追蹤代碼到函數(shù)具體某行,這樣的功能,是每一個(gè)程序員都希望會(huì)有的,因?yàn)樗梢詭椭覀冏粉櫟侥承写a的錯(cuò)誤,接下來(lái)介紹下android上一個(gè)可追蹤代碼到函數(shù)具體某行的日志類,希望對(duì)開發(fā)者有所幫助2012-12-12Android Usb設(shè)備的監(jiān)聽(Dev)外設(shè)端口的判定以及耳機(jī)的插拔
今天小編就為大家分享一篇關(guān)于Android Usb設(shè)備的監(jiān)聽(Dev)外設(shè)端口的判定以及耳機(jī)的插拔,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2018-12-12Android Studio實(shí)現(xiàn)QQ的注冊(cè)登錄和好友列表跳轉(zhuǎn)
最近做了一個(gè)項(xiàng)目,這篇文章主要介紹了Android Studio界面跳轉(zhuǎn),本次項(xiàng)目主要包含了注冊(cè)、登錄和好友列表三個(gè)界面以及之間相互跳轉(zhuǎn),感興趣的可以了解一下2021-05-05多面分析HarmonyOS與Android的特點(diǎn)
請(qǐng)教身邊的大佬們,公司的CTO、中臺(tái)部門的總監(jiān)、老東家數(shù)十年行業(yè)經(jīng)驗(yàn)的老架構(gòu)、以及在中科院讀研究生的大學(xué)老室友、技術(shù)圈的網(wǎng)友等等,他們都給出了自己獨(dú)特的看法,讓我從多方面更好的去了解到了大家對(duì)鴻蒙的認(rèn)識(shí)2021-08-08調(diào)用startService會(huì)拋出IllegalStateException異常解決
這篇文章主要為大家介紹了調(diào)用startService會(huì)拋出IllegalStateException異常解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07詳解Android 手機(jī)衛(wèi)士設(shè)置向?qū)ы?yè)面
這篇文章主要介紹了詳解Android 手機(jī)衛(wèi)士設(shè)置向?qū)ы?yè)面的相關(guān)資料,需要的朋友可以參考下2016-04-04