Skip to content

【自定义View】仿网易新闻分类效果,拖拽排序,删除,点击,弹窗效果!

Notifications You must be signed in to change notification settings

Arisono/GridTagDragView

Repository files navigation

GridTagDragView

仿网易新闻app下拉标签选择菜单,长按拖动排序,点击增删标签控件

修复Bug

  • EasyTagDragView 基础之上优化改进的版本,再次感谢作者已经做了大部分贡献;这个原版本的bug有没有修复,你去clone下就知道了,估计是没有修复,你能发现不少问题;
  • tag太长导致显示出现bug
  • 表格控件嵌套在scrollview中的冲突问题
  • 带有选中tag分类效果
  • apk 文件在主目录下的apk文件夹下

##示例 introduce.gif

##EasyTagDragView的使用

在layout布局里添加:
<com.wenhuaijun.easytagdragview.EasyTipDragView
   android:id="@+id/easy_tip_drag_view"
   android:background="@android:color/white"
   android:layout_width="match_parent"
   android:layout_gravity="center"
   android:layout_height="match_parent"/>
   
在java代码中:
    给EasyTagDragView添加标签数据,包括已添加的标签数据和可添加的标签数据。
    添加的数据bean需继承SimpleTitleTip类,可自由增加成员属性。如没特殊需求,可直接使用提供的SimpleTitleTip类。
    注意每个tip的id必须唯一,不然拖拽会有bug
    
    //设置已添加的的标签数据
    easyTipDragView.setDragData(TipDataModel.getDragTips());
    
    //设置可以添加的标签数据
    easyTipDragView.setAddData(TipDataModel.getAddTips());
    
    //显示EasyTagDragView
    easyTipDragView.open();
    
    //在easyTipDragView处于非编辑模式下点击item的回调(编辑模式下点击item作用为删除item)
    easyTipDragView.setSelectedListener(new TipItemView.OnSelectedListener() {
        @Override
        public void onTileSelected(Tip entity, int position, View view) {
            toast(((SimpleTitleTip) entity).getTip());
        }
    });
    
    //设置每次数据改变后的回调(例如每次拖拽排序了标签或者增删了标签都会回调)
    easyTipDragView.setDataResultCallback(new EasyTipDragView.OnDataChangeResultCallback() {
        @Override
        public void onDataChangeResult(ArrayList<Tip> tips) {
            Log.i("heheda", tips.toString());
        }
    });
    
    //设置点击“确定”按钮后最终数据的回调
    easyTipDragView.setOnCompleteCallback(new EasyTipDragView.OnCompleteCallback() {
        @Override
        public void onComplete(ArrayList<Tip> tips) {
            toast("最终数据:" + tips.toString());
        }
    });
    
注:当已经显示EasyTagDragView的时候,需监听返回键,
    在编辑模式下点击返回键取消编辑模式。非编辑模式下则关闭EasyTagDragView
    
    
    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event) {
        switch (keyCode){
            //点击返回键
            case KeyEvent.KEYCODE_BACK:
                //判断easyTipDragView是否已经显示出来
                if(easyTipDragView.isOpen()){
                    if(!easyTipDragView.onKeyBackDown()){
                        btn.setVisibility(View.VISIBLE);//自己的业务逻辑
                    }
                    return true;
                }
                //....自己的业务逻辑

                break;
        }
        return super.onKeyDown(keyCode, event);
    }

后期增加更多自定义属性和一些API,将View放入popupWindow,增加过渡动画

About

【自定义View】仿网易新闻分类效果,拖拽排序,删除,点击,弹窗效果!

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages