【问题标题】:Android Changing Seekbar Thumb with Java causes Thumb position to ResetAndroid 使用 Java 更改 Seekbar Thumb 会导致 Thumb 位置重置
【发布时间】:2011-10-07 15:46:27
【问题描述】:

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

对android有点陌生,我不知道我做错了什么。

这是在触摸时更改可绘制对象的代码。

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);
}

这是将拇指设置回原始可绘制对象的代码。

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();
        }
    });

【问题讨论】:

    标签: java android drawable seekbar


    【解决方案1】:

    我可以通过在可绘制文件夹中创建一个样式然后将拇指可绘制设置为该样式来完成这项工作。

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

    拇指样式代码

    <?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>
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多