因為最近項目的需要,需要實現(xiàn)一個拖動效果,看了一下網上剛好有這種拖動效果的demo,代碼大概如下:
十載的晉江網站建設經驗,針對設計、前端、開發(fā)、售后、文案、推廣等六對一服務,響應快,48小時及時工作處理。成都全網營銷的優(yōu)勢是能夠根據(jù)用戶設備顯示端的尺寸不同,自動調整晉江建站的顯示方式,使網站能夠適用不同顯示終端,在瀏覽器中調整網站的寬度,無論在任何一種瀏覽器上瀏覽網站,都能展現(xiàn)優(yōu)雅布局與設計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯(lián)建站從事“晉江網站設計”,“晉江網站推廣”以來,每個客戶項目都認真落實執(zhí)行。
private void initListener(){ screenWidth = getScreenWidth(this);//獲取屏幕寬度 screenHeight = getScreenHeight(this) - getStatusHeight(MainActivity.this);//屏幕高度-狀態(tài)欄 testTv.setOnTouchListener(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { switch (event.getAction()) { case MotionEvent.ACTION_DOWN: lastX = (int) event.getRawX(); lastY = (int) event.getRawY(); break; case MotionEvent.ACTION_MOVE: int dx = (int) event.getRawX() - lastX; int dy = (int) event.getRawY() - lastY; int top = v.getTop() + dy; int left = v.getLeft() + dx; if (top <= 0) { top = 0; } if (top >= screenHeight - testTv.getHeight() ) { top = screenHeight - testTv.getHeight(); } if (left >= screenWidth - testTv.getWidth()) { left = screenWidth - testTv.getWidth(); } if (left <= 0) { left = 0; } v.layout(left, top, left+v.getWidth(), top+v.getHeight()); v.postInvalidate(); lastX = (int) event.getRawX(); lastY = (int) event.getRawY(); break; case MotionEvent.ACTION_UP: break; } return true;//這里根據(jù)項目需要選擇false與true } }); }
可是我的項目本身是有涂鴉的界面,還有很多復雜的事件,發(fā)現(xiàn)會有很奇怪的效果,抖動很厲害,而且時不時回到原來的位置,后來發(fā)現(xiàn)這個v.layout(left, top, left+v.getWidth(), top+v.getHeight());可能不適合項目的需求,所以我想了另一種解法。代碼如下:
private void initListener(){ screenWidth = getScreenWidth(this);//獲取屏幕寬度 screenHeight = getScreenHeight(this) - getStatusHeight(MainActivity.this);//屏幕高度-狀態(tài)欄 testTv.setOnTouchListener(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { switch (event.getAction()) { case MotionEvent.ACTION_DOWN: lastX = (int) event.getRawX(); lastY = (int) event.getRawY(); break; case MotionEvent.ACTION_MOVE: int dx = (int) event.getRawX() - lastX; int dy = (int) event.getRawY() - lastY; int top = v.getTop() + dy; int left = v.getLeft() + dx; if (top <= 0) { top = 0; } if (top >= screenHeight - testTv.getHeight() ) { top = screenHeight - testTv.getHeight(); } if (left >= screenWidth - testTv.getWidth()) { left = screenWidth - testTv.getWidth(); } if (left <= 0) { left = 0; } RelativeLayout.LayoutParams param = new RelativeLayout.LayoutParams(v.getWidth(), v.getHeight()); param.leftMargin = left; param.topMargin = top; v.setLayoutParams(param); // v.layout(left, top, left+v.getWidth(), top+v.getHeight()); v.postInvalidate(); lastX = (int) event.getRawX(); lastY = (int) event.getRawY(); break; case MotionEvent.ACTION_UP: break; } return true; } }); }
效果如下圖:
覺得可以了,不過要注意一些事項:鍵盤彈出需要自己處理一下(比如處理成彈出鍵盤就不能移動這些,不然會變形的),我覺得這種寫法可以應用于各種復雜的場景。好了,今天一些項目問題總結就到這里了,希望對大家有幫助,代碼也上傳了,地址如下:Android實現(xiàn)拖動效果
以上所述是小編給大家介紹Android實現(xiàn)拖動效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網站的支持!
網站標題:Android實現(xiàn)拖動效果的兩種方法
本文來源:http://www.chinadenli.net/article2/gepdic.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供做網站、自適應網站、微信小程序、網頁設計公司、品牌網站制作、響應式網站
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)