Android实现渐变色的圆弧虚线效果

所属分类: 软件编程 / Android 阅读数: 51
收藏 0 赞 0 分享

首先来看看效果图:


1,SweepGradient(梯度渲染)

public SweepGradient (float cx, float cy, int[] colors, float[] positions)

扫描渲染,就是以某个点位中心旋转一周所形成的效果!参数依次是:

      cx:扫描的中心x坐标

      cy:扫描的中心y坐标

      colors:梯度渐变的颜色数组

      positions:指定颜色数组的相对位置

public static final int[] SWEEP_GRADIENT_COLORS = new int[]{Color.GREEN, Color.GREEN, Color.BLUE, Color.RED, Color.RED};
mColorShader = new SweepGradient(radius, radius,SWEEP_GRADIENT_COLORS,null);

效果图:


SweepGradient

2,DashPathEffect(Path的线段虚线化)

DashPathEffect(float[] intervals, float phase)

      intervals:为虚线的ON和OFF的数组,数组中元素数目需要 >= 2

      phase:为绘制时的偏移量

//计算路径的长度
PathMeasure pathMeasure = new PathMeasure(mPath, false);
float length = pathMeasure.getLength();
float step = length / 60;
dashPathEffect = new DashPathEffect(new float[]{step / 3, step * 2 / 3}, 0);

效果图:


DashPathEffect

3,下面是全部的代码:

package com.example.yyw.xfermodedemo;

import android.animation.ValueAnimator;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.DashPathEffect;
import android.graphics.Paint;
import android.graphics.Path;
import android.graphics.PathMeasure;
import android.graphics.RectF;
import android.graphics.SweepGradient;
import android.util.AttributeSet;
import android.view.View;

/**
 * Created by yyw on 2016/10/11.
 */

public class OilTableLine extends View {
 public static final int[] SWEEP_GRADIENT_COLORS = new int[]{Color.GREEN, Color.GREEN, Color.BLUE, Color.RED, Color.RED};
 private int tableWidth = 50;
 private Paint mPaint;
 private Path mPath;
 private RectF mTableRectF;
 //把路径分成虚线段的
 private DashPathEffect dashPathEffect;
 //给路径上色
 private SweepGradient mColorShader;
 //指针的路径
 private Path mPointerPath;
 private float mCurrentDegree = 60;

 public OilTableLine(Context context, AttributeSet attrs) {
  super(context, attrs);
  mPaint = new Paint();
  mPaint.setAntiAlias(true);
  mPaint.setDither(true);
  mPaint.setColor(Color.BLACK);
  mPath = new Path();
  mPointerPath = new Path();
  startAnimator();

 }

 @Override
 protected void onSizeChanged(int w, int h, int oldw, int oldh) {
  super.onSizeChanged(w, h, oldw, oldh);
  float size = Math.min(w, h) - tableWidth * 2;
  //油表的位置方框
  mTableRectF = new RectF(0, 0, size, size);
  mPath.reset();
  //在油表路径中增加一个从起始弧度
  mPath.addArc(mTableRectF, 60, 240);
  //计算路径的长度
  PathMeasure pathMeasure = new PathMeasure(mPath, false);
  float length = pathMeasure.getLength();
  float step = length / 60;
  dashPathEffect = new DashPathEffect(new float[]{step / 3, step * 2 / 3}, 0);

  float radius = size / 2;
  mColorShader = new SweepGradient(radius, radius,SWEEP_GRADIENT_COLORS,null);
  //设置指针的路径位置
  mPointerPath.reset();
  mPointerPath.moveTo(radius, radius - 20);
  mPointerPath.lineTo(radius, radius + 20);
  mPointerPath.lineTo(radius * 2 - tableWidth, radius);
  mPointerPath.close();
 }

 @Override
 protected void onDraw(Canvas canvas) {
  super.onDraw(canvas);
  float dx = (getWidth() - mTableRectF.width()) / 2;
  float dy = (getHeight() - mTableRectF.height()) / 2;
  //把油表的方框平移到正中间
  canvas.translate(dx, dy);
  canvas.save();
  //旋转画布
  canvas.rotate(90, mTableRectF.width() / 2, mTableRectF.height() / 2);
  mPaint.setStyle(Paint.Style.STROKE);
  mPaint.setStrokeWidth(tableWidth);
  mPaint.setPathEffect(dashPathEffect);
  mPaint.setShader(mColorShader);
  canvas.drawPath(mPath, mPaint);
  canvas.restore();
  //还原画笔
  mPaint.setPathEffect(null);
  mPaint.setShader(null);
  mPaint.setStyle(Paint.Style.FILL);
  mPaint.setStrokeWidth(tableWidth / 10);
  canvas.save();
  canvas.rotate(150 + mCurrentDegree, mTableRectF.width() / 2, mTableRectF.height() / 2);
  canvas.drawPath(mPointerPath, mPaint);
  canvas.restore();
 }

 public void startAnimator() {
  ValueAnimator animator = ValueAnimator.ofFloat(0, 240);
  animator.setDuration(40000);
  animator.setRepeatCount(ValueAnimator.INFINITE);
  animator.setRepeatMode(ValueAnimator.RESTART);
  animator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
   @Override
   public void onAnimationUpdate(ValueAnimator animation) {
    mCurrentDegree = (int) (0 + (Float) animation.getAnimatedValue());
    invalidate();
   }
  });
  animator.start();
 }
}

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

更多精彩内容其他人还在看

Android网络编程之获取网络上的Json数据实例

这篇文章主要介绍了Android网络编程之获取网络上的Json数据实例,本文用完整的代码实例讲解了在Android中读取网络中Json数据的方法,需要的朋友可以参考下
收藏 0 赞 0 分享

Android中的windowSoftInputMode属性详解

这篇文章主要介绍了Android中的windowSoftInputMode属性详解,本文对windowSoftInputMode的9个属性做了详细总结,需要的朋友可以参考下
收藏 0 赞 0 分享

Android网络编程之UDP通信模型实例

这篇文章主要介绍了Android网络编程之UDP通信模型实例,本文给出了服务端代码和客户端代码,需要的朋友可以参考下
收藏 0 赞 0 分享

Android中使用ListView实现漂亮的表格效果

这篇文章主要介绍了Android中使用ListView实现漂亮的表格效果,本文用详细的代码实例创建了一个股票行情表格,需要的朋友可以参考下
收藏 0 赞 0 分享

Android中刷新界面的二种方法

这篇文章主要介绍了Android中刷新界面的二种方法,本文使用Handler、postInvalidate两种方法实现界面刷新,需要的朋友可以参考下
收藏 0 赞 0 分享

Android SDK三种更新失败及其解决方法

这篇文章主要介绍了Android SDK三种更新失败及其解决方法,需要的朋友可以参考下
收藏 0 赞 0 分享

Android学习笔记——Menu介绍(一)

Android3.0(API level 11)开始,Android设备不再需要专门的菜单键。随着这种变化,Android app应该取消对传统6项菜单的依赖。取而代之的是提供anction bar来提供基本的用户功能
收藏 0 赞 0 分享

Android学习笔记——Menu介绍(二)

这次将继续上一篇文章没有讲完的Menu的学习,上下文菜单(Context menu)和弹出菜单(Popup menu)
收藏 0 赞 0 分享

Android学习笔记——Menu介绍(三)

今天继续昨天没有讲完的Menu的学习,主要是Popup Menu的学习,需要的朋友可以参考下
收藏 0 赞 0 分享

Android显示网络图片实例

这篇文章主要介绍了Android显示网络图片的方法,以实例形式展示了Android程序显示网络图片的方法,非常具有实用价值,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多