RadialGradient环形渲染

学习自:http://blog.csdn.net/q445697127/article/details/7865672

package com.example.demo;

import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.RadialGradient;
import android.graphics.Shader;
import android.view.View;

public class RadialGameView extends View implements Runnable {
    Paint mPaint = null;
    // 环形渐变渲染
    Shader mRadialGradient = null;

    public RadialGameView(Context context) {
        super(context);

        // 创建RadialGradient对象
        // 第一个,第二个参数表示渐变圆中心坐标
        // 第三个参数表示半径
        // 第四个,第五个,第六个与线性渲染相同
        mRadialGradient = new RadialGradient(250, 250, 150, new int[] {
                Color.GREEN, Color.RED, Color.WHITE, Color.BLUE }, null,
                Shader.TileMode.REPEAT);

        mPaint = new Paint();
        new Thread(this).start();
    }

    @Override
    protected void onDraw(Canvas canvas) {
        // 绘制环形渐变
        mPaint.setShader(mRadialGradient);
        // 第一个,第二个参数表示圆心坐标
        // 第三个参数表示半径
        canvas.drawCircle(250, 250, 150, mPaint);
    }

    @Override
    public void run() {
        while(!Thread.currentThread().isInterrupted()) {
            try {
                Thread.sleep(100);
            }
            catch(Exception e) {
                Thread.currentThread().interrupt();
            }
            postInvalidate();
        }
    }
}

完整工程代码:http://download.csdn.net/detail/yegucheng2618/7646667

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于大量数据的散点图,我们可以采用 echarts 中的数据分块加载方式进行渲染,这样可以有效减少渲染的时间和内存占用。以下是使用数据分块加载方式绘制散点图的一些步骤和配置项: 1. 在使用 echarts 绘制散点图时,需要将数据分块后绑定到散点图的数据源中。可以使用 echarts 提供的 `dataZoom` 组件实现数据分块加载方式。 2. 在配置项中配置 `dataZoom` 组件的相关属性,如 `start` 和 `end` 属性来控制数据的加载范围。 3. 在配置项中配置 `visualMap` 组件的相关属性,如 `min` 和 `max` 属性来控制散点图的颜色显示范围。 4. 如果散点图中数据点过多,可以使用 echarts 的 `symbolSize` 属性来控制数据点的大小,从而避免数据点之间的重叠。 下面是一个示例代码,具体实现可以根据自己的需求进行调整: ```javascript option = { xAxis: {}, yAxis: {}, dataZoom: { type: 'slider', show: true, start: 0, end: 50 }, visualMap: { min: 0, max: 100, calculable: true, inRange: { color: ['#50a3ba', '#eac736', '#d94e5d'] }, textStyle: { color: '#fff' } }, series: [{ type: 'scatter', data: data, symbolSize: function (value) { return Math.sqrt(value[2]) / 5e2; }, label: { emphasis: { show: true, formatter: function (param) { return param.data[3]; }, position: 'top' } }, itemStyle: { normal: { shadowBlur: 10, shadowColor: 'rgba(120, 36, 50, 0.5)', shadowOffsetY: 5, color: new echarts.graphic.RadialGradient(0.4, 0.3, 1, [{ offset: 0, color: 'rgb(251, 118, 123)' }, { offset: 1, color: 'rgb(204, 46, 72)' }]) } } }] }; ``` 以上代码中,数据源 `data` 应该是一个数组,每个元素代表一个散点的位置和大小信息,例如: ```javascript var data = [ [10.0, 8.04, 10], [8.0, 6.95, 20], [13.0, 7.58, 30], [9.0, 8.81, 40], [11.0, 8.33, 50], [14.0, 9.96, 60], [6.0, 7.24, 70], [4.0, 4.26, 80], [12.0, 10.84, 90], [7.0, 4.82, 100], [5.0, 5.68, 110] ]; ``` 其中,每个元素的前两个数值代表散点的 x 和 y 坐标,第三个数值代表散点的大小。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值