seek bar 显示进度的控件

src 中的 MainActivity:

public class MainActivity extends Activity implements View.OnClickListener {
	private ProgressBar progressBar;
	private Button button;
	
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		
		progressBar = (ProgressBar) findViewById(R.id.progressBar1);
		button = (Button) findViewById(R.id.button1);
		button.setOnClickListener(this);
	}
	
	private int progress;

	@Override
	public void onClick(View v) {
		if(progress < 100) {
			progress += 5;
			progressBar.setProgress(progress);
		} else {
			Toast.makeText(this, "爆了爆了,不能再点了!!!", Toast.LENGTH_SHORT).show();
			button.setEnabled(false);
		}
	}
}
layout 中的 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" >

    <ProgressBar
        android:max="100"
        android:progress="0"
        android:id="@+id/progressBar1"
        style="?android:attr/progressBarStyleHorizontal"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_below="@+id/progressBar1"
        android:text="更新进度" />

</RelativeLayout>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你想让 ProgressBar 底部的文字能够跟随进度条的移动而移动,可以使用 ProgressBar 的 getThumb() 方法获取到进度条的滑块,然后通过设置滑块的位置来实现底部文字的移动。具体的代码如下: ```java SeekBar seekBar = findViewById(R.id.seek_bar); final TextView textView = findViewById(R.id.text_view); seekBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() { @Override public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) { // 获取进度条的滑块 Drawable thumb = seekBar.getThumb(); // 计算滑块的位置 int thumbLeft = seekBar.getLeft() + seekBar.getPaddingLeft() + (seekBar.getWidth() - seekBar.getPaddingLeft() - seekBar.getPaddingRight()) * progress / seekBar.getMax() - thumb.getBounds().width() / 2; // 设置滑块的位置 thumb.setBounds(thumbLeft, thumb.getBounds().top, thumbLeft + thumb.getBounds().width(), thumb.getBounds().bottom); // 更新底部文字的位置 textView.setX(thumbLeft); textView.setText("当前进度:" + progress); } @Override public void onStartTrackingTouch(SeekBar seekBar) {} @Override public void onStopTrackingTouch(SeekBar seekBar) {} }); ``` 在这个例子中,我们创建了一个 SeekBar 控件和一个 TextView 控件,然后在 setOnSeekBarChangeListener() 方法中设置了一个监听器。在 onProgressChanged() 方法中,我们获取了进度条的滑块,并计算出了滑块的位置。然后通过设置滑块的位置和更新底部文字的位置,使底部文字能够跟随进度条的移动而移动。需要注意的是,我们还需要设置一下 TextView 的宽度,使其能够居中显示在滑块下方。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值