canvas实现环形图 uni-app(含渐变,数据流形式)

简介: canvas实现环形图 uni-app(含渐变,数据流形式)

基本参数

 

普通环形图

实现效果

实现流程

1.通过标签给出canvas宽高,绑定canvas-id一会根据这个进行生成

<canvas class="progress_bg" canvas-id="cpbg"></canvas>

2.页面挂载调用方法进行环形图渲染

下方ctx.beginPath()开辟新路径前后共生成两个环形图,第一个代表下方灰色,第二个代表蓝色

                var ctx = uni.createCanvasContext('cpbg', this);
        let end = (50 / 100 ) * 2 * Math.PI; //设置弧度
        console.log(end);
        ctx.setLineWidth(12); // 设置圆环的宽度
        ctx.arc(185, 80, 40, 0, 2 * Math.PI)
        ctx.setStrokeStyle('#f2f2f2');
        ctx.stroke(); //对当前路径进行描边
        // ctx.setLineCap('square'); // 设置圆环端点的形状  无圆角
        ctx.beginPath(); //开始一个新的路径
        ctx.setStrokeStyle('#0079fe'); // 设置圆环的颜色
        ctx.setLineCap('round'); // 设置圆环端点的形状  圆角
        ctx.arc(185, 80, 40, 0, end, false);
        ctx.stroke(); //对当前路径进行描边
        //设置一个原点(110,110),半径为100的圆的路径到当前路径
        ctx.stroke(); //对当前路径进行描边
        ctx.draw();

渐变环形图

效果

代码

                var ctx = uni.createCanvasContext('cpbar', this);
        // 进度条的渐变(中心x坐标-半径-边宽,中心Y坐标,中心x坐标+半径+边宽,中心Y坐标)
        var gradient = ctx.createLinearGradient(0, 0, 150, 0);
        let increase = 0.05;
        let end = (50 / 100) * 2 * Math.PI - Math.PI / 2; // 最后的角度
        let current = -Math.PI / 2; // 起始角度
        let timer = setInterval(() => {
          gradient.addColorStop('0', '#00F2FE'); //渐变颜色
          gradient.addColorStop('1.0', '#0079fe'); //渐变颜色
          // 圆弧粗度
          ctx.setLineWidth(12);
          ctx.setStrokeStyle(gradient);
          ctx.setLineCap('square');
          ctx.beginPath();
          // 参数step 为绘制的百分比
          if (current < end) {
            current = current + increase;
          }
          if (current >= end) {
            current = end;
            clearInterval(timer);
          }
          ctx.arc(85, 65, 40, -Math.PI / 2, current, false);
          ctx.stroke();
          ctx.draw();
        }, 20);

数据流环形图

效果

代码

<view class="progress_box">
    <canvas class="progress_bg" canvas-id="cpbg"></canvas>
    <canvas class="progress_bar" canvas-id="cpbar"></canvas>
    <canvas class="progress_line" canvas-id="cpline"></canvas>
    <view class="progress_txt">
      <view class="progress_info">{{ progress_txt }}%</view>
      <view class="pcds">正确率</view>
    </view>
  </view>
mounted: function() {
      this.drawProgressbg();
      this.drawCircle(this.progress_txt); //参数为1-100
      this.drawLine();
    },
methods: {
            drawProgressbg: function() {
        // 自定义组件实例 this ,表示在这个自定义组件下查找拥有 canvas-id 的 <canvas/>
        var ctx = uni.createCanvasContext('cpbg', this);
        ctx.setLineWidth(12); // 设置圆环的宽度
        ctx.setStrokeStyle('#E9E9E9'); // 设置圆环的颜色
        // ctx.setLineCap('round'); // 设置圆环端点的形状
        ctx.setLineCap('square'); // 设置圆环端点的形状
        ctx.beginPath(); //开始一个新的路径
        ctx.arc(85, 65, 40, 0 * Math.PI, 2 * Math.PI, false);
        //设置一个原点(110,110),半径为100的圆的路径到当前路径
        ctx.stroke(); //对当前路径进行描边
        ctx.draw();
      },
      drawCircle: function(step) {
        var ctx = uni.createCanvasContext('cpbar', this);
        // 进度条的渐变(中心x坐标-半径-边宽,中心Y坐标,中心x坐标+半径+边宽,中心Y坐标)
        var gradient = ctx.createLinearGradient(0, 0, 130, 0);
        let increase = 0.05;
        let end = (step / 100) * 2 * Math.PI - Math.PI / 2; // 最后的角度
        let current = -Math.PI / 2; // 起始角度
        let timer = setInterval(() => {
          gradient.addColorStop('0', '#00F2FE');
          gradient.addColorStop('1.0', '#4FACFE');
          ctx.setLineWidth(12);
          ctx.setStrokeStyle(gradient);
          ctx.setLineCap('square');
          ctx.beginPath();
          // 参数step 为绘制的百分比
          if (current < end) {
            current = current + increase;
          }
          if (current >= end) {
            current = end;
            clearInterval(timer);
          }
          ctx.arc(85, 65, 40, -Math.PI / 2, current, false);
          ctx.stroke();
          ctx.draw();
        }, 20);
      },
      // 画刻度
      drawLine() {
        var context = uni.createCanvasContext("cpline", this);
        var r = 40;
        var x0 = 85;
        var y0 = 65;
        var x;
        var y;
        var lineWidth = 12;
        for (let i = 0; i < 60; i++) {
          context.beginPath();
          context.setLineWidth(lineWidth);
          context.setStrokeStyle("#FFFFFF");
          x = x0 - r * Math.sin(((6 * (i + 1) - 3) * Math.PI) / 180);
          y = y0 - r * Math.cos(((6 * (i + 1) - 3) * Math.PI) / 180);
          // console.log('x0:' + x0 + '   y0:' + y0 + '    x:' + x + '    y:' + y);
          context.moveTo(x, y);
          context.arc(
            x0,
            y0,
            r,
            ((270 - 6 * (i + 1) + 3) * Math.PI) / 180,
            ((270 - 6 * i) * Math.PI) / 180,
            false
          );
          context.stroke();
          context.closePath();
        }
        context.stroke();
        context.draw();
      },
}
.progress_box {
    /* position: relative; */
    /* width: 100%; */
    height: 200upx;
    /* background-color: red; */
    display: inline-block;
    align-items: center;
    justify-content: center;
    text-align: center;
  }
.pcds {
    margin-top: 90rpx;
    color: black;
  }
.progress_bg {
    position: absolute;
    width: 150px;
    height: 150px;
  }
.progress_txt {
    position: absolute;
    font-size: 28upx;
    margin-top: 85rpx;
    margin-left: 95rpx;
    color: #999999;
  }
.progress_bar {
    position: absolute;
    width: 220px;
    height: 220px;
  }
.progress_line {
    position: absolute;
    width: 220px;
    height: 220px;
  }
.progress_info {
    font-size: 36upx;
    padding-left: 16upx;
    letter-spacing: 2upx;
    font-size: 45upx;
    color: #333333;
  }


目录
相关文章
|
Android开发
Android Compose 新闻App(二)ViewModel、Hlit、数据流
Android Compose 新闻App(二)ViewModel、Hlit、数据流
133 0
Android Compose 新闻App(二)ViewModel、Hlit、数据流
|
3天前
|
前端开发 Java 开发工具
【03】完整flutter的APP打包流程-以apk设置图标-包名-签名-APP名-打包流程为例—-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈 章节内容【03】
【03】完整flutter的APP打包流程-以apk设置图标-包名-签名-APP名-打包流程为例—-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈 章节内容【03】
【03】完整flutter的APP打包流程-以apk设置图标-包名-签名-APP名-打包流程为例—-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈 章节内容【03】
|
3天前
|
Dart 前端开发 Android开发
【02】写一个注册页面以及配置打包选项打包安卓apk测试—开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【02】写一个注册页面以及配置打包选项打包安卓apk测试—开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
【02】写一个注册页面以及配置打包选项打包安卓apk测试—开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈
|
4天前
|
Dart 前端开发 架构师
【01】vs-code如何配置flutter环境-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈-供大大的学习提升
【01】vs-code如何配置flutter环境-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈-供大大的学习提升
|
20天前
|
开发框架 小程序 前端开发
圈子社交app前端+后端源码,uniapp社交兴趣圈子开发,框架php圈子小程序安装搭建
本文介绍了圈子社交APP的源码获取、分析与定制,PHP实现的圈子框架设计及代码编写,以及圈子小程序的安装搭建。涵盖环境配置、数据库设计、前后端开发与接口对接等内容,确保平台的安全性、性能和功能完整性。通过详细指导,帮助开发者快速搭建稳定可靠的圈子社交平台。
155 18
|
16天前
|
JSON 供应链 搜索推荐
淘宝APP分类API接口:开发、运用与收益全解析
淘宝APP作为国内领先的购物平台,拥有丰富的商品资源和庞大的用户群体。分类API接口是实现商品分类管理、查询及个性化推荐的关键工具。通过开发和使用该接口,商家可以构建分类树、进行商品查询与搜索、提供个性化推荐,从而提高销售额、增加商品曝光、提升用户体验并降低运营成本。此外,它还能帮助拓展业务范围,满足用户的多样化需求,推动电商业务的发展和创新。
44 5
|
16天前
|
移动开发 安全 搜索推荐
圈子社交系统APP,同城本地圈子论坛开发,让身边的人沟通更加紧密
圈子社交系统APP是一款基于社交网络的移动应用,用户可创建、加入和管理兴趣圈子。主要功能包括:动态分享与交流、实时聊天、会员体系与身份认证、活动策划等。该APP注重个性化定制、社交关系深化、隐私安全及跨平台互联,提供丰富的社交体验。
|
19天前
鸿蒙语言开发 几十套鸿蒙ArkTs app毕业设计及课程作业
鸿蒙语言开发 几十套鸿蒙ArkTs app毕业设计及课程作业
28 1
|
28天前
|
JSON 缓存 前端开发
HarmonyOS NEXT 5.0鸿蒙开发一套影院APP(附带源码)
本项目基于HarmonyOS NEXT 5.0开发了一款影院应用程序,主要实现了电影和影院信息的展示功能。应用包括首页、电影列表、影院列表等模块。首页包含轮播图与正在热映及即将上映的电影切换显示;电影列表模块通过API获取电影数据并以网格形式展示,用户可以查看电影详情;影院列表则允许用户选择城市后查看对应影院信息,并支持城市选择弹窗。此外,项目中还集成了Axios用于网络请求,并进行了二次封装以简化接口调用流程,同时添加了请求和响应拦截器来处理通用逻辑。整体代码结构清晰,使用了组件化开发方式,便于维护和扩展。 该简介概括了提供的内容,但请注意实际开发中还需考虑UI优化、性能提升等方面的工作。
93 11
|
25天前
|
前端开发 数据库 UED
uniapp开发,前后端分离的陪玩系统优势,陪玩app功能特点,线上聊天线下陪玩,只要4800
前后端分离的陪玩系统将前端(用户界面)和后端(服务器逻辑)分开开发,前者负责页面渲染与用户交互,后者处理数据并提供接口。该架构提高开发效率、优化用户体验、增强可扩展性和稳定性,降低维护成本,提升安全性。玩家可发布陪玩需求,陪玩人员发布服务信息,支持在线聊天、预约及线下陪玩功能,满足多样化需求。[演示链接](https://www.51duoke.cn/games/?id=7)

热门文章

最新文章