日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Android >内容正文

Android

Android源码解析--SwipeMenuListView仿QQ聊天左滑

發布時間:2023/11/29 Android 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Android源码解析--SwipeMenuListView仿QQ聊天左滑 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
版權聲明:本文為博主原創文章,轉載請標明出處。 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

總結

以上是生活随笔為你收集整理的Android源码解析--SwipeMenuListView仿QQ聊天左滑的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。