网络公司做网站后期注意,健康湖州网站,营销推广的形式包括,邮箱号怎么注册版权声明#xff1a;本文为博主原创文章#xff0c;转载请标明出处。 https://blog.csdn.net/lyhhj/article/details/50612714 绪论#xff1a; 好久没写博客了#xff0c;最近比较懒#xff0c;不想写博客#xff0c;但是在看书#xff0c;看一些Android进阶的书#… 版权声明本文为博主原创文章转载请标明出处。 https://blog.csdn.net/lyhhj/article/details/50612714 绪论 好久没写博客了最近比较懒不想写博客但是在看书看一些Android进阶的书这里小编也给大家推荐几本适合进阶的书相信会对你有所帮助的。 1.《Android群英传》 —徐宜生 2.《Android开发艺术探索》 —任玉刚 3.《Android源码设计模式》 —何红辉郭爱民 以上几本是针对Android开发所用的如果上面三本你都吃透了的话相信你就可以在Android的世界里尽情的翱翔了。 下面的几本是一些在你编程之路上必不可少的几本经典的书 1.《代码整洁之道》 2.《重构改善有代码的设计》 3.《MacTalk跨越边界》 好了下面进入正题吧今天小编给大家分享的是仿QQ聊天实现左滑效果先看一下效果吧 实现 1.定义滑动选项视图 通过监听滑动手势弹出滑动选项卡前提是先创建好选项卡 这里只贴出核心代码 public boolean onSwipe(MotionEvent event) {mGestureDetector.onTouchEvent(event);switch (event.getAction()) {case MotionEvent.ACTION_DOWN:mDownX (int) event.getX();isFling false;break;case MotionEvent.ACTION_MOVE:int dis (int) (mDownX - event.getX());if (state STATE_OPEN) {dis mMenuView.getWidth();}swipe(dis);break;case MotionEvent.ACTION_UP:if (isFling || (mDownX - event.getX()) (mMenuView.getWidth() / 2)) {// 打开选项卡smoothOpenMenu();} else {// 关闭选项卡smoothCloseMenu();return false;}break;}return true;} 2.创建选项卡 public void createMenu(SwipeMenu menu) {// Test CodeSwipeMenuItem item new SwipeMenuItem(mContext);item.setTitle(Item 1);item.setBackground(new ColorDrawable(Color.GRAY));item.setWidth(300);menu.addMenuItem(item);item new SwipeMenuItem(mContext);item.setTitle(Item 2);item.setBackground(new ColorDrawable(Color.RED));item.setWidth(300);menu.addMenuItem(item);} 3.将选项卡添加到布局中 private void addItem(SwipeMenuItem item, int id) {LayoutParams params new LayoutParams(item.getWidth(),LayoutParams.MATCH_PARENT);LinearLayout parent new LinearLayout(getContext());parent.setId(id);parent.setGravity(Gravity.CENTER);parent.setOrientation(LinearLayout.VERTICAL);parent.setLayoutParams(params);parent.setBackgroundDrawable(item.getBackground());parent.setOnClickListener(this);addView(parent);if (item.getIcon() ! null) {parent.addView(createIcon(item));}if (!TextUtils.isEmpty(item.getTitle())) {parent.addView(createTitle(item));}} 4.Activity中调用 ISwipeMenuCreator creator new ISwipeMenuCreator() {Overridepublic void create(SwipeMenu menu) {// 创建滑动选项SwipeMenuItem showItem new SwipeMenuItem(getApplicationContext());// 设置选项背景showItem.setBackground(new ColorDrawable(Color.rgb(0xC9, 0xC9,0xCE)));// 设置选项宽度showItem.setWidth(HankkinUtil.dp2px(90,MainActivity.this));// 设置选项标题showItem.setTitle(Show);// 设置选项标题showItem.setTitleSize(18);// 设置选项标题颜色showItem.setTitleColor(Color.WHITE);// 添加选项menu.addMenuItem(showItem);// 创建删除选项SwipeMenuItem deleteItem new SwipeMenuItem(getApplicationContext());deleteItem.setBackground(new ColorDrawable(Color.rgb(0xF9,0x3F, 0x25)));deleteItem.setWidth(HankkinUtil.dp2px(90, MainActivity.this));deleteItem.setIcon(R.drawable.ic_delete);menu.addMenuItem(deleteItem);}};menuListView.setMenuCreator(creator); 5.选项卡点击事件 menuListView.setOnMenuItemClickListener(new SwipeMenuListView.OnMenuItemClickListener() {Overridepublic void onMenuItemClick(int position, SwipeMenu menu, int index) {switch (index) {case 0: //第一个选项HankkinUtil.showToast(MainActivity.this, data.get(position).getTitle());break;case 1: //第二个选项data.remove(position);adapter.notifyDataSetChanged();break;}}}); 代码中的下拉刷新上拉加载小编是用的SwipeRefreshLayout 源码小编已经传到Github上了 https://github.com/Hankkin/MultiPurposeListView