国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

Android控件SeekBar仿淘寶滑動驗證效果

2019-12-12 04:32:59
字體:
來源:轉載
供稿:網友

SeekBar是一個拖動條控件,最簡單的案例就是我們的調節音量,還有音頻視頻的播放,傳統的SeekBar樣式,如圖

傳統的實現太簡單,不足以讓我們到能裝逼的地步。本來是打算實現滴滴出行滑動完成訂單的效果,可惜找不到效果圖,今天也就用淘寶的滑動驗證來作為實例


1.1 實現分析

SeekBar:使用progressDrawable屬性自定義SeekBar
拖動塊:使用thumb屬性更改,其實就是一張圖片
文字:使用RelativeLayout嵌套在一起

1.2 實現布局

<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  android:layout_width="match_parent"  android:layout_height="wrap_content"  android:padding="16dp">  <SeekBar    android:id="@+id/sb"    android:layout_width="match_parent"    android:layout_height="wrap_content"    android:max="100"    android:progress="0"    android:progressDrawable="@drawable/seekbar_bg"    android:thumb="@drawable/thumb"    android:thumbOffset="0dp" />  <TextView    android:id="@+id/tv"    android:layout_width="match_parent"    android:layout_height="wrap_content"    android:layout_centerInParent="true"    android:gravity="center"    android:text="請按住滑塊,拖動到最右邊"    android:textColor="#888888"    android:textSize="14dp" /></RelativeLayout>

其效果是


SeekBar屬性介紹

android:max:設置進度條最大的進度值
android:progress:設置當前的進度值
android:progressDrawable:設置進度條的Drawable樣式
android:thumb:設置進度條滑塊
android:thumbOffset:設置進度條滑塊的偏移量

1.3 SeekBar樣式

這里是Android:progressDrawable里面的seekbar_bg.xml

<?xml version="1.0" encoding="UTF-8"?><layer-list xmlns:android="http://schemas.android.com/apk/res/android">  <!--seekBar背景-->  <item android:id="@android:id/background">    <!--形狀-->    <shape android:shape="rectangle">      <!--大小-->      <size android:height="29dp" />      <!--圓角-->      <corners android:radius="2dp" />      <!--背景-->      <solid android:color="#E7EAE9" />      <!--邊框-->      <stroke        android:width="1dp"        android:color="#C3C5C4" />    </shape>  </item>  <!--seekBar的進度條-->  <item android:id="@android:id/progress">    <clip>      <shape>        <corners android:radius="2dp" />        <solid android:color="#7AC23C" />        <stroke          android:width="1dp"          android:color="#C3C5C4" />      </shape>    </clip>  </item></layer-list>

1.4 代碼實現邏輯

代碼也非常簡單,seekBar提供了一個監聽事件OnSeekBarChangeListener,在對應的回調中實現文字的出現和消失、文本內容的修改

public class MainActivity extends AppCompatActivity implements SeekBar.OnSeekBarChangeListener {  private TextView tv;  private SeekBar seekBar;  @Override  protected void onCreate(Bundle savedInstanceState) {    super.onCreate(savedInstanceState);    setContentView(R.layout.activity_main);    tv = (TextView) findViewById(R.id.tv);    seekBar = (SeekBar) findViewById(R.id.sb);    seekBar.setOnSeekBarChangeListener(this);  }  /**   * seekBar進度變化時回調   *   * @param seekBar    * @param progress    * @param fromUser    */  @Override  public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {    if (seekBar.getProgress() == seekBar.getMax()) {      tv.setVisibility(View.VISIBLE);      tv.setTextColor(Color.WHITE);      tv.setText("完成驗證");    } else {      tv.setVisibility(View.INVISIBLE);    }  }  /**   * seekBar開始觸摸時回調   *   * @param seekBar   */  @Override  public void onStartTrackingTouch(SeekBar seekBar) {  }  /**   * seekBar停止觸摸時回調   *   * @param seekBar   */  @Override  public void onStopTrackingTouch(SeekBar seekBar) {    if (seekBar.getProgress() != seekBar.getMax()) {      seekBar.setProgress(0);      tv.setVisibility(View.VISIBLE);      tv.setTextColor(Color.GRAY);      tv.setText("請按住滑塊,拖動到最右邊");    }  }}

好了,今天的SeekBar的使用就到這里,如果對其他基礎控件感興趣的,可以關注我的博客,基礎控件系列,歡迎提供大家idea。

源碼下載:http://xiazai.VeVB.COm/201611/yuanma/Androidseekbar(VeVB.COm).rar

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宜宾县| 河间市| 彭州市| 长汀县| 高安市| 正宁县| 绥德县| 乌兰察布市| 贡嘎县| 兴和县| 竹山县| 轮台县| 武清区| 山阴县| 临沂市| 潢川县| 梁河县| 隆子县| 阿鲁科尔沁旗| 保靖县| 连平县| 洞头县| 荔波县| 绥芬河市| 邓州市| 通山县| 中山市| 阳西县| 恭城| 平南县| 同仁县| 汤阴县| 高邑县| 九龙县| 台南市| 修文县| 东海县| 佛冈县| 邓州市| 荥阳市| 茂名市|