开发日记——手机安全卫士 Day02 2016-7-21 完成导航页面和切换功能

手机安全卫士 Day02 2016-7-21 完成导航页面和切换功能

导航页面底端使用RadioGroup和RadioButton控件。RadioButton背景使用了自定义的背景选择器,用于控制按钮点击时显示的颜色。

背景选择器:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checked = "true" android:drawable="@drawable/circle_blue"/>
    <item android:state_checked = "false" android:drawable="@drawable/circle_gray"/>
</selector>

灰色圆点:
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="oval">
    <solid android:color="#acacac"/>
</shape>

切换页面需要定义动画效果,在res目录下新建anim文件夹
(-100%p,0) (0,0) (100%p,0)
上一个页面进入动画如下:
<?xml version="1.0" encoding="utf-8"?>
<translate xmlns:android="http://schemas.android.com/apk/res/android"
    android:fromXDelta="-100%p"
    android:toXDelta="0"
    android:fromYDelta="0"
    android:toYDelta="0"
    android:duration="500"
    android:repeatCount="0"
    >
</translate>
 
 
由于每一个界面都需要进行滑动,定义一个父类实现手势识别功能。
public abstract class BaseSetUpActivity extends Activity {
    public SharedPreferences sp;
    private GestureDetector mGestureDetector;
    @Override
    protected void onCreate(Bundle savedInstanceState){
        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_NO_TITLE);
        sp=getSharedPreferences("config",MODE_PRIVATE);
        mGestureDetector = new GestureDetector(this,new GestureDetector.SimpleOnGestureListener(){
            //e1:触碰 e2:离开
            //velocity速度 pix/s
            @Override
            public boolean onFling(MotionEvent e1,MotionEvent e2,float velocityX,float velocityY){
                if(Math.abs(velocityX)<200){
                    return true;
                }
                if(e2.getRawX()-e1.getRawX()>200){
                    //从左向右
                    showLast();
                    overridePendingTransition(R.anim.last_in,R.anim.next_out);
                    return true;
                }
                if(e1.getRawX()-e2.getRawX()>200){
                    //从左向右
                    showNext();
                    overridePendingTransition(R.anim.next_in,R.anim.last_out);
                    return true;
                }
                return super.onFling(e1,e2,velocityX,velocityY);
            }
        });
    }

    public abstract void showLast();
    public abstract void showNext();

    @Override
    public boolean onTouchEvent(MotionEvent event){
        mGestureDetector.onTouchEvent(event);
        return super.onTouchEvent(event);
    }

    public void startActivityAndFinishActivity(Class<?> cls){
        Intent intent = new Intent(this,cls);
        startActivity(intent);
        finish();
    }
}

页面4的按钮是一个ToggleButton,按钮背景可以通过自定义图片显示器控制
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_checked="true" android:drawable="@drawable/swtch_btn_on"></item>
    <item android:state_checked="false" android:drawable="@drawable/switch_btn_off"></item>
</selector>


 
 


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值