/PopupView

自定义下拉选择框,简单易用,自带默认动画,支持各个方向弹出,支持多种注入数据方式

Primary LanguageJava

PopupView

image

Add it in your root build.gradle at the end of repositories:

Step 1:

  allprojects {
	  repositories {
		  ...
		  maven { url 'https://jitpack.io' }
	  }
  }

Step 2:

dependencies {
        implementation 'com.github.wbaizx:PopupView:1.3.3'
}

最简单用法:

<com.library.PopupView xmlns:att="http://schemas.android.com/apk/res-auto"
    android:id="@+id/popup"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerInParent="true"
    att:menuRes="@menu/test2"
    att:listItemHeight="40dp"/>

其他参数用法:

<com.library.PopupView xmlns:att="http://schemas.android.com/apk/res-auto"
    android:id="@+id/popup"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerInParent="true"
    att:arrayRes="@array/test3"
    att:direction="down"
    att:dividerHeight="5dp"
    att:popupDrawable="@drawable/a"
    att:rightDrawable="@drawable/b"
    att:hideSelected="false"
    att:horizontalWidth="200dp"
    att:itemFontSize="12sp"
    att:itemTextColor="@color/colorPrimary"
    att:itemTextGravity="left"
    att:popupTextColor="#f90606"
    att:itemTextSelectColor="#FF4081"
    att:listItemHeight="50dp"
    att:maxNum="4"
    att:menuRes="@menu/test2"
    att:needDivider="true"
    att:textViewSize="15sp" />

解释各个参数作用

    listItemHeight:item布局高度,可以不设置
    maxNum:最大显示行数,只有设置了listItemHeight才能生效
    arrayRes:注入数组资源
    rightDrawable:箭头图片资源
    direction:弹出方向
    dividerHeight:分割线高度
    hideSelected:是否隐藏当前选中项,默认false
    menuRes:menu资源注入
    itemFontSize:item字体大小
    needDivider:是否需要分割线,默认true
    popupDrawable:下拉菜单背景,注意设置此项后可能弹出框阴影消失
    textViewSize:PopupView字体大小,控件宽度能根据大小自适应,若在代码中使用set方法设置,则控件大小不能对应改变
    horizontalWidth:水平方向弹出时弹出框宽度
    itemTextGravity:弹出框字体对齐方式
    itemTextSelectColor:弹出框选中项字体颜色
    itemTextColor:弹出框未选中项字体颜色
    popupTextColor:popup字体颜色

xml中的各种参数设置一般都可以在代码中完成(如果没有对应set方法,就是我忘了),介绍一下代码中的不同地方

注入数据有三种方式:

通过一项一项注入数据,其中PoputItem构造方法有三种,参见源码

    popup.addItems(new PoputItem("11"));
    popup.addItems(new PoputItem(ContextCompat.getDrawable(this, R.mipmap.ic_launcher_round)));
    popup.addItems(new PoputItem("22", ContextCompat.getDrawable(this, R.mipmap.ic_launcher_round)));

通过menu菜单注入

      popup.setItemsFromMenu(this, R.menu.aaaa);

通过List列表注入:

    List<CharSequence> stringList = new ArrayList<>();
    stringList.add("55");
    popup.setItemsFromList(stringList);

设置默认选中项,小于0或大于数据长度则默认选中第一项:

    popup.setPostion();

获取当前选中位置

    popup.getNowPosition();

获取当前选中位置文本

    popup.getNowText();

清空当前设置的数据,然后可以重新添加数据,用于更新

    popup.clearData();

设置点击监听,返回值如果对应项有id则返回对应id,没有返回-1,position表示在数据中的索引,title表示对应文本信息

    popup.setOnItemClickListener(new OnPopupItemClickListener() {
        @Override
        public void onItemClickListener(int id, int position, CharSequence title) {
        }
    });

设置关闭监听

    popup.setOnDismissListener(new OnDismissListener() {
        @Override
        public void onDismissListener() {
        }
    });