仿iReader切换皮肤进度条
仿iReader切换皮肤进度条
标签(空格分隔): 自定义View
本以为使用paint.setXfermode(new PorterDuffXfermode(Mode.XOR));
可以轻松搞定,没想到我对PorterDuffXfermode(参考APIDemos代码,路径/APIDemos/Graphics/Xfermodes)
的理解有问题,比较悲催了。最后使用了ClipRect的方式实现了这个东西!
定义属性文件:
<?xml version="1.0" encoding="utf-8"?>
<resources>
<declare-styleable name="ProgressView">
<attr name="text" format="string"/>
<attr name="textSize" format="dimension"/>
<attr name="color" format="color"/>
<attr name="progress" format="integer"/>
<attr name="maxProgress" format="integer"/>
<attr name="crossColor" format="color"/>
</declare-styleable>
</resources>
实现代码:
package com.example.testproject;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Rect;
import android.util.AttributeSet;
import android.view.View;
/**
*
* @author
*
*/
public class ProgressView extends View {
/** 最大进度 **/
private int maxProgress;
/** 当前进度 **/
private int progress;
/** 当前显示的文字 **/
private String text;
/** 进度和没有交叉的时候的文字的颜色 **/
private int color;
/** 文字和进度交叉的时候的文字的颜色 **/
private int crossColor;
/** 画进度和没有交叉的时候的文字的Paint **/
private Paint paint;
/** 表示进度的Rect **/
private Rect rect;
public ProgressView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
init(context, attrs);
}
public ProgressView(Context context, AttributeSet attrs) {
super(context, attrs);
init(context, attrs);
}
public ProgressView(Context context) {
super(context);
init(context, null);
}
private void init(Context context, AttributeSet attrs){
/** 得到XML属性 **/
TypedArray ta = context.obtainStyledAttributes(attrs, R.styleable.ProgressView);
maxProgress = ta.getInt(R.styleable.ProgressView_maxProgress, 100);
progress = ta.getInt(R.styleable.ProgressView_progress, 0);
text = ta.getString(R.styleable.ProgressView_text);
color = ta.getColor(R.styleable.ProgressView_color, Color.GREEN);
crossColor = ta.getColor(R.styleable.ProgressView_crossColor, Color.WHITE);
float textSize = ta.getDimensionPixelOffset(R.styleable.ProgressView_textSize, 20);
ta.recycle();
/** 设置默认的Paint属性 **/
paint = new Paint();
paint.setAntiAlias(true);
paint.setFlags(Paint.ANTI_ALIAS_FLAG);
paint.setStyle(Paint.Style.FILL);
paint.setTextSize(textSize);
paint.setColor(color);
}
@Override
protected void onDraw(Canvas canvas) {
/** 白色背景 **/
canvas.drawColor(Color.WHITE);
/** 恢复颜色 **/
paint.setColor(color);
/** 得到画文字的左上角顶点 **/
int offsetX = (int) ((getWidth() - text.length() * paint.getTextSize()) / 2);
int offsetY = (int) ((getHeight() - paint.getTextSize()) / 2);
/** 画默认文字 **/
canvas.drawText(text, offsetX, offsetY, paint);
/** 画进度 **/
if(rect == null){
rect = new Rect();
rect.left = 0;
rect.top = 0;
rect.bottom = getHeight();
}
rect.right = (int) (getWidth() * progress / (float)maxProgress);
canvas.drawRect(rect, paint);
/** 画交叉的时候的文字 **/
canvas.save();
canvas.clipRect(rect);
paint.setColor(crossColor);
canvas.drawText(text, offsetX, offsetY, paint);
canvas.restore();
}
/**
* 设置最大进度
* @return
*/
public int getMaxProgress() {
return maxProgress;
}
/**
* 得到最大进度
* @param maxProgress
*/
public void setMaxProgress(int maxProgress) {
this.maxProgress = maxProgress;
invalidate();
}
/**
* 得到当前进度
* @return
*/
public int getProgress() {
return progress;
}
/**
* 设置当前进度
* @param progress
*/
public void setProgress(int progress) {
this.progress = progress;
invalidate();
}
/**
* 得到显示的文字
* @return
*/
public String getText() {
return text;
}
/**
* 设置显示的文字
* @param text
*/
public void setText(String text) {
this.text = text;
invalidate();
}
/***
* 设置提示文字的大小
* @param textSize
*/
public void setTextSize(int textSize) {
paint.setTextSize(textSize);
invalidate();
}
/***
* 设置进度和没有交叉的时候的文字的颜色
* @param color
*/
public void setColor(int color) {
this.color = color;
paint.setColor(color);
invalidate();
}
/**
* 设置进度和文字交叉之后的文字颜色
* @param color
*/
public void setCrossColor(int color){
crossColor = color;
invalidate();
}
}
简单测试代码:
package com.example.testproject;
import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.view.ViewGroup.LayoutParams;
public class ProgressTextViewActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
LayoutParams params = new LayoutParams(LayoutParams.MATCH_PARENT,500);
ProgressView view = new ProgressView(ProgressTextViewActivity.this);
view.setText("正在下载...");
view.setTextSize(40);
view.setMaxProgress(10000);
view.setProgress(5000);
view.setColor(Color.parseColor("#FF336699"));
view.setLayoutParams(params);
view.setCrossColor(Color.WHITE);
setContentView(view);
}
}
仿iReader切换皮肤进度条的更多相关文章
- 自定义仿 QQ 健康计步器进度条
自定义仿 QQ 健康计步器进度条 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 源码:CircleProgress 文中如有纰漏,欢迎大家留言指出. 闲着没事,趁上班时间偷偷撸了 ...
- 仿IOS圆形下载进度条
/** * Created by C058 on 2016/5/25. */ public class MyHoriztalProgressBar extends ProgressBar { priv ...
- Android开发-各种各样好看漂亮的进度条,指示器,加载提示汇总
导读:之前项目中用到一些进度条,找了不少,打算写个demo自己总结一下,留着以后用, 有些是自己写的,有些是github上找的别人的库,如果大家觉得好看可以用,直接下载复制代码到项目里就可以用,ok ...
- Qt编写自定义控件17-按钮进度条
前言 按钮进度条,顾名思义,表面上长得像一个按钮,单击以后切换成进度条指示按钮单击动作执行的进度,主要用在一些需要直接在按钮执行动作显示对应进度的场景,在很多网页中经常看到这种效果,这个效果有个优点就 ...
- Android -- 真正的 高仿微信 打开网页的进度条效果
(本博客为原创,http://www.cnblogs.com/linguanh/) 目录: 一,为什么说是真正的高仿? 二,为什么要搞缓慢效果? 三,我的实现思路 四,代码,内含注释 五,使用方法与截 ...
- Core Animation一些Demo总结 (动态切换图片、大转盘、图片折叠、进度条等动画效果)
前一篇总结了Core Animation的一些基础知识,这一篇主要是Core Animation 的一些应用,涉及到CAShapeLayer.CAReplicatorLayer等图层的知识. 先看效果 ...
- Android特效专辑(十一)——仿水波纹流量球进度条控制器,实现高端大气的主流特效
Android特效专辑(十一)--仿水波纹流球进度条控制器,实现高端大气的主流特效 今天看到一个效果挺不错的,就模仿了下来,加上了一些自己想要的效果,感觉还不错的样子,所以就分享出来了,话不多说,上图 ...
- Unity3D 场景切换加载进度条实现
需要三个场景,场景A,场景B,场景C: 场景A:一个按钮,点击加载场景B: 场景B:从A切换到C过度场景,加载进度条: 场景C:目标场景: 创建OnProgress.cs脚本: using Syste ...
- iOS8 无缝切换WKWebView,借鉴IMYWebview,解决进度条,cookie,本地页面等问题
webkit使用WKWebView来代替IOS的UIWebView和OSX的WebView,并且使用Nitro JavaScript引擎,这意味着所有第三方浏览器运行JavaScript将会跟safa ...
随机推荐
- 腾讯DBA官方博客开通了
腾讯DBA官方博客开通了,欢迎交流哈.. http://tencentdba.com 腾讯互娱游戏DBA团队一直致力于为游戏提供稳定.高效的DB运营服务,这是我们团队的使命. 过去DBA团 ...
- Mac上远程桌面连接Windows Server 2012 R2
在将一台服务器的操作系统由Windows Server 2012升级为Windows Server 2012 R2之后,在Mac电脑上用微软的远程桌面软件怎么也连不上服务器,错误信息如下: Remot ...
- EasyUI Jquery 动态加载树,点击节点加载
<script type="text/javascript"> $(function() { $(document).ready(function() { $.post ...
- 【译】用Fragment创建动态的界面布局(附Android示例代码)
原文链接:Building a Dynamic UI with Fragments 为了在Android上创建一个动态和多视图的用户界面,你需要封装UI控件和模块化Activity的行为,以便于你能够 ...
- jenkins和docker 在docker里运行jenkins
在docker里运行jenkins server. 文章来自:http://www.ciandcd.com文中的代码来自可以从github下载: https://github.com/ciandcd ...
- SpringMVC从一个controller跳转到另一个controller
return "redirect:……路径……"; @RequestMapping(value = "/index", method = RequestMeth ...
- 01_JavaScript简介
js用途 前端三层 结构层 HTML 从主义角度描述页面的结构 样式层 CSS 从审美的角度装饰页面 行为层 JS 从交互角度提升体验 HTML 里面的 b(加粗)/i(倾斜)/u(下划线)等标签由于 ...
- paip.ikanalyzer 重加载词库的方法.
paip.ikanalyzer 重加载词库的方法. 作者Attilax 艾龙, EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn ...
- atitit.技术选型方法总结为什么java就是比.net有前途
atitit.技术选型方法总结为什么java就是比.net有前途 #----按照不同的需要有不铜的法... 一般有开发效率,稳定性上的需要.. 作者 老哇的爪子 Attilax 艾龙, EMAIL: ...
- paip.gui控件tabs控件加载内容的原理以及easyui最佳实现
paip.gui控件tabs控件加载内容的原理以及easyui最佳实现 //////////////tabs控件的加载 同form窗体一样,俩个方式 两个方式:一个是url,简单的文本可以使用这个,不 ...