Android 高仿微信(QQ)滑动弹出编辑、删除菜单效果,增加下拉刷新功能-阿里云开发者社区

开发者社区> 无名公子> 正文

Android 高仿微信(QQ)滑动弹出编辑、删除菜单效果,增加下拉刷新功能

简介:
+关注继续查看

  不可否认,微信、QQ列表的滑动删除、编辑功能着实很经典(从IOS那边模仿过来的),然、Android这边,对列表的操作,其实大多还停留上下文菜单来实现。 

  Android如何实现list item的滑动呢?介绍一个很简单实用的开源项目:

  https://github.com/baoyongzhang/SwipeMenuListView

  使用该开源项目,我们只需要很简单的一些逻辑,就可以实现滑动菜单功能了!先看下效果图:

     



1. 下载开源项目,并将其中的liberary导入到自己的项目中:



2. 使用SwipeMenuListView代替ListView,在页面中布局:

    <android.support.v4.widget.SwipeRefreshLayout
        android:id="@+id/swipeRefreshMusic"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <com.baoyz.swipemenulistview.SwipeMenuListView
            android:id="@+id/listViewMusic"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />

    </android.support.v4.widget.SwipeRefreshLayout>

 注: SwipeRefreshLayout主要是为了给该列表增加下拉刷新功能!


3. 为该ListView创建适配器,与正常的实现并无二致:

public class MusicAdapter extends BaseAdapter {

    private List<Music> mDatas;

    private Context mContext;

    public MusicAdapter(List<Music> mDatas, Context mContext) {
        this.mDatas = mDatas;
        this.mContext = mContext;
    }

    @Override
    public int getCount() {
        return mDatas.size();
    }

    @Override
    public Music getItem(int position) {
        return mDatas.get(position);
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        if (convertView == null) {
            convertView = View.inflate(mContext, R.layout.list_item_music, null);
            new ViewHolder(convertView);
        }

        ViewHolder holder = (ViewHolder) convertView.getTag();

        Music music = mDatas.get(position);

        holder.textTitle.setText(music.title);
        holder.textDesc.setText(music.desc);

        return convertView;
    }

    class ViewHolder {
        TextView textTitle;
        TextView textDesc;

        public ViewHolder(View view) {
            textTitle = (TextView) view.findViewById(R.id.textTitle);
            textDesc = (TextView) view.findViewById(R.id.textDesc);
            view.setTag(this);
        }
    }
}


4. 为SwipeMenuListView实现Adapter,并在之后,创建滑动菜单:

public class MainActivity extends AppCompatActivity {

    @ViewInject(R.id.listViewMusic)
    private SwipeMenuListView listViewMusic;

    @ViewInject(R.id.swipeRefreshMusic)
    private SwipeRefreshLayout swipeRefreshMusic;

    private List<Music> musics;

    private MusicAdapter musicAdapter;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        x.view().inject(this);
        musics = new ArrayList<>();

        for (int i = 0; i < 4; i++) {

            Music music = new Music();
            music.title = "上邪 : " + i;
            music.desc = "我欲与君相知,长命无绝衰";
            musics.add(music);
        }

        musicAdapter = new MusicAdapter(musics, this);
        listViewMusic.setAdapter(musicAdapter);

        SwipeMenuCreator swipeMenuCreator = new SwipeMenuCreator() {
            @Override
            public void create(SwipeMenu menu) {
                // create "edit" item
                SwipeMenuItem editItem = new SwipeMenuItem(
                        getApplicationContext());
                // set item background
                editItem.setBackground(new ColorDrawable(Color.rgb(0xC9, 0xC9,
                        0xCE)));
                // set item width
                editItem.setWidth(dp2px(90));
                // set item title
                editItem.setTitle("编辑");
                // set item title fontsize
                editItem.setTitleSize(18);
                // set item title font color
                editItem.setTitleColor(Color.WHITE);
                // add to menu
                menu.addMenuItem(editItem);

                // create "edit" item
                SwipeMenuItem deleteItem = new SwipeMenuItem(
                        getApplicationContext());
                // set item background
                deleteItem.setBackground(new ColorDrawable(Color.parseColor("#ff0000")));
                // set item width
                deleteItem.setWidth(dp2px(90));
                // set item title
                deleteItem.setTitle("删除");
                // set item title fontsize
                deleteItem.setTitleSize(18);
                // set item title font color
                deleteItem.setTitleColor(Color.WHITE);
                // add to menu
                menu.addMenuItem(deleteItem);
            }
        };

        listViewMusic.setMenuCreator(swipeMenuCreator);

        listViewMusic.setOnMenuItemClickListener(new SwipeMenuListView.OnMenuItemClickListener() {
            @Override
            public boolean onMenuItemClick(int position, SwipeMenu menu, int index) {
                switch (index) {// index即是操作menu添加的顺序
                    case 0:
                        Toast.makeText(MainActivity.this, "编辑 : " + position, Toast.LENGTH_SHORT).show();
                        break;
                    case 1:
                        Toast.makeText(MainActivity.this, "删除 : " + position, Toast.LENGTH_SHORT).show();
                        musics.remove(position);
                        musicAdapter.notifyDataSetChanged();
                        break;
                }

                return false;
            }
        });

        swipeRefreshMusic.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
            @Override
            public void onRefresh() {

                swipeRefreshMusic.setRefreshing(true);
                new Handler().postDelayed(new Runnable() {
                    @Override
                    public void run() {

                        for (int i = 0; i < 4; i++) {

                            Music music = new Music();
                            music.title = "无缘 : " + i;
                            music.desc = "风雨千山玉独行,天下倾心叹无缘";
                            musics.add(music);
                        }
                        musicAdapter.notifyDataSetChanged();

                        swipeRefreshMusic.setRefreshing(false);
                    }
                }, 2000);

            }
        });
    }

    private int dp2px(int dp) {
        return (int) TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, dp,
                getResources().getDisplayMetrics());
    }
}

注: 

  1. SwipeMenuCreator是为了给该listitem创建菜单使用,需要实现该的接口中的create方法,在该方法中,可以自由创建菜单项,比如删除、编辑,可以设置菜单的背景颜色,字体颜色大小等; 

  2. 在创建SwipeMenuCreator实例后,需为列表设置菜单:listViewMusic.setMenuCreator(swipeMenuCreator);

  3. 通过设置SwipeMenuListView的setOnMenuItemClickListener方法,监听菜单的点击事件,通过onMenuItemClick(int position, SwipeMenu menu, int index)方法,对菜单事件进行处理;

  4. 通过设置SwipeMenuListView的setOnRefreshListener方法,为菜单添加下拉刷新功能!


如此这般,便可完美的实现的list item滑动编辑删除功能啦,欢迎指正!

如有疑问,欢迎进QQ群:487786925( Android研发村 )



源码下载地址:https://github.com/zuiwuyuan/SwipeRefreshStickyList  

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
用PS设计等高线效果的背景图片
有些简单的单网页,如果利用等高线效果的背景图片,再配合合适的背景色,能达到绚丽的效果。如下图所示:   本文就介绍该等高线效果的背景图片是如何制作的。Follow Me!!!!   1、新建文档,尺寸:1000px*1000px   2、用矩形工具创建一个矩形,尺寸:500px*...
672 0
Case7 FreeSwitch配置开启转码功能及安装G729语音编码
FreeSwitch配置开启转码功能及安装G729语音编码
516 0
在GitHub上删除项目后,在Android Studio上传项目依然提示project is already on github
描述: 在GitHub上面上传项目,但是感觉有些问题,就想删除了重新上传。 但是在Android Studio重新上传项目时,遇到了问题,一直提示“project is already on github”   解决方案: 1、关闭Android Studio项目;   2、进入到本地项目目录,找到隐藏文件夹.
1217 0
+关注
122
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载