知識
不管是網(wǎng)站,軟件還是小程序,都要直接或間接能為您產(chǎn)生價(jià)值,我們在追求其視覺表現(xiàn)的同時(shí),更側(cè)重于功能的便捷,營銷的便利,運(yùn)營的高效,讓網(wǎng)站成為營銷工具,讓軟件能切實(shí)提升企業(yè)內(nèi)部管理水平和效率。優(yōu)秀的程序?yàn)楹笃谏壧峁┍憬莸闹С郑?
自定義帶滑動(dòng)屬性的Switch
發(fā)表時(shí)間:2020-11-13
發(fā)布人:葵宇科技
瀏覽次數(shù):47
1. 效果圖
[img]http://img.blog.csdn.net/20150107140702906?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcXE0MzU3NTczOTk=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center
2. SlidingSwitch.java文件內(nèi)容:
<pre name="code" class="java">package com.jun.widget; import com.jun.slidingswitch.R; import android.annotation.SuppressLint; import android.content.Context; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.graphics.Canvas; import android.graphics.Matrix; import android.graphics.Paint; import android.graphics.Rect; import android.util.AttributeSet; import android.view.MotionEvent; import android.view.View; import android.view.View.OnTouchListener; /** * * slidingSwitch.setCheck(true); * slidingSwitch.SetOnChangedListener(new OnChangedListener() * { * @Override * public void OnChanged(boolean CheckState) * { * //處理slidingSwitch開關(guān)事件 * } * }); **/ public class SlidingSwitch extends View implements OnTouchListener { private boolean NowChoose = false;// 記錄當(dāng)前按鈕是否打開,true為打開,flase為關(guān)閉 private boolean isChecked; private boolean OnSliding = false;// 記錄用戶是否在滑動(dòng)的變量 private float DownX, NowX;// 按下時(shí)的x,當(dāng)前的x private Rect Btn_On, Btn_Off;// 打開和關(guān)閉狀態(tài)下,游標(biāo)的Rect private boolean isChgLsnOn = false; private OnChangedListener ChgLsn; private Bitmap bg_on, bg_off, sliding_switch; public SlidingSwitch(Context context) { super(context); init(); } public SlidingSwitch(Context context, AttributeSet attrs) { super(context, attrs); init(); } public SlidingSwitch(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); init(); } private void init() {// 初始化 bg_on = BitmapFactory.decodeResource(getResources(), R.drawable.slip_left); bg_off = BitmapFactory.decodeResource(getResources(), R.drawable.slip_right); sliding_switch = BitmapFactory.decodeResource(getResources(), R.drawable.slip_ball); Btn_On = new Rect(0, 0, sliding_switch.getWidth(), sliding_switch.getHeight()); Btn_Off = new Rect(bg_off.getWidth() - sliding_switch.getWidth(), 0, bg_off.getWidth(), sliding_switch.getHeight()); setOnTouchListener(this);// 設(shè)置監(jiān)聽器,也可以直接復(fù)寫OnTouchEvent } @SuppressLint("DrawAllocation") @Override protected void onDraw(Canvas canvas) {// 繪圖函數(shù) super.onDraw(canvas); Matrix matrix = new Matrix(); Paint paint = new Paint(); float x; if (NowX < (bg_on.getWidth() / 2))// 滑動(dòng)到前半段與后半段的背景不同,在此做判斷 { x = NowX - sliding_switch.getWidth() / 2; canvas.drawBitmap(bg_off, matrix, paint);// 畫出關(guān)閉時(shí)的背景 } else { x = bg_on.getWidth() - sliding_switch.getWidth() / 2; canvas.drawBitmap(bg_on, matrix, paint);// 畫出打開時(shí)的背景 } if (OnSliding)// 是否是在滑動(dòng)狀態(tài), { if (NowX >= bg_on.getWidth())// 是否劃出指定范圍,不能讓游標(biāo)跑到外頭,必須做這個(gè)判斷 x = bg_on.getWidth() - sliding_switch.getWidth() / 2;// 減去游標(biāo)1/2的長度... else if (NowX < 0) { x = 0; } else { x = NowX - sliding_switch.getWidth() / 2; } } else {// 非滑動(dòng)狀態(tài) if (NowChoose)// 根據(jù)現(xiàn)在的開關(guān)狀態(tài)設(shè)置畫游標(biāo)的位置 { x = Btn_Off.left; canvas.drawBitmap(bg_on, matrix, paint);// 初始狀態(tài)為true時(shí)應(yīng)該畫出打開狀態(tài)圖片 } else x = Btn_On.left; } if (isChecked) { canvas.drawBitmap(bg_on, matrix, paint); x = Btn_Off.left; isChecked = !isChecked; } if (x < 0)// 對游標(biāo)位置進(jìn)行異常判斷... x = 0; else if (x > bg_on.getWidth() - sliding_switch.getWidth()) x = bg_on.getWidth() - sliding_switch.getWidth(); canvas.drawBitmap(sliding_switch, x, 0, paint);// 畫出游標(biāo). } @Override public boolean onTouch(View v, MotionEvent event) { switch (event.getAction()) // 根據(jù)動(dòng)作來執(zhí)行代碼 { case MotionEvent.ACTION_MOVE:// 滑動(dòng) NowX = event.getX(); break; case MotionEvent.ACTION_DOWN:// 按下 if (event.getX() > bg_on.getWidth() || event.getY() > bg_on.getHeight()) return false; OnSliding = true; DownX = event.getX(); NowX = DownX; break; case MotionEvent.ACTION_CANCEL: // 移到控件外部 OnSliding = false; boolean choose = NowChoose; if (NowX >= (bg_on.getWidth() / 2)) { NowX = bg_on.getWidth() - sliding_switch.getWidth() / 2; NowChoose = true; } else { NowX = NowX - sliding_switch.getWidth() / 2; NowChoose = false; } if (isChgLsnOn && (choose != NowChoose)) // 如果設(shè)置了監(jiān)聽器,就調(diào)用其方法.. ChgLsn.OnChanged(NowChoose); break; case MotionEvent.ACTION_UP:// 松開 OnSliding = false; boolean LastChoose = NowChoose; if (event.getX() >= (bg_on.getWidth() / 2)) { NowX = bg_on.getWidth() - sliding_switch.getWidth() / 2; NowChoose = true; } else { NowX = NowX - sliding_switch.getWidth() / 2; NowChoose = false; } if (isChgLsnOn && (LastChoose != NowChoose)) // 如果設(shè)置了監(jiān)聽器,就調(diào)用其方法.. ChgLsn.OnChanged(NowChoose); break; default: } invalidate();// 重畫控件 return true; } public void SetOnChangedListener(OnChangedListener l) { // 設(shè)置監(jiān)聽器,當(dāng)狀態(tài)修改的時(shí)候 isChgLsnOn = true; ChgLsn = l; } public interface OnChangedListener { abstract void OnChanged(boolean CheckState); } public void setCheck(boolean isChecked) { this.isChecked = isChecked; NowChoose = isChecked; } }
2. activity_main.xml布局內(nèi)容:
<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="com.jun.slidingswitch.MainActivity" > <com.jun.widget.SlidingSwitch android:layout_width="wrap_content" android:layout_height="wrap_content"/> </RelativeLayout>
3. MainActivity.java文件內(nèi)容:
package com.jun.slidingswitch; import android.support.v7.app.ActionBarActivity; import android.os.Bundle; import android.view.Menu; import android.view.MenuItem; public class MainActivity extends ActionBarActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { // Handle action bar item clicks here. The action bar will // automatically handle clicks on the Home/Up button, so long // as you specify a parent activity in AndroidManifest.xml. int id = item.getItemId(); if (id == R.id.action_settings) { return true; } return super.onOptionsItemSelected(item); } }
5.demo(百度云網(wǎng)盤)
http://pan.baidu.com/s/1dDpgqdV
相關(guān)案例查看更多
相關(guān)閱讀
- 小程序被騙
- 網(wǎng)站優(yōu)化哪家好
- 花農(nóng)小程序
- 軟件定制公司
- 服務(wù)器
- 云南企業(yè)網(wǎng)站
- 云南網(wǎng)站建設(shè)專業(yè)品牌
- 云南省城鄉(xiāng)建設(shè)廳網(wǎng)站
- 云南網(wǎng)站建設(shè)特性
- 小程序表單
- 汽車報(bào)廢
- 開通微信小程序被騙
- 網(wǎng)站小程序
- 網(wǎng)站建設(shè)特性
- 云南做網(wǎng)站
- php網(wǎng)站
- 云南建設(shè)廳網(wǎng)站
- 云南網(wǎng)站建設(shè)高手
- 網(wǎng)站建設(shè)服務(wù)公司
- 微信小程序
- 昆明小程序開發(fā)
- 網(wǎng)站建設(shè)服務(wù)
- 北京小程序制作
- 搜索引擎優(yōu)化
- 云南省住房建設(shè)廳網(wǎng)站
- 云南小程序開發(fā)報(bào)價(jià)
- 小程序公司
- 楚雄網(wǎng)站建設(shè)公司
- 手機(jī)網(wǎng)站建設(shè)
- 制作一個(gè)小程序