全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Android控件之SeekBar的用法总结

1 SeekBar简介

SeekBar是进度条。我们使用进度条时,可以使用系统默认的进度条;也可以自定义进度条的图片和滑块图片等。

2 SeekBar示例

创建一个activity,包含2个SeekBar。

第1个SeekBar是系统默认的SeekBar。

第2个SeekBar是自定义SeekBar,使用自定义的背景图和滑块图片。

应用层代码

package com.skywang.control;

import android.os.Bundle;
import android.app.Activity;
import android.util.Log;
import android.widget.TextView;
import android.widget.SeekBar;
import android.widget.SeekBar.OnSeekBarChangeListener;

public class SeekBarTest extends Activity implements SeekBar.OnSeekBarChangeListener{
  private static final String TAG = "SKYWANG";

  // 与“系统默认SeekBar”对应的TextView
  private TextView mTvDef;
  // 与“自定义SeekBar”对应的TextView
  private TextView mTvSelf;
  // “系统默认SeekBar”
  private SeekBar mSeekBarDef;
  // “自定义SeekBar”
  private SeekBar mSeekBarSelf;
  
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.seek_bar_test);
    
    // 与“系统默认SeekBar”对应的TextView
    mTvDef = (TextView) findViewById(R.id.tv_def);
    // “系统默认SeekBar”
    mSeekBarDef = (SeekBar) findViewById(R.id.seekbar_def);
    mSeekBarDef.setOnSeekBarChangeListener(this);

    // 与“自定义SeekBar”对应的TextView
    mTvSelf = (TextView) findViewById(R.id.tv_self);
    // “自定义SeekBar”
    mSeekBarSelf = (SeekBar) findViewById(R.id.seekbar_self);
    mSeekBarSelf.setOnSeekBarChangeListener(this);
  }  
  
  /*
   * SeekBar停止滚动的回调函数
   */
  @Override
  public void onStopTrackingTouch(SeekBar seekBar) {
    
  }

  /*
   * SeekBar开始滚动的回调函数
   */
  @Override
  public void onStartTrackingTouch(SeekBar seekBar) {

  }

  /*
   * SeekBar滚动时的回调函数
   */
  @Override
  public void onProgressChanged(SeekBar seekBar, int progress,
      boolean fromUser) {
    Log.d(TAG, "seekid:"+seekBar.getId()+", progess"+progress);
    switch(seekBar.getId()) {
      case R.id.seekbar_def:{
        // 设置“与系统默认SeekBar对应的TextView”的值
        mTvDef.setText(getResources().getString(R.string.text_def)+" : "+String.valueOf(seekBar.getProgress()));
        break;
      }
      case R.id.seekbar_self: {
        // 设置“与自定义SeekBar对应的TextView”的值        
        mTvSelf.setText(getResources().getString(R.string.text_self)+" : "+String.valueOf(seekBar.getProgress()));
        break;
      }
      default:
        break;
    }
  }
}

代码说明:

要监听SeekBar的滑动消息,通过实现“SeekBar.OnSeekBarChangeListener”接口。这个接口中包含3个方法onStartTrackingTouch()、onStopTrackingTouch()和onProgressChanged()。

layout文件

<LinearLayout 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:orientation="vertical" >
  
  <TextView
    android:id="@+id/tv_def"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="@string/text_def" />
  
  <!-- 
    max=100,代表它的取值范围是0-100,共101个值;
    progress=10,代表默认值是10 
  -->
  <SeekBar
    android:id="@+id/seekbar_def"
    android:layout_width="620px"
    android:layout_height="wrap_content"
    android:max="100"
    android:progress="10"
    />
  
  <TextView
    android:id="@+id/tv_self"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="@string/text_self" />
  
  <!-- 
    max=100,代表它的取值范围是0-100,共101个值;
    progress=20,代表默认值是20
    progressDrawable,表示SeekBar的背景图片
    thumbe,表示SeekBar的滑块图片 
  -->
  <SeekBar
    android:id="@+id/seekbar_self"
    android:layout_width="620px" 
    android:layout_height="wrap_content"
    android:max="100"
    android:progress="20"
    android:progressDrawable="@drawable/bg_bar" 
    android:thumb="@drawable/thumb_bar" /> 
  
</LinearLayout>

自定义SeekBar的背景定义为:android:progressDrawable="@drawable/bg_bar"。

它调用的bg_bar.xml的内容如下:

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android">
  <!-- 背景图 -->
  <item android:id="@+android:id/background" android:drawable="@drawable/bar_dn" />
  <!-- 第二进度图 -->
  <item android:id="@+android:id/SecondaryProgress" android:drawable="@drawable/bar_dn" />
  <!-- 进度度 -->
  <item android:id="@+android:id/progress" android:drawable="@drawable/bar_up" />
</layer-list>

bar_dn.png如下图:

bar_up.png如下图:

自定义SeekBar的滑块定义为:android:thumb="@drawable/thumb_bar"。

它调用的thumb_bar.xml的内容如下:

<?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/thumb_dn" />

  <!-- 焦点状态 -->
  <item android:state_focused="true"
    android:drawable="@drawable/thumb_up" />
  
  <!-- 默认状态 -->
  <item android:drawable="@drawable/thumb_up" /> 
  
</selector> 

thumb_up.png如下图:

thumb_dn.png如下图:

manifest文件

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
  package="com.skywang.control"
  android:versionCode="1"
  android:versionName="1.0" >

  <uses-sdk
    android:minSdkVersion="8"
    android:targetSdkVersion="17" />

  <application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
      android:name="com.skywang.control.SeekBarTest"
      android:label="@string/app_name" >
      <intent-filter>
        <action android:name="android.intent.action.MAIN" />

        <category android:name="android.intent.category.LAUNCHER" />
      </intent-filter>
    </activity>
  </application>

</manifest>

点击下载:源代码

运行效果:如图

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Android  # SeekBar  # android自定义seekbar 


相关文章: 微信推文制作网站有哪些,怎么做微信推文,急?  英语简历制作免费网站推荐,如何将简历翻译成英文?  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  建站之星免费模板:自助建站系统与智能响应式一键生成  完全自定义免费建站平台:主题模板在线生成一站式服务  如何在IIS7中新建站点?详细步骤解析  建站主机类型有哪些?如何正确选型  建站之星客服服务时间及联系方式如何?  威客平台建站流程解析:高效搭建教程与设计优化方案  如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法  网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?  活动邀请函制作网站有哪些,活动邀请函文案?  C#如何在一个XML文件中查找并替换文本内容  官网建站费用明细查询_企业建站套餐价格及收费标准指南    如何快速建站并高效导出源代码?  广州顶尖建站服务:企业官网建设与SEO优化一体化方案  建站之星2.7模板快速切换与批量管理功能操作指南  如何获取上海专业网站定制建站电话?  ,sp开头的版面叫什么?  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  如何零成本快速生成个人自助网站?  建站主机无法访问?如何排查域名与服务器问题  如何在阿里云通过域名搭建网站?  南京网站制作费用,南京远驱官方网站?  如何在服务器上配置二级域名建站?  名字制作网站免费,所有小说网站的名字?  网站制作的步骤包括,正确网址格式怎么写?  建站之星上传入口如何快速找到?  单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?  专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  怎么将XML数据可视化 D3.js加载XML  移民网站制作流程,怎么看加拿大移民官网?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  如何快速生成专业多端适配建站电话?  宝塔新建站点报错如何解决?  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  建站主机选哪种环境更利于SEO优化?  C++如何使用std::optional?(处理可选值)  图片制作网站免费软件,有没有免费的网站或软件可以将图片批量转为A4大小的pdf?  网站制作免费,什么网站能看正片电影?  娃派WAP自助建站:免费模板+移动优化,快速打造专业网站  内部网站制作流程,如何建立公司内部网站?  购物网站制作公司有哪些,哪个购物网站比较好?  清除minerd进程的简单方法  外贸公司网站制作,外贸网站建设一般有哪些步骤?  如何在景安服务器上快速搭建个人网站?  建设网站制作价格,怎样建立自己的公司网站?  如何优化Golang Web性能_Golang HTTP服务器性能提升方法  如何用VPS主机快速搭建个人网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。