Android仿支付宝UI功能开发,Android 自定义view仿支付宝咻一咻功能

支付宝上有一个咻一咻的功能,就是点击图片后四周有水波纹的这种效果,今天也写一个类似的功能。

效果如下所示:

3797386159c5b80ef6d3d4865990dfbf.gif

思路:

就是几个圆的半径不断在变大,这个可以使用动画缩放实现,还有透明动画

还有就是这是好几个圆,然后执行的动画有个延迟效果,其实这些动画是放在一起执行的,熟悉属性动画的知道已经给我们提供了同步执行动画和顺序执行动画的实现api,也会会有人说这几个view就是在onDraw()方法中画几个圆,可能会说我还要继承容器view去onLayout()方法中这些子view添加在某个特定的区域,当然这也是可以的,其实简单的就是以图片为中心(图片imageview在父view的中心),然后画圆,指定每个字view的宽和高就行了,具体看代码:

package com.zhifubaoxiuyixiu.view;

import android.animation.Animator;

import android.animation.AnimatorSet;

import android.animation.ObjectAnimator;

import android.content.Context;

import android.graphics.Color;

import android.graphics.Paint;

import android.util.AttributeSet;

import android.view.Gravity;

import android.view.View;

import android.view.animation.AccelerateDecelerateInterpolator;

import android.widget.FrameLayout;

import java.util.ArrayList;

/**

* Created by admin on 2016/12/29.

*/

public class ZhifubaoFrameLayout extends FrameLayout {

private int rippleColor = Color.parseColor("#0099CC");//水波纹的颜色

private int radius = 0;//水波纹圆的半径

private long anim_duration = 3000;//动画执行的时间

private int water_ripple_count = 6;

private int scale = 6;//动画缩放比例

private long animDelay;//动画延迟的时间

private Paint paint;

private AnimatorSet animatorSet;

private ArrayList animatorList;

private FrameLayout.LayoutParams rippleParams;

private ArrayList rippleViewList=new ArrayList();

private boolean isAnimRunning = false;

public ZhifubaoFrameLayout(Context context) {

this(context,null);

}

public ZhifubaoFrameLayout(Context context, AttributeSet attrs) {

this(context,attrs,0);

}

public ZhifubaoFrameLayout(Context context, AttributeSet attrs, int defStyleAttr) {

super(context, attrs, defStyleAttr);

initPaint();

addChildView();

initAnim();

}

/**

* 初始化动画

*/

private void initAnim() {

animatorSet = new AnimatorSet();

animatorSet.setInterpolator(new AccelerateDecelerateInterpolator());

animatorList=new ArrayList();

for(int i=0;i

final ObjectAnimator scaleXAnimator = ObjectAnimator.ofFloat(rippleViewList.get(i), "ScaleX", 1.0f, scale);

scaleXAnimator.setRepeatCount(ObjectAnimator.INFINITE);

scaleXAnimator.setRepeatMode(ObjectAnimator.RESTART);

scaleXAnimator.setStartDelay(i * animDelay);

scaleXAnimator.setDuration(anim_duration);

animatorList.add(scaleXAnimator);

final ObjectAnimator scaleYAnimator = ObjectAnimator.ofFloat(rippleViewList.get(i), "ScaleY", 1.0f, scale);

scaleYAnimator.setRepeatCount(ObjectAnimator.INFINITE);

scaleYAnimator.setRepeatMode(ObjectAnimator.RESTART);

scaleYAnimator.setStartDelay(i * animDelay);

scaleYAnimator.setDuration(anim_duration);

animatorList.add(scaleYAnimator);

final ObjectAnimator alphaAnimator = ObjectAnimator.ofFloat(rippleViewList.get(i), "Alpha", 1.0f, 0f);

alphaAnimator.setRepeatCount(ObjectAnimator.INFINITE);

alphaAnimator.setRepeatMode(ObjectAnimator.RESTART);

alphaAnimator.setStartDelay(i * animDelay);

alphaAnimator.setDuration(anim_duration);

animatorList.add(alphaAnimator);

}

animatorSet.playTogether(animatorList);

}

/**

* 添加水波纹子view

*/

private void addChildView() {

radius = 32;

animDelay=350;

rippleParams=new FrameLayout.LayoutParams((int)(2*(radius)),(int)(2*(radius)));

rippleParams.gravity = Gravity.CENTER;

for(int i=0;i

WateRipple rippleView=new WateRipple(getContext(),paint);

addView(rippleView,rippleParams);

rippleViewList.add(rippleView);

}

}

/**

* 初始化画笔

*/

private void initPaint() {

paint = new Paint();

paint.setAntiAlias(true);

paint.setColor(rippleColor);

paint.setStyle(Paint.Style.FILL);

}

/**

* 开启动画

*/

public void startRippleAnimation(){

if(!isRunning()){

for(WateRipple wateRipple:rippleViewList){

wateRipple.setVisibility(VISIBLE);

}

animatorSet.start();

isAnimRunning=true;

}

}

/**

* 动画停止运行

*/

public void stopAnimation(){

if(isRunning()){

animatorSet.cancel();

isAnimRunning=false;

}

}

/**

* 判断是否动画在运行

* @return

*/

public boolean isRunning(){

return isAnimRunning;

}

/**

* ui不可见时关闭动画

* @param visibility

*/

@Override

protected void onWindowVisibilityChanged(int visibility) {

super.onWindowVisibilityChanged(visibility);

if(visibility==View.INVISIBLE||visibility ==View.GONE){

stopAnimation();

}

}

}

每个水波纹view

package com.zhifubaoxiuyixiu.view;

import android.content.Context;

import android.graphics.Canvas;

import android.graphics.Paint;

import android.view.View;

/**

* Created by admin on 2016/12/29.

*/

public class WateRipple extends View {

private Paint mPaint;

public WateRipple(Context context, Paint paint){

super(context);

if(paint==null){

this.mPaint = new Paint();

}else{

this.mPaint = paint;

}

setVisibility(View.INVISIBLE);//刚开始设置不可见

}

public WateRipple(Context context) {

super(context);

}

@Override

protected void onDraw(Canvas canvas) {

super.onDraw(canvas);

int radius=(Math.min(getWidth(),getHeight()))/2;

canvas.drawCircle(radius,radius,radius,mPaint);

}

}

圆形图片:

package com.zhifubaoxiuyixiu.view;

import android.content.Context;

import android.graphics.Bitmap;

import android.graphics.BitmapFactory;

import android.graphics.BitmapShader;

import android.graphics.Canvas;

import android.graphics.Paint;

import android.graphics.Shader;

import android.graphics.drawable.ShapeDrawable;

import android.graphics.drawable.shapes.OvalShape;

import android.util.AttributeSet;

import android.view.View;

import com.zhifubaoxiuyixiu.R;

/**

* Created by admin on 2016/12/29.

*/

public class CircleView extends View {

private BitmapShader bitmapShaderp ;

private ShapeDrawable shapeDrawable;

public CircleView(Context context) {

this(context,null);

}

public CircleView(Context context, AttributeSet attrs) {

this(context, attrs,0);

}

public CircleView(Context context, AttributeSet attrs, int defStyleAttr) {

super(context, attrs, defStyleAttr);

initBitmap();

}

private void initBitmap() {

Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.mipmap.grid);

shapeDrawable = new ShapeDrawable(new OvalShape());

bitmapShaderp = new BitmapShader(bitmap, Shader.TileMode.CLAMP,Shader.TileMode.CLAMP);

shapeDrawable.getPaint().setShader(bitmapShaderp);

}

@Override

protected void onDraw(Canvas canvas) {

super.onDraw(canvas);

shapeDrawable.setBounds(0,0,getWidth(),getHeight());

shapeDrawable.draw(canvas);

}

}

布局文件:

xmlns:android="http://schemas.android.com/apk/res/android"

android:layout_width="match_parent"

android:layout_height="match_parent"

>

android:layout_width="match_parent"

android:layout_height="match_parent"

android:id="@+id/root"

>

android:layout_width="64dp"

android:layout_height="64dp"

android:layout_centerInParent="true"

android:id="@+id/imageView"

android:layout_gravity="center"

android:src="@mipmap/grid"/>

使用:

package com.zhifubaoxiuyixiu;

import android.app.Activity;

import android.os.Bundle;

import android.view.View;

import com.zhifubaoxiuyixiu.view.CircleView;

import com.zhifubaoxiuyixiu.view.ZhifubaoFrameLayout;

public class MainActivity extends Activity {

private CircleView imageView;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

imageView = (CircleView) findViewById(R.id.imageView);

final ZhifubaoFrameLayout root = (ZhifubaoFrameLayout) findViewById(R.id.root);

imageView.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View view) {

root.startRippleAnimation();

}

});

}

}

以上所述是小编给大家介绍的Android 自定义view仿支付宝咻一咻功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/488226.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学习git

git一直没掌握熟练,写记录一下常用的操作及遇到的问题 远程克隆库: git clone ssh://gitxxx or git clone http://gitxxx 库初始化: git init 查看当前分支 : git branch 查看远程分支: git branch -r 提交文件到远程仓…

tensorflow 读取cifar_TensorFlow实战4——TensorFlow实现Cifar10识别

1 importcifar10, cifar10_input2 importtensorflow as tf3 importnumpy as np4 importtime5 importmath67 max_steps 30008 batch_size 1289 data_dir /tmp/cifar10_data/cifar-10-batches-bin101112 defvariable_with_weight_loss(shape, stddev, w1):13 定义初始化weight…

​CPU将进入新时代:押注计算芯片的极限协同设计

来源:内容由半导体行业观察(icbank)编译自「nextplatform」,作者:Timothy Prickett Morgan,谢谢。我们现在进入了一个时代,那就是IT行业的计算引擎将需要比以往任何时候都更需要更低的价格&…

rk3288 android编译环境搭建,RK3288系统编译及环境搭建

准备工作编译 Android 对机器的配置要求较高:64 位 CPU16GB 物理内存交换内存30GB 空闲的磁盘空间用于构建,源码树另外占用大约 8GB官方推荐 Ubuntu 12.04 操作系统,实际上也可以采用更新的操作系统版本,只需要满足 http://source…

50 days before NOI2017

2017.5.31 今天开了这个博客,打算每天来写点东西,嗯。。。毕竟要NOI了嘛。。。 第一天跑到常州里集训,打开题目一看湖南集训题。。。 T1刷一下写完,然后交了然后发现错了。。。赶紧改过来,大概1h吧。。。 T2刷一下发现…

2020城市大脑与超级智能建设规范研究报告(附下载)

报告下载地址: https://pan.baidu.com/s/1x85xZrAG6df4BcVkJqtcqw提取码: 6ytv21世纪以来,21世纪以来,眼花缭乱的前沿科技新概念喷薄而出,从Web2.0、社交网络、物联网、移动互联网、大数据、工业4.0、工业互联网到云机器人、深度学习、边缘计…

android按钮点击无响应时间,AndroidStudio下的点击事件不响应

本来是测试自定义Toast,发现implements View.OnClickListener的Onclick事件怎么都不响应,开始以为是自定义的问题。结果当然不是;需要clean项目就好了,AndroidStudio的问题还是很多~Overridepublic void onBackPressed() {ToastUt…

同步带周长计算公式_同步带的长度计算和常见问题

同步带的长度计算公式如下:lb ((df dm) 1.5708 ) (2 lfm)其中lb是同步带的长度,df是大同步带轮的直径,dm是小同步带轮的直径,lfm是大同步带轮的中心和小同步带轮中心的距离。从上述同步带长度的计算公式可以看出同步带轮的直径对…

nodejs中处理回调函数的异常

假设是使用nodejsexpress3这个经典的组合。那么有一种非常方面的处理回调函数异常的方法: 1. 安装模块:express-domain-middleware 2. 增加例如以下的代码: app.use(require(express-domain-middleware)); app.use(function errorHandler(err…

5G新标准将延迟3个月发布,但5G“新战场”已经明确

来源:雷锋网2019年,5G开启商用元年。2020年开年,5G智能手机的发布就迎来了一个发布高峰,2月份至今,国内就有10多款5G手机发布。5G手机的数量和销量也迅速增长,根据工信部副部长辛国斌给出的数据&#xff0c…

python copy deepcopy_python-copy-deepcopy

1.结论:—–我们寻常意义的复制就是深复制,即将被复制对象完全再复制一遍作为独立的新个体单独存在。所以改变原有被复制对象不会对已经复制出来的新对象产生影响。—–而浅复制并不会产生一个独立的对象单独存在,他只是将原有的数据块打上一…

android 2个界面抽屉,Android使用DrawerLayout创建左右两个抽屉菜单

在Android support.v4 中有一个抽屉视图控件DrawerLayout。使用这个控件,可以生成通过在屏幕上水平滑动打开或者关闭菜单,能给用户一个不错的体验效果。最近在项目中,设计中有用到这个效果,但是是左右两边都能划出这样的一个菜单效…

报告:100家AI初创公司榜单 这五大趋势不得不看!

来源: 网易智能用新药治疗一系列慢性疾病;抵御各种网络攻击;让城市更加智能;更精准地预报天气和野火,从而提高安全性并降低风险。此外,还有深度伪造技术(deepfakes)的商业化。这些看…

android默认exported_AndroidManifest.xml文件中exported属性解析

4、目标Activity的属性Android:exported”true”如果组件包含有intent-filter则 exported默认值为true;没有intent-filter则exported默认值为false。当exported为 true时可以被外部其他App所调用当exported为 false时可以被外部其他App所调用5、目标Activity具有相应的IntentFi…

android外接键盘打汉字,Android在外接物理键盘时,如何强制调用系统软键盘

Android在外接物理键盘时,如何强制调用系统软键盘?第一次写,写的不好请见谅参考:物理键盘映射过程:手机/system/usr/keylayout/*.kl :内核将keyCode映射成有含义的字符串KeycodeLabels.h : framework 将字符…

20155204 2016-2017-2《Java程序设计》课程总结

20155204 2016-2017-2《Java程序设计》课程总结 目录 作业链接汇总作业总结实验报告链接汇总代码托管链接课堂项目实践学习经验问卷调查链接二维码(按顺序)每周作业链接汇总 预备作业1:我对师生关系的思考预备作业2:做中学感悟预备…

android网络测试上传速度慢,Android:如何获得互联网连接上传速度和延迟?

要获取当前网络连接类型:TelephonyManager telephonyManager (TelephonyManager) getSystemService(Context.TELEPHONY_SERVICE);int networkType telephonyManager.getNetworkType();并为延迟:String host "172.16.0.2";int timeOut 3000…

复杂性科学与还原论

来源:陶勇科学网博客1984年,两位诺贝尔物理学奖得主盖尔曼(Murray Gell-mann)、安德森(Philip Anderson)和诺贝尔经济学奖得主阿罗(Kenneth Arrow)聚集了一批从事物理、经济、生物、…

ios math 那个头文件_C++ 头文件系列(ios)

1 简介我们都知道,平时常用的那些标准流,诸如iostream、ofstream、ifstream等等,其实都是对应的basic_XXX模版的实例类。 而这些basic_XXX类模版又都是继承自同一个基类模版----basic_ios。2 basic_ios模版定义这个基类模版应该是出于可重用的…

Nim游戏(初谈博弈)

通常的Nim游戏的定义是这样的:有若干堆石子,每堆石子的数量都是有限的,合法的移动是“选择一堆石子并拿走若干颗(不能不拿)”, 如果轮到某个人时所有的石子堆都已经被拿空了,则判负(…