android viewpager實現(xiàn)豎直滑動效果
做過android開發(fā)的朋友們,一定知道viewpager是什么,但是viewpager只能水平滑動?,F(xiàn)在有的項目引導(dǎo)頁也開始使用豎直滑動,這個時候viewpager就不能幫到我們了,怎么辦?只有自定義了,今天就簡單講下viewpager豎直滑動的實現(xiàn),但是這是告訴大家怎么實現(xiàn),具體肯定不能用于真實項目中,因為還有些細(xì)節(jié)沒處理,只是給大家講個思路而已!
首先新建一個android項目叫:Customviewpager
我們也知道viewpager也是繼承了ViewGroup類的,在這里我們寫一個CustomViewPager類也繼承了ViewGroup。
其實代碼很少,先貼代碼然后講解:
CustomViewPager.java
public class CustomViewPager extends ViewGroup { private static final String TAG = CustomViewPager.class.getSimpleName(); private float startX = 0; private GestureDetector detector; int a = 30; public CustomViewPager(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } public CustomViewPager(Context context, AttributeSet attrs) { super(context, attrs); init(context); } private void init(Context context) { detector = new GestureDetector(context, new GestureDetector.SimpleOnGestureListener(){ /** * distanceX 在屏幕上要移動的距離 而不是坐標(biāo) */ @Override public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) { scrollBy(0, (int)distanceY); return true; } }); } public CustomViewPager(Context context) { super(context); } @Override protected void onLayout(boolean changed, int l, int t, int r, int b) { for(int i=0;i<getChildCount();i++){ View childView = getChildAt(i); // childView.layout(i*getWidth(), 0, (i+1)*getWidth(), getHeight());、//這是水平方向滑動 childView.layout(0, i*getHeight(), getWidth(), (i+1)*getHeight());//這是豎直方向滑動 } } /** * 這個默認(rèn)super.onTouchEvent(event)為false */ @Override public boolean onTouchEvent(MotionEvent event) { detector.onTouchEvent(event); return true; } }
MainActivity.java
public class MainActivity extends ActionBarActivity { private CustomViewPager custom_view_pager; private int[] ids = {R.drawable.a1,R.drawable.a2,R.drawable.a3,R.drawable.a4,R.drawable.a5,R.drawable.a6}; private List<ImageView> imageViews; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); DisplayUtil.init(this); custom_view_pager = (CustomViewPager) findViewById(R.id.custom_view_pager); initData(); } private void initData() { imageViews = new ArrayList<>(); for(int i=0;i<ids.length;i++){ ImageView imageView = new ImageView(this); imageView.setBackgroundResource(ids[i]); imageViews.add(imageView); custom_view_pager.addView(imageView); } } }
這就可以了,再貼下布局文件
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="fill_parent" android:layout_height="fill_parent" > <zhi.more.customviewpager.view.CustomViewPager android:id="@+id/custom_view_pager" android:layout_width="fill_parent" android:layout_height="fill_parent" /> </RelativeLayout>
這里注意下:onTouchEvent()這個方法返回值。返回true和false有啥區(qū)別。簡單的說下
返回true表示自己處理了這個滑動事件。返回false表示傳遞給子view,而當(dāng)前這個父view就不再持有這個滑動事件了,想很好了解這個問題,就設(shè)計到view事件傳遞了,大家可以通過在down,move,up下返回不同的值,打log去分析原理,,在這里就不講解了。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android利用ViewPager實現(xiàn)滑動廣告板實例源碼
- Android App中ViewPager所帶來的滑動沖突問題解決方法
- Android App中使用ViewPager+Fragment實現(xiàn)滑動切換效果
- Android中ViewPager帶來的滑動卡頓問題解決要點解析
- Android開發(fā)之使用ViewPager實現(xiàn)圖片左右滑動切換效果
- Android ViewPager無限循環(huán)實現(xiàn)底部小圓點動態(tài)滑動
- android配合viewpager實現(xiàn)可滑動的標(biāo)簽欄示例分享
- Android利用ViewPager實現(xiàn)可滑動放大縮小畫廊效果
- android viewpager實現(xiàn)豎屏滑動效果
- Android自定義ViewPager實現(xiàn)縱向滑動翻頁效果
相關(guān)文章
Android中asset文件夾與raw文件夾的區(qū)別深入解析
本篇文章是對Android中的asset文件夾與raw文件夾區(qū)別進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06Android 開發(fā) 使用WebUploader解決安卓微信瀏覽器上傳圖片中遇到的bug
這篇文章主要介紹了Android 開發(fā) 使用WebUploader解決安卓微信瀏覽器上傳圖片中遇到的bug問題,本文給介紹的非常詳細(xì),需要的朋友可以參考下2016-11-11Android開發(fā)仿QQ空間根據(jù)位置彈出PopupWindow顯示更多操作效果
我們打開QQ空間的時候有個箭頭按鈕點擊之后彈出PopupWindow會根據(jù)位置的變化顯示在箭頭的上方還是下方,比普通的PopupWindow彈在屏幕中間顯示好看的多,今天就給大家分享下實現(xiàn)代碼,需要的朋友參考下吧2016-12-12