Android使用Java更改Seekbar Thumb会导致Thumb位置重置

时间:2011-10-07 15:46:28

标签: java android drawable seekbar

我正在尝试使用拇指创建一个搜索栏,当用户按下该搜索栏时会改变颜色,并在用户放开时更改回来。我设法用set拇指改变拇指抽屉。但是,我还必须在java中设置drawable边界以使其在更改后出现。现在,当用户放开滑块并恢复其原始绘图时,它会将drawable重置为零位置并将进度保留在应有的位置。我已经尝试使用全局变量来重置drawable更改后的搜索栏进度,但它似乎不起作用。如果我使用静态整数来重置进度,它就会按照我想要的方式工作。

有点新的Android,我不知道我做错了什么。

这是在触摸时更改drawable的代码。

private void Seek_Height_Click() {
    Drawable myThumb = getResources().getDrawable(R.drawable.slider_button_click);
    myThumb.setBounds(new Rect(0, 0, myThumb.getIntrinsicWidth(),myThumb.getIntrinsicHeight()));
    Height_of_Target_skbr.setThumb(myThumb);
    Height_of_Target_skbr.setThumbOffset(-1);
}

这是将拇指设置回原始drawable的代码。

private void Seek_Height_UnClick() {
    Drawable myThumb = getResources().getDrawable(R.drawable.slider_button);
    myThumb.setBounds(new Rect(0, 0,   myThumb.getIntrinsicWidth(),myThumb.getIntrinsicHeight()));
    Height_of_Target_skbr.setThumb(myThumb);
    Height_of_Target_skbr.setThumbOffset(-1);
    Height_of_Target_skbr.setProgress(Height_Prog_int);
}

这是调用上述方法的代码。

this.Height_of_Target_skbr.setOnSeekBarChangeListener(new OnSeekBarChangeListener() {

        @Override
        public void onStopTrackingTouch(SeekBar seekBar) {
            returnHeight_skbr();
            Seek_Height_UnClick();
        }

        @Override
        public void onStartTrackingTouch(SeekBar seekBar) {
            returnHeight_skbr();
            Seek_Height_Click();
        }

        @Override
        public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {
            returnHeight_skbr();
        }
    });

1 个答案:

答案 0 :(得分:1)

我能够通过在drawable文件夹中创建一个样式然后将thumb drawable设置为该样式来使用此工作。

我参考了这个教程来完成这项工作。 http://www.youtube.com/watch?v=zXXCFmfJMNw

Thumb Style代码

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
<item 
    android:state_pressed="true"
    android:drawable="@drawable/slider_button_click">
</item>
<item 
    android:drawable="@drawable/slider_button">
</item>
</selector>