android自己定义进度值可拖动的seekbar

近期忙找实习,加上实验室在推新项目,须要学习新知识。所以非常长一段时间没去整理了官博客了,github也蛮久没更新。非常羞愧。接下来还是要坚持写。

今天就简单的写一下我在项目中用到的算自己定义seekbar的博客,需求是这种。seekbar须要显示最左和最右值。进度要尾随进度块移动。

看下效果图就明确了。

事实上实现起来非常easy,主要是思路。

自己定义控件的话也不难,之前我的博客也有专门介绍,这里就不再多说。

实现方案

这里是通过继承seekbar来自己定义控件,这种方式最快。主要难点在于进度的显示,事实上我非常的是最笨的方法,就是用了一个popwindow显示在进度条的上方,然后在移动滑块的时候实时的改变它显示的横坐标。

看进度显示的核心代码:

private void initHintPopup(){

String popupText = null;

    if (mProgressChangeListener!=null){
        popupText = mProgressChangeListener.onHintTextChanged(this, cuclaProcess(leftText));
    }

    LayoutInflater inflater = (LayoutInflater)getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    final View undoView = inflater.inflate(R.layout.popup, null);
    mPopupTextView = (TextView)undoView.findViewById(R.id.text);
    mPopupTextView.setText(popupText!=null?

popupText : String.valueOf(cuclaProcess(leftText)));

   // mPopup.dismiss();
    if(mPopup == null)
        mPopup = new PopupWindow(undoView, mPopupWidth, ViewGroup.LayoutParams.WRAP_CONTENT, false);
    else{
        mPopup.dismiss();
        mPopup = new PopupWindow(undoView, mPopupWidth, ViewGroup.LayoutParams.WRAP_CONTENT, false);

    }
}

布局非常easy。就一个TextView。

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="horizontal"
    android:background="#0fff"
    android:gravity="center">
    <TextView android:id="@+id/text"
        android:padding="8dp"
        android:textSize="16sp"
        android:singleLine="true"
        android:ellipsize="end"
        android:textColor="@color/green"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"/>
</LinearLayout>

左右的显示值原理也是一样的。看以下代码:

 private void initRightText(){

     LayoutInflater inflater = (LayoutInflater)getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        final View undoView = inflater.inflate(R.layout.rightpop, null);
        mPopupRightView = (TextView)undoView.findViewById(R.id.righttext);
        mPopupRightView.setText(rightText+"");

        mRightPopup = new PopupWindow(undoView, mPopupWidth, ViewGroup.LayoutParams.WRAP_CONTENT, false);

        mRightPopup.setAnimationStyle(R.style.fade_animation);
   }

那么怎样让滑块上方的文字跟着滑动。仅仅要重写onProgressChanged就能够了。

 public void onProgressChanged(SeekBar seekBar, int progress, boolean b) {
        String popupText = null;
        if (mProgressChangeListener!=null){
            popupText = mProgressChangeListener.onHintTextChanged(this, cuclaProcess(leftText));
        }

        if(mExternalListener !=null){
            mExternalListener.onProgressChanged(seekBar, progress, b);
        }

        step = cuclaProcess(leftText);
        mPopupTextView.setText(popupText!=null?

popupText : String.valueOf(step));

        if(mPopupStyle==POPUP_FOLLOW){
            mPopup.update((int) (this.getX()+(int) getXPosition(seekBar)), (int) (this.getY()+2*mYLocationOffset+this.getHeight()), -1, -1);
        }

    }

事实上最基本的就是算出x的位置getXPosition。看以上代码:

   private float getXPosition(SeekBar seekBar){
        float val = (((float)seekBar.getProgress() * (float)(seekBar.getWidth() - 2 * seekBar.getThumbOffset())) / seekBar.getMax());
        float offset = seekBar.getThumbOffset()*2;

        int textWidth = mPopupWidth;
        float textCenter = (textWidth/2.0f);

        float newX = val+offset - textCenter;

        return newX;
    }

通过getProgress获得进度来计算x移动的距离。这样就实现了文字的移动。

最后会给出源代码下载。

怎样使用呢。跟普通自己定义的控件一样。例如以下:

<com.canmou.cm4restaurant.tools.SeekBarHint
        android:id="@+id/seekbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:layout_marginTop="40dp"
        android:progress="5"
        hint:popupWidth="40dp"
        hint:yOffset="10dp"
        hint:popupStyle="fixed"/>

当然眼下实现了原生的样式,以下来说说怎样自己定义seekbar的样式。

自己定义样式

seekbar要改样式得准备三张图片,左边己选择的滑动条图片,右边未选择的滑动条图片和滑块图片,滑动条要9.png格式的最好。这里为方便,直接用layer-list来处理滑动条部分。在drawable中定义xml文件。

<?xml version="1.0" encoding="utf-8"?>
    <layer-list xmlns:android="http://schemas.android.com/apk/res/android" >

  <item android:id="@android:id/background">
<shape >
          <corners android:radius="10dip" />
          <gradient
              android:angle="180"
              android:centerColor="#F5F5F5"
              android:centerY="0.2"
              android:endColor="#F5F5F5"
              android:startColor="#F5F5F5" />
      </shape>
  </item>

  <item android:id="@android:id/progress">
<clip >
          <shape >
              <corners android:radius="10dip"
               />
              <gradient
                  android:angle="180"

                  android:centerColor="#39ac69"
                  android:centerY="0.45"
                  android:endColor="#39ac69"
                  android:startColor="#39ac69" />

          </shape>
      </clip>
  </item>
</layer-list>

这样就实现了重叠的图片。设置滑块的图片则直接在seekhint中设置:

android:thumb="@drawable/bt_seekbar"

到此进度值可拖动的seekbar就实现了。

源代码下载

时间: 2024-11-10 02:03:32

android自己定义进度值可拖动的seekbar的相关文章

android自定义进度值可拖动的seekbar

最近忙找实习,加上实验室在推新项目,需要学习新知识.所以很长一段时间没去整理了官博客了,github也蛮久没更新,很惭愧.接下来还是要坚持写.今天就简单的写一下我在项目中用到的算自定义seekbar的博客,需求是这样的,seekbar需要显示最左和最右值,进度要跟随进度块移动.看下效果图就明白了. 其实实现起来很简单,主要是思路.自定义控件的话也不难,之前我的博客也有专门介绍,这里就不再多说. 实现方案 这里是通过继承seekbar来自定义控件,这样的方式最快.主要难点在于进度的显示,其实我很的

Android——菜单和进度条

xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent&quo

Android View 之进度条+拖动条+星级评论条....

PS:将来的你会感谢现在奋斗的自己.... 学习内容: 1.进度条 2.拖动条 3.星级评论条 1.进度条...       进图条这东西想必大家是很熟悉的...为了使用户不会觉得应用程序死掉了,因此为之设置一个进度条使应用程序的运行状态更好的反馈给客户...这也就是进度条的作用...因此一般的应用程序都会加入进度条...进度条分为圆形进度条和线性的进度条...目的都是一样的,只是展示的效果是不同的...用代码讲解一下... <LinearLayout xmlns:android="htt

android 14 进度条和拖动条

进度条: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <ProgressBar 默认进度条 andr

Android自己定义控件:进度条的四种实现方式

前三种实现方式代码出自: http://stormzhang.com/openandroid/2013/11/15/android-custom-loading/ (源代码下载)http://download.csdn.net/detail/chaoyu168/9616035 近期一直在学习自己定义控件,搜了很多大牛们Blog里分享的小教程.也上GitHub找了一些类似的控件进行学习.发现读起来都不太好懂,就想写这么一篇东西作为学习笔记吧. 一.控件介绍: 进度条在App中非经常见,比例如以下载

android自己定义渐变进度条

项目中须要用到一个弧形渐变的进度条,通过android自带是不能实现的.我是没有找到实现的方法,有大神知道的能够指点.效果图是以下这种 这是通过继承VIew来绘制出来的,网上也有相似的,可是代码那是相当的累赘,并且创建了非常多没用的对象,给内存管理带来负担? ?? 我在这把自己定义的View代码贴出来了,用到的话能够加以參考 public class SpringProgressView extends View { /** * 分段颜色 */ private static final int[

Android 自学之拖动条SeekBar

拖动条(SeekBar)和进度条非常相似,只是进度条采用颜色填充来表明进度完成的程度,而拖动条则通过滑块的位置来标识数值----而且拖动条允许用户拖动滑动块来改变值,因此拖动条通常用于对系统的某种数值进行调节,比如音量调节. SeekBar允许用户改变拖动条的滑块外观,改变滑块外观通过如下属性来指定 android:thumb  指定一个Drawable对象,该对象将作为自定义滑块. 为了让程序能响应拖动条滑块位置的改变,程序可以考虑为他绑定一个OnSeekBarChangerListener监

Android UI--自定义ListView(实现下拉刷新+加载更多)

http://blog.csdn.net/wwj_748/article/details/12512885 Android UI--自定义ListView(实现下拉刷新+加载更多) 关于实现ListView下拉刷新和加载更多的实现,我想网上一搜就一堆.不过我就没发现比较实用的,要不就是实现起来太复杂,要不就是不健全的.因为小巫近期要开发新浪微博客户端,需要实现ListView的下拉刷新,所以就想把这个UI整合到项目当中去,这里只是一个demo,可以根据项目的需要进行修改. 就不要太在乎界面了哈:

进度条与拖动条的使用学习

(一)进度条 常用属性详解: android:max:进度条的最大值android:progress:进度条已完成进度值android:progressDrawable:设置轨道对应的Drawable对象android:indeterminate:如果设置成true,则进度条不精确显示进度android:indeterminateDrawable:设置不显示进度的进度条的Drawable对象android:indeterminateDuration:设置不精确显示进度的持续时间android:s