实现一个简单的android开关
近期在学习android中的graphics中绘图系列。依照大神思路。找葫芦画瓢实现了一个开关。如图下:
记录一下实现方式:
1.画背景
上图形状。分成两个半圆与一个矩形,那么代码能够写成:
private void drawBackground(Canvas canvas) {
mBackGroundPaint.setColor(mCurrentBackGroundColor);
//画右边的半圆
RectF recF = new RectF(mToggleWidth / 2 - mRadius, -mRadius, mToggleWidth / 2 + mRadius, mRadius);
canvas.drawArc(recF, -90, 180, true, mBackGroundPaint);
//画矩形
RectF tangle = new RectF(-mToggleWidth / 2, -mRadius, mToggleWidth / 2, mRadius);
canvas.drawRect(tangle, mBackGroundPaint);
//画左边的半圆
RectF rectF = new RectF(-mToggleWidth / 2 - mRadius, -mRadius, -mToggleWidth / 2 + mRadius, mRadius);
canvas.drawArc(rectF, 270, -180, true, mBackGroundPaint);
canvas.restore();
}
3.画圆点:
这里我是用一个圆环[紫色的]+内切圆环的实心圆[蓝色]构成的。或许你会说,直接设置panint.setStrokeWidth不就能够了。这个傻冒,呵呵。事实上我也想。可是发现不行啊【比較难看,并且我的颜色还不好设置,呵呵,你试一下就知道了】。
紫色的圆环负责显示包住内部实心圆,形成一个边界作用。这个对于白色的实心圆是非常好看的。
4.设置开关
public void setOpen(boolean isOpen) {
if (mIsOpen != isOpen) {
mIsOpen = isOpen;
showAnimation(mIsOpen);
}
}
能够看出。这里我用了动画的显示效果,在android横行的年代,不加点动画就会显示生硬。举个梨子,我第一个遇到哥们做相似的开关时。直接叫视觉project师[说白了就是美工]切了两张图,不得不说,那哥们非常聪明非常牛逼,我自然也是学到了,后来发现发现好生硬啊,没有一点美感。于是我就自己写了。
A.实心圆的圆心坐标:
图中能够看到非常清楚了。那么我能够直接写代码了:
//mToggleWidth正好是矩形的矩形的长度哦:
final float start = isOpen ? -mToggleWidth / 2 : mToggleWidth / 2;
float end = isOpen ?
mToggleWidth / 2 : -mToggleWidth / 2;
ValueAnimator animator = ValueAnimator.ofFloat(start, end);
animator.setDuration(mAnimationTime);
animator.setInterpolator(new LinearInterpolator());
animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator valueAnimator) {
mCurrentXPosition = (float) valueAnimator.getAnimatedValue();
setCurrentColor();
invalidate();
}
});
animator.start();
}
B. 背景的变色:
从关闭颜色到打开颜色,这当中是有颜色过度的。不清楚,好你看看这个:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMzc2MjU3Mg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="这里写图片描写叙述" title=""> 清楚了吧,恩这个颜色该怎么玩呢????
非常多大神的文章里,都是有个叫颜色估值器的介绍,即:
ValueAnimator.ofArgb(...)
本来用这个非常easy实现的,能够我练习的sdk min版本号是14,也真是懒得改,好吧,懒得改我就的想想方法了,方法是这种:
我在s点的坐标我是知道的,那么我就能够计算我动画运行的百分比了吧,恩,啥意思?:
float percent = (mCurrentXPosition + mToggleWidth / 2) * 1.0f / mToggleWidth;
这个看图能够直观些。我也就不多讲了,事实上我数学也非常不好,还特么刚学习Paint,也搞了好久,多搞搞或许就好了。知道了动画进行的百分比,那么我们就知道了随意时刻的动画了:
float percent = (mCurrentXPosition + mToggleWidth / 2) * 1.0f / mToggleWidth;
int currentR = (int) ((mEndBgColorR - mStartBgColorR) * percent + mStartBgColorR);
int currentG = (int) ((mEndBgColorG - mStartBgColorG) * percent + mStartBgColorG);
int currentB = (int) ((mEndBgColorB - mStartBgColorB) * percent + mStartBgColorB);
mCurrentBackGroundColor = Color.rgb(currentR, currentG, currentB);
这里的EndBgColor是指结束时的背景颜色。而StartBgColor就是指開始时的背景颜色。
使用:
xml文件里配置:
<micro.com.testpaint.view.ToggleButton
android:id="@+id/button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
app:circle_ring_width="4dp"/>
activity中调用:
ToggleButton button = (ToggleButton) findViewById(R.id.button);
button.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
button.setOpen(!button.ToggleIsOpen());
}
});
然后就出现了我们点击的样子了。
。。。
好了,大家能够看看,也能够在我的基础上扩展了。刚学习这方面的东西。大神勿喷,要脸。
最后,代码 。
实现一个简单的android开关的更多相关文章
- 一个简单的Android小实例
原文:一个简单的Android小实例 一.配置环境 1.下载intellij idea15 2.安装Android SDK,通过Android SDK管理器安装或卸载Android平台 3.安装J ...
- Android高效的应用程序开发工具集1---ant构建一个简单的Android工程
在java编译那些事通过提到ant编译Java工程,如今扩大到用它来构建Android目,事实上道理是相通的.变化的仅仅是使用的形式.ant构建相比IDE的优点是多个子项目使用自己定义jar包时,an ...
- 一个简单的Android富文本TextView实现
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 24.0px Helvetica; color: #555555 } p.p2 { margin: 0.0p ...
- 使用工具Android Studio实现一个简单的Android版的新闻APP
目的: 这是我学完Android课程后所写的一个小的.简单版的新闻APP 技术概要: 用到了SQLite数据库,用它来存储每篇新闻下的评论 新闻的来源是新浪新闻,我通过使用Fiddler来对新浪新闻A ...
- 一个简单的Android木马病毒的分析
一.样本信息 文件名称: 一个安卓病毒木马.apk 文件大小:242867 byte 文件类型:application/jar 病毒名称:Android.Trojan.SMSSend.KS 样本MD5 ...
- 一个简单的Android音乐播放器
Android小白的期末作业 Android期末项目,仅用作学习使用,在线音乐部分只获取了网易云热歌榜,API来自鼻子亲了脸 传送门: GitHub 参考: anddiencn 实现功能 展示出本地的 ...
- 一个简单的Android小实例分享,包含recycleView与recyclerView嵌套
先上图: 1.首页 2.第二页 3.第三页 项目目录: 代码不多,本人太懒,就不贴了 项目地址:
- 我的第一个 Mono for Android 应用
创建 Mono for Android 应用 打开 MonoDevelop , 选择新建解决方案, 左边的分类选择 "Mono for Android" , 右边选择 " ...
- Appium+Robotframework实现Android应用的自动化测试-6:一个简单的例子
万事具备,只欠编码! 下面看一个简单的示例,这个示例验证Android手机自带的通讯录的添加联系人的操作是否成功.这个例子是Appium官网自带的示例,有兴趣的同学也可以自己下载来研究和学习,下载地址 ...
随机推荐
- 怎样让孩子爱上设计模式 —— 7.适配器模式(Adapter Pattern)
怎样让孩子爱上设计模式 -- 7.适配器模式(Adapter Pattern) 标签: 设计模式初涉 概念相关 定义: 适配器模式把一个类的接口变换成client所期待的还有一种接口,从而 使原本因接 ...
- android自己定义进度值可拖动的seekbar
近期忙找实习,加上实验室在推新项目,须要学习新知识.所以非常长一段时间没去整理了官博客了,github也蛮久没更新.非常羞愧.接下来还是要坚持写. 今天就简单的写一下我在项目中用到的算自己定义seek ...
- Word批量调整插入图片大小
做标书,word中需要插入大量图片,实为一些证书.文件的扫描文件.但插入后,大小不是想要的,太小了,打印出来看不清.需要调整,需要批量调整. 这是一个不错的方法: 选中第一张图片,按页面调整大小到适合 ...
- 微信小程序 - async/await
下面只是做一些介绍以及使用的原因,详情介绍还请移步博主:https://www.cnblogs.com/SamWeb/p/8417940.html regenerator-runtime下载:http ...
- Executor并发框架--线程池,ThreadToolExecutor初步
Executor存在的目的是提供一种将"任务提交"与"任务如何运行"分离开来的机制.虽然只有一个方法,但是却为灵活且强大的异步任务执行框架提供了基础.它提供了一 ...
- 让span对宽度有响应而且兼容多种浏览器
span {display:-moz-inline-box; display:inline-block; width:20px;height:20px;}
- 转:CentOS系统yum源配置修改、yum安装软件包源码包出错解决办法!
yum安装包时报错: Could not retrieve mirrorlist http://mirrorlist.repoforge.org/el6/mirrors-rpmforge error ...
- cocos2d-js Shader系列4:Shader、GLProgram在jsb(native、手机)和html5之间的兼容问题。cocos2d-js框架各种坑。
为了让jsb也能顺利跑起滤镜效果,在手机侧折腾了2天,因为每次在真机上运行总要耗那么半分钟,而且偶尔还遇到apk文件无法删除导致运行失败的情况. 这个调试起来,实在让人烦躁加沮丧. 还好,测试上百轮, ...
- java 将数字转成成16进制
java 将数字转成成16进制 CreationTime--2018年6月11日17点11分 Author:Marydon 1.前提 数字必须是byte类型,即[-128,127] 2.代码实现 ...
- Unable to instantiate application com.txrj.sms.activity.TxrjApplication
07-18 12:04:57.413: E/AndroidRuntime(4448): FATAL EXCEPTION: main 07-18 12:04:57.413: E/AndroidRunti ...