利用DrawerLayout和触摸事件分发来实现抽屉侧滑业务
来源:互联网 发布:淘宝导航条自定义图片 编辑:程序博客网 时间:2024/05/20 23:31
效果展示
还是看代码实在,直接上菜了。
1.MainActivity的代码:
public class MainActivity extends AppCompatActivity implements MyDraweLayout.GetPositionCallback { private List<ImageView> imageList; private ViewPager viewPager; private MyAdapter adapter; private MyDraweLayout myDraweLayout; private int currentPosition; @Override protected void onCreate (Bundle savedInstanceState){ super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); viewPager = (ViewPager) findViewById(R.id.viewpager); myDraweLayout = (MyDraweLayout) findViewById(R.id.mydrawelayout); initdata(); adapter = new MyAdapter(this, imageList); myDraweLayout.setCallback(this); viewPager.setAdapter(adapter); viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() { @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { } @Override public void onPageSelected(int position) { currentPosition=position; } @Override public void onPageScrollStateChanged(int state) { } }); } private void initdata() { imageList = new ArrayList<ImageView>(); ImageView imageView = new ImageView(this); imageView.setImageResource(R.mipmap.ic_launcher); imageView.setScaleType(ImageView.ScaleType.FIT_XY); imageList.add(imageView); imageView = new ImageView(this); imageView.setImageResource(R.mipmap.ic_launcher); imageView.setScaleType(ImageView.ScaleType.FIT_XY); imageList.add(imageView); imageView = new ImageView(this); imageView.setImageResource(R.mipmap.ic_launcher); imageView.setScaleType(ImageView.ScaleType.FIT_XY); imageList.add(imageView); imageView = new ImageView(this); imageView.setImageResource(R.mipmap.ic_launcher); imageView.setScaleType(ImageView.ScaleType.FIT_XY); imageList.add(imageView); } @Override public int position() { return currentPosition;//TODO 通过接口回调把当前位置传到MyDraweLayout中 }}
2.MyDraweLayout类中的代码:
public class MyDraweLayout extends DrawerLayout { public MyDraweLayout(Context context) { super(context); } public MyDraweLayout(Context context, AttributeSet attrs) { super(context, attrs); } public MyDraweLayout(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } //TODO 事件拦截 @Override public boolean onInterceptTouchEvent(MotionEvent ev) { //Todo 获得当前位置,进行判断 if(callback.position()==0){ return super.onInterceptTouchEvent(ev); }else { return false; } } public interface GetPositionCallback{ int position(); } private GetPositionCallback callback; public void setCallback(GetPositionCallback callback){ this.callback = callback; }}
3.适配器的代码;
public class MyAdapter extends PagerAdapter { private final List<ImageView> imageList; private final Context contex; public MyAdapter(Context context, List<ImageView> imageList) { this.contex=context; this.imageList = imageList; } @Override public int getCount() { return imageList.size(); } @Override public boolean isViewFromObject(View view, Object object) { return view==object; } @Override public Object instantiateItem(ViewGroup container, int position) { ImageView imageView = imageList.get(position); container.addView(imageView); return imageView; } @Override public void destroyItem(ViewGroup container, int position, Object object) { //super.destroyItem(container, position, object);这行代码记得删除,不然滑到Viewpager的时候会闪退哦 container.removeView(imageList.get(position)); }}
4.xml布局:
<?xml version="1.0" encoding="utf-8"?><com.example.a43_drawelayoutandviewpager.MyDraweLayout android:id="@+id/mydrawelayout" xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"><RelativeLayout android:layout_width="match_parent" android:layout_height="match_parent"> <android.support.v4.view.ViewPager android:layout_width="match_parent" android:layout_height="250dp" android:id="@+id/viewpager"/> </RelativeLayout> <ImageView android:background="@mipmap/ic_launcher" android:layout_width="300dp" android:layout_gravity = "start" android:layout_height="match_parent" android:layout_below="@+id/viewpager" /></com.example.a43_drawelayoutandviewpager.MyDraweLayout>
0 0
- 利用DrawerLayout和触摸事件分发来实现抽屉侧滑业务
- 利用DrawerLayout实现侧滑抽屉的功能
- 利用DrawerLayout实现侧划栏、抽屉
- MaterialDesign之NavigationView和DrawerLayout实现侧滑菜单栏(抽屉)
- MaterialDesign之NavigationView和DrawerLayout实现侧滑菜单栏(抽屉)
- DrawerLayout和NavigationView轻松实现抽屉侧滑
- DrawerLayout和NavigationView轻松实现抽屉侧滑
- 利用DrawerLayout实现简单的抽屉效果
- 抽屉DrawerLayout onBackPressed事件
- ToolBar+DrawerLayout实现左右双布局侧滑和动画返回控制显示抽屉布局
- DrawerLayout 和NavigationView 实现抽屉式侧滑
- Android侧滑菜单DrawerLayout(抽屉布局)实现
- Android侧滑菜单DrawerLayout(抽屉布局)实现
- Android实现侧滑抽屉菜单(DrawerLayout+NavigationView+toolbar)
- 侧滑菜单(抽屉效果)DrawerLayout实现原理
- Kotlin实现侧滑抽屉菜单(DrawerLayout+NavigationView+Toolbar)
- DrawerLayout实现抽屉效果
- DrawerLayout来实现头部固定的抽屉效果的框架
- 禁止页面Body在后台滚动
- iOS 中单例的使用以及原理
- 优秀程序员的十个习惯
- 更改Windows命令行字体
- solr4.7新建core
- 利用DrawerLayout和触摸事件分发来实现抽屉侧滑业务
- Android 内部存储和Cache简单介绍
- 自定义基类BaseActivity,节省开发步骤
- LeetCode-334.Increasing Triplet Subsequence
- Charged view 0x7f9fb9568c80 was still registered to a window when it was deallocated.
- HDBSQL-命令行模式执行SQL
- easyui的datagrid整合struts2,以及Ajax,实现局部刷新功能,并设置分页的实现---------投票案例
- AspectJ org.aspectj.tools.ajc
- ibatis(0)ibatis 与 mybatis 简述