Seekbar for two values [-50, 0, 50]

混江龙づ霸主 提交于 2019-11-29 06:56:26

I faced the same problem. Thanks to Commonsware to point to right direction. I wrote a class inspired by code.google.com/p/range-seek-bar) to get the solution.

https://github.com/vashisthg/StartPointSeekBar

suresh n

As Above all said, it can be achieved my implementing our own custom seekbar.

I tried in the following way and it worked out for me.

activity_main.xml

 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:paddingBottom="@dimen/activity_vertical_margin"
  android:paddingLeft="@dimen/activity_horizontal_margin"
  android:paddingRight="@dimen/activity_horizontal_margin"
  android:paddingTop="@dimen/activity_vertical_margin"
  tools:context=".MainActivity" 
  android:layout_margin="20dp">

 <com.example.customseekbar.CustomSeekBar
    android:layout_width="match_parent"
    android:layout_height="wrap_content"        
    android:max="100"
    android:progress="50"
    android:progressDrawable="@android:color/transparent"
    android:id="@+id/customSeekBar"
 />

</RelativeLayout>

MainActivity.java

package com.example.customseekbar;

import com.example.suricustomseekbar.R;
import android.app.Activity;
import android.os.Bundle;
import android.widget.SeekBar;

public class MainActivity extends Activity {

SeekBar mseekBar;

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

    mseekBar = (SeekBar) findViewById(R.id.customSeekBar);
    mseekBar.setProgress(50);
     }
  }

CustomSeekBar.java

package com.example.customseekbar;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.widget.SeekBar;

  public class CustomSeekBar extends SeekBar {

private Rect rect;
private Paint paint ;
private int seekbar_height; 

public CustomSeekBar(Context context) {
    super(context);

}

public CustomSeekBar(Context context, AttributeSet attrs) {

    super(context, attrs);
    rect = new Rect();
    paint = new Paint();
    seekbar_height = 6;
}

public CustomSeekBar(Context context, AttributeSet attrs, int defStyle) {
    super(context, attrs, defStyle);
}

@Override
protected synchronized void onDraw(Canvas canvas) {

    rect.set(0 + getThumbOffset(), 
            (getHeight() / 2) - (seekbar_height/2), 
            getWidth()- getThumbOffset(), 
            (getHeight() / 2) + (seekbar_height/2));

    paint.setColor(Color.GRAY);

    canvas.drawRect(rect, paint);



    if (this.getProgress() > 50) {


        rect.set(getWidth() / 2,
                (getHeight() / 2) - (seekbar_height/2), 
                getWidth() / 2 + (getWidth() / 100) * (getProgress() - 50),
                getHeight() / 2 + (seekbar_height/2));

        paint.setColor(Color.CYAN);
        canvas.drawRect(rect, paint);

    }

    if (this.getProgress() < 50) {

        rect.set(getWidth() / 2 - ((getWidth() / 100) * (50 - getProgress())),
                (getHeight() / 2) - (seekbar_height/2),
                 getWidth() / 2,
                 getHeight() / 2 + (seekbar_height/2));

        paint.setColor(Color.CYAN);
        canvas.drawRect(rect, paint);

    }

    super.onDraw(canvas);
    }
}

To start in the middle, you can call setProgress() with a value that is half of your total range.

To have the SeekBar start in the middle and go to an end (i.e., your blue line runs from middle to the left or from middle to the right), you would need to create your own replacement for SeekBar, or find somebody else who has done this, as this is not supported by SeekBar itself.

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!