• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >Android > Android特效专辑(十)——点击水波纹效果实现,逻辑清晰实现简单

Android特效专辑(十)——点击水波纹效果实现,逻辑清晰实现简单

作者:网友 字体:[增加 减小] 来源:互联网 时间:2017-05-26

网友通过本文主要向大家介绍了android水波纹效果,android 水波纹,android水波纹动画,android 波纹效果,android 波纹等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

Android特效专辑(十)——点击水波纹效果实现,逻辑清晰实现简单


Android特效专辑(十)——点击水波纹效果实现,逻辑清晰实现简单

这次做的东西呢,和上篇有点类似,就是用比较简单的逻辑思路去实现一些比较好玩的特效,最近也是比较忙,所以博客更新的速度还得看时间去推演,但是也能保证一周三更的样子,现在也还是以小功能,或者说是一些小入门级别的博客为主,我也不算是什么很厉害的人,很多细节的支持处理的仍然还是不到位,所以也是一直在弥补,话不多说,来看看今天的效果

这里写图片描述

实现起来很简单吧,那我们就来看一下他是怎么实现的咯!

OnclickRuning

package com.lgl.onclickruning;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Paint.Style;
import android.os.Handler;
import android.util.AttributeSet;
import android.util.Log;
import android.view.MotionEvent;
import android.view.View;

/**
 * 点击水波纹涟漪动画效果
 * 
 * @author LGL
 * 
 */
public class Runing extends View {

    // 画笔
    private Paint mPaint;
    // 内圆宽度
    private int strokeWidth;
    // 圆心x
    private int cx;
    // 圆心y
    private int cy;
    // 半径
    private int radius;
    // Handler消息
    private static final int FLUSH = 0;

    public Runing(Context context, AttributeSet attrs) {
        super(context, attrs);

        init();

    }

    private void init() {

        // 初始化画笔
        mPaint = new Paint();
        // 抗锯齿
        mPaint.setAntiAlias(true);
        // 设置颜色
        mPaint.setColor(Color.BLUE);
        // 设置空心
        mPaint.setStyle(Style.STROKE);
        // 设置内圆的宽度
        mPaint.setStrokeWidth(strokeWidth);
        // 设置透明度 0-255
        mPaint.setAlpha(255);

        // 初始值
        strokeWidth = 0;
        radius = 0;
    }

    /**
     * 绘制
     */
    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        // 绘制圆环
        canvas.drawCircle(cx, cy, radius, mPaint);
    }

    /**
     * 触摸事件
     */
    @Override
    public boolean onTouchEvent(MotionEvent event) {

        // 判断手势按下和抬起
        switch (event.getAction()) {
        case MotionEvent.ACTION_DOWN:
            /**
             * 按下去开始画圆,也就是起涟漪,所以我们首先得获取到按下的坐标,事实上,我们要做这样操作的开发,都必须先提前拿到该有的坐标
             */
            cx = (int) event.getX();
            cy = (int) event.getY();
            Log.i("坐标", "圆心x:" + cx + "圆心y:" + cy);

            break;
        }
        // 初始化
        init();
        // 发送
        handler.sendEmptyMessage(FLUSH);
        return true;
    }

    /**
     * 刷新状态
     */
    private void flush() {
        // 半径每次+10
        radius += 10;
        // 线条的宽度每次都是半径的四分之一
        strokeWidth = radius / 4;
        // 重新设置给画笔
        mPaint.setStrokeWidth(strokeWidth);
        // 颜色渐变,每次减少20的色值
        int nextAlpha = mPaint.getAlpha() - 20;
        // 避免等于负数
        if (nextAlpha < 20) {
            // 直接设置为透明
            nextAlpha = 0;
        }
        // 继续重新设置给画笔
        mPaint.setAlpha(nextAlpha);
    }

    private Handler handler = new Handler() {
        public void handleMessage(android.os.Message msg) {
            switch (msg.what) {
            case FLUSH:
                // 更改参数状态
                flush();
                // 刷新 执行我们的绘制方法
                invalidate();
                // 继续验证透明度,只要不为0就一直发送,直到透明
                if (mPaint.getAlpha() != 0) {
                    handler.sendEmptyMessageDelayed(FLUSH, 100);
                }
                break;
            }
        }
    };
}

layout_main.xml

<code class=" hljs avrasm"><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">

    <com.lgl.onclickruning.runing android:layout_width="match_parent" android:layout_height="match_parent">

</com.lgl.onclickruning.runing></relativelayout>
</code>

代码其实很简单,我们简单的逻辑就可以实现了,但是别小看了这个思维,你可以用这个逻辑去实现更多有趣的特效,这里就期待你的挖掘了,嘻嘻

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • Android特效专辑(十)——点击水波纹效果实现,逻辑清晰实现简单

相关文章

  • 2017-05-26Smalidea+IntelliJ IDEA/Android Studio动态调试安卓app教程
  • 2017-05-26MAT使用入门,mat入门
  • 2017-05-26Android 手机卫士8--删除通话记录,android8--
  • 2017-05-26Android中Activity运行时屏幕方向与显示方式详解,androidactivity
  • 2017-05-26Android触摸事件(一)-AbsTouchEventHandle
  • 2017-05-26自己写的书《深入理解Android虚拟机内存管理》,不出版只是写着玩,深入理解java虚拟机
  • 2017-05-26getDrawingCache()和Android中的截图方法简介
  • 2017-05-26IDA动态调试Android的DEX文件
  • 2017-05-26关于Android项目隐藏标题栏的方法总结,android标题栏
  • 2017-05-26一个帖子学会Android开发四大组件,android四大

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • Android面试准备 第二天 第五例 数据存储
    • Android API Guides---App Widgets
    • Android小知识,理财小知识
    • 安卓四大组件之广播,安卓四大组件
    • Android--根据子控件的大小自动换行的ViewGroup,android--viewgroup
    • Android,androidstudio
    • Android 实现闪屏页和右上角的倒计时跳转,android跳转
    • Android入门——Drawable与对应的资源xml的应用
    • APK瘦身记,如何实现高达53%的压缩效果,apk53%
    • 百度地图开发的学习(一),百度地图开发学习

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有