這篇文章主要介紹了Android怎么自定義View圓形和拖動(dòng)圓實(shí)現(xiàn)跟隨手指拖動(dòng)效果的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇Android怎么自定義View圓形和拖動(dòng)圓實(shí)現(xiàn)跟隨手指拖動(dòng)效果文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。
創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括朝天網(wǎng)站建設(shè)、朝天網(wǎng)站制作、朝天網(wǎng)頁(yè)制作以及朝天網(wǎng)絡(luò)營(yíng)銷策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,朝天網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到朝天省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!我在第一次自定義View圓遇到的幾個(gè)Bug:
1.拖動(dòng)圓的話在xml里面設(shè)置的自定義圓的寬和高是它能活動(dòng)的空間的大小 不是圓控件的大小 如果你定義了100dp 拖動(dòng)它的時(shí)候超過100dp這個(gè)距離這個(gè)圓就會(huì)看不見 就像下面這樣 如果想活動(dòng)于整個(gè)屏幕直接給寬和高match_parent
屬性就好了
2.我在定義充滿屬性match_parent
的時(shí)候運(yùn)行會(huì)報(bào)錯(cuò),什么方法都用了就是不行,耐心等待過一會(huì)就好了…有可能是studio沒來(lái)得及編譯過來(lái)
下面開始寫代碼: 先是單純的創(chuàng)建一個(gè)圓形 創(chuàng)建一個(gè)類繼承View 實(shí)現(xiàn)onDraw方法
public class CustomView extends View { //創(chuàng)建point對(duì)象 參數(shù)為x坐標(biāo)和y坐標(biāo) private PointF point = new PointF(100, 100); public CustomView(Context context) { super(context); } public CustomView(Context context, @Nullable AttributeSet attrs) { super(context, attrs); } public CustomView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); //參數(shù)為圓的橫坐標(biāo) ,縱坐標(biāo),半徑,創(chuàng)建 canvas.drawCircle(point.x,point.y, 50, new Paint()); } }
XML里、自己定義的view類的名字:
一個(gè)圓就這樣創(chuàng)建好了 直接運(yùn)行就可以了 ManActivity里什么也不用改
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); }
下面是添加拖動(dòng)圓的功能 非常簡(jiǎn)單 實(shí)現(xiàn)觸摸監(jiān)聽即可 代碼非常少 如下:
public class CustomView extends View { //創(chuàng)建point對(duì)象 參數(shù)為x坐標(biāo)和y坐標(biāo) private PointF point = new PointF(100, 100); public CustomView(Context context) { super(context); } public CustomView(Context context, @Nullable AttributeSet attrs) { super(context, attrs); } public CustomView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); //參數(shù)為圓的橫坐標(biāo) ,縱坐標(biāo),半徑,創(chuàng)建 canvas.drawCircle(point.x,point.y, 50, new Paint()); } //觸摸事件 @Override public boolean onTouchEvent(MotionEvent event) { //獲得觸摸事件 switch (event.getAction()) { case MotionEvent.ACTION_DOWN: break; //ACTION_MOVE不要設(shè)置break,否則圓形不會(huì)跟隨手指活動(dòng) 只會(huì)手指松開屏幕的時(shí)候圓形直接到了屏幕停止的位置 case MotionEvent.ACTION_MOVE: case MotionEvent.ACTION_UP: //獲取手指觸摸位置的x坐標(biāo) point.x = event.getX(); //獲取手指觸摸位置的y坐標(biāo) point.y = event.getY(); //啟動(dòng) postInvalidate(); break; } return true; } }
關(guān)于“Android怎么自定義View圓形和拖動(dòng)圓實(shí)現(xiàn)跟隨手指拖動(dòng)效果”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“Android怎么自定義View圓形和拖動(dòng)圓實(shí)現(xiàn)跟隨手指拖動(dòng)效果”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。