Kotlin-范围搜索栏库

时间:2019-03-08 21:28:38

标签: android kotlin android-widget rangeseekbar

我正在使用syedowaisali的Range Seekbar,但我无法根据拇指在条上的位置更改TextView。

我的活动的onCreate中包含以下内容:

    val rangeSeekbar = CrystalRangeSeekbar(this)
    rangeSeekbar.setOnRangeSeekbarChangeListener { minValue, maxValue ->
        tv_rent_time_range.text = maxValue.toString()
    }

tv_rent_time_rangemaxValue一起加载,但是当我移动右拇指时它不会改变

在他的Java文档中,应该看起来像这样:

rangeSeekbar.setOnRangeSeekbarChangeListener(new OnRangeSeekbarChangeListener() {
    @Override
    public void valueChanged(Number minValue, Number maxValue) {
        tvMin.setText(String.valueOf(minValue));
        tvMax.setText(String.valueOf(maxValue));
    }
});

我觉得我在Kotlin中设置了setOnRangeSeekbarChangeListener错误

1 个答案:

答案 0 :(得分:1)

您正在创建新对象(val rangeSeekbar = CrystalRangeSeekbar(this)),而不是使用膨胀布局中的视图。您可以使用:

rangeSeekbar.setOnRangeSeekbarChangeListener { minValue, maxValue ->
    // Do something there  
}

对于来自Android SDK的SeekBar,您可以从setOnSeekBarChangeListener接收更新。

对于来自Android SDK的CrystalRangeSeekbar,您可以从setOnRangeSeekbarChangeListener接收更新。

import android.os.Bundle
import android.support.v7.app.AppCompatActivity
import android.widget.SeekBar
import kotlinx.android.synthetic.main.activity_main.*

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        setupUi()
    }

    private fun setupUi() {
        // Regular SeekBar (from Android SDK)
        seek_bar.setOnSeekBarChangeListener(object : SeekBar.OnSeekBarChangeListener {
            override fun onProgressChanged(seekBar: SeekBar?, progress: Int, fromUser: Boolean) {
                // Update text here
            }

            override fun onStartTrackingTouch(seekBar: SeekBar?) {
            }

            override fun onStopTrackingTouch(seekBar: SeekBar?) {
            }
        })

        crystal_range_seek_bar.setOnRangeSeekbarChangeListener { minValue, maxValue ->
            // Update text here
        }
    }
}