欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Android实现动态定值范围效果的控件

程序员文章站 2024-03-06 13:07:49
先来看看效果: 一、添加依赖库的步骤 1.项目的gradle文件内的做以下改动 allprojects { repositories {...

先来看看效果:

Android实现动态定值范围效果的控件

一、添加依赖库的步骤

1.项目的gradle文件内的做以下改动

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

2.添加最新版本的依赖库,最新版本如右所示,修改末尾的版本即可(因为我有时候更新版本了会忘记修改readme)

dependencies {
   compile 'com.github.brioal:brioalsetting:1.0'
   ////例如上面最新版本是1.1,则只要把1.0改成1.1即可使用最新版本
 }

二、使用步骤:

1.xml布局文件

实际使用过程中发现如果与其他组件在一起,则滑动事件会实效,暂时没发现代码里面怎么解决,设置focus啥的都没用,暂时的解决办法是给组件添加一个父布局并且不包含其他组件即可,如下:

<linearlayout
  android:id="@+id/layout"
android:layout_centerinparent="true"
  android:layout_width="match_parent"
  android:layout_height="wrap_content">
  <com.brioal.rangeseek.view.rangebar
   android:id="@+id/main_container"
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:layout_centerinparent="true"/>

 </linearlayout>

2.代码设置

mrangebar = (rangebar) findviewbyid(r.id.main_container);
   //添加数据源
  final list<rangeentity> list = new arraylist<>();
  //要显示的文字和实际的值,分别是string 和 object类型
  list.add(new rangeentity("15℃", 15));
  list.add(new rangeentity("18℃", 18));
  list.add(new rangeentity("21℃", 21));
  list.add(new rangeentity("24℃", 24));
  list.add(new rangeentity("27℃", 27));
  list.add(new rangeentity("30℃", 30));
  //设置数据源
  mrangebar.setvalues(list);
  //添加范围改变监听器
  mrangebar.addonrangechangedlistener(new onrangechangedlistener() {
   @override
   public void selected(int startindex, int endindex) {
   //获取到的是起始和终止的数据在list中所对应的下标
    mtvmin.settext(list.get(startindex).getvalue() + "");
    mtvmax.settext(list.get(endindex).getvalue() + "");
   }
  });

3.提供的供自定义视图的方法

方法 功能
void addonrangechangedlistener(onrangechangedlistener listener) 设置事件监听器
void setlinecolor(int linecolor) 设置中间的线条颜色
void setlinewidth(int linewidth) 设置中间的线条宽度
void setcirclecolor(int circlecolor) 设置圆点的边框颜色
void setcircleradius(int circleradius) 设置圆点的半径
void setcirclewidth(int circlewidth) 设置圆点的线条宽度
void setcentercolor(int centercolor) 设置选中的圆点的填充颜色
void setpointcolor(int pointcolor) 设置游标的填充颜色
void setstartindex(int startindex) 设置选中的起始下标
int getstartindex() 获取选中的起始下标
void setendindex(int endindex) 设置终止下标
int getendindex() 获取终止的下标

总结

以上就是这篇文章的全部内容,希望本文能对大家的学习或者工作带来一定的帮助,如果有疑问大家可以留言交流。