纯血鸿蒙APP第三方库——MpChart运动健康场景实践案例

介绍

MpChart是一个包含各种类型图表的图表库,主要用于业务数据汇总,例如销售数据走势图,股价走势图等场景中使用,方便开发者快速实现图表UI,MpChart主要包括线形图、柱状图、饼状图、蜡烛图、气泡图、雷达图、瀑布图等自定义图表库。
本示例介绍了MpChart图表组件的使用方法。
该组件多用于可视化等场景。

效果图预览

使用说明

  • 滑动屏幕,查看各图表组件。
  • 点击曲线图内容,展示图表信息。

实现思路

  1. 健身记录部分:使用柱状图描述近七日每日的热量消耗情况,主要实现点在于柱状图的创建过程。
  • 初始化图表配置构建类
  // 初始化图表配置构建类this.model = new BarChartModel();// 设置图表数据最大的绘制数,如果超过该数值,则不进行绘制图表的数值标签this.model.setMaxVisibleValueCount(VISIBLE_VALUE_COUNT);// 是否绘制图表的背景色,绘制范围为图表柱状图的绘制范围,不包含轴线之外的部分this.model.setDrawGridBackground(true);// 设置图表的背景色,颜色的规格需要满足CanvasRenderingContext2D.fillstyle/strokestyle规格this.model.setGridBackgroundColor(GRID_BG_COLOR);// 设置不绘制柱状图的柱体阴影背景this.model.setDrawBarShadow(false);// 设置柱状图的数值在柱体上方this.model.setDrawValueAboveBar(true);// 设置柱状图的高亮范围是否为整个柱体,只在堆叠柱状图中有区别this.model.setHighlightFullBarEnabled(true);
  • 限制线的设置
  // 为左Y轴设置LimitLine,可设置限制线的宽度,线段样式,限制标签的位置,标签字体大小等this.limitLine = new LimitLine(STEP_TARGET_NUMBER, STEP_TARGET);// 设置限制线的宽度this.limitLine.setLineWidth(LINE_WIDTH);// 设置限制线虚线类型的长度this.limitLine.enableDashedLine(DASHED_LINE_LENGTH, DASHED_SPACE_LENGTH, ZERO);// 设置限制线的颜色this.limitLine.setLineColor(Color.Gray);// 设置限制线的位置this.limitLine.setLabelPosition(LimitLabelPosition.RIGHT_TOP);// 设置限制线上文本的大小this.limitLine.setTextSize(vp2px(TEXT_SIZE));
  • X轴Y轴设置
  // 设置图表左Y轴信息this.leftAxis = this.model.getAxisLeft();if (this.leftAxis) {// 设置图表左Y轴最小值this.leftAxis.setAxisMinimum(ZERO);// 设置图表左Y轴是否在数据后绘制限制线this.leftAxis.setDrawLimitLinesBehindData(false);// 设置图表左Y轴数据的格式转换器this.leftAxis.setValueFormatter(new YValueFormatter());// 添加LimitLinesthis.leftAxis.addLimitLine(this.limitLine);}// 设置图表右Y轴信息this.rightAxis = this.model.getAxisRight();if (this.rightAxis) {// 设置图表右Y轴是否显示this.rightAxis.setEnabled(false);// 设置图表右Y轴最小值this.rightAxis.setAxisMinimum(ZERO);}// 设置X轴信息this.xAxis = this.model.getXAxis();if (this.xAxis) {// 设置X轴是否绘制网格线this.xAxis.setDrawGridLines(false);// 设置绘制标签个数this.xAxis.setLabelCount(LABEL_COUNT, false);//设置标签位置this.xAxis.setPosition(XAxisPosition.BOTTOM);// 设置数据的格式转换器this.xAxis.setValueFormatter(new XValueFormatter());}
  • 绑定图表数据
  // 生成数据this.data = this.getNormalData();// TODO 知识点:将数据与图表配置类绑定this.model.setData(this.data);
  1. 健康数据部分:使用曲线图展示每日的热量消耗情况,主要实现点在于曲线图的创建过程。
  • 初始化图表配置构建类
  // 初始化图表配置构建类this.model = new LineChartModel();this.model.setPinchZoom(false);this.model.setDrawGridBackground(false);
  • X轴Y轴设置
  // 设置X轴信息this.xAxis = this.model.getXAxis();if (this.xAxis) {//设置标签位置this.xAxis.setPosition(XAxisPosition.BOTTOM);// 设置X轴是否绘制网格线this.xAxis.setDrawGridLines(true);this.xAxis.setGranularity(1);// 设置数据的格式转换器this.xAxis.setValueFormatter(new XValueFormatter());// 设置绘制标签个数this.xAxis.setLabelCount(10);this.xAxis.enableGridDashedLine(2, 2, 0);}// 设置图表左Y轴信息this.leftAxis = this.model.getAxisLeft();if (this.leftAxis) {this.leftAxis.setLabelCount(4, true);this.leftAxis.setDrawGridLines(true);// 设置图表左Y轴是否在数据后绘制限制线this.leftAxis.setDrawGridLinesBehindData(true);this.leftAxis.setPosition(YAxisLabelPosition.OUTSIDE_CHART);this.leftAxis.setAxisMinimum(0);// 设置图表左Y轴数据的格式转换器this.leftAxis.setValueFormatter(new YValueFormatter());this.leftAxis.setEnabled(true);this.leftAxis.enableGridDashedLine(2, 2, 0);}// 设置图表右Y轴信息this.rightAxis = this.model.getAxisRight();if (this.rightAxis) {// 设置图表右Y轴是否显示this.rightAxis.setEnabled(false);}
  • 图表图例部分
  // 获取图表图例部件,设置图表图例部件不可用let legend: Legend | null = this.model.getLegend();if (legend) {legend.setEnabled(true);// 设置图例类型legend.setForm(LegendForm.LINE);// 设置图例文本大小legend.setTextSize(vp2px(14));// 设置图例方向为水平legend.setOrientation(LegendOrientation.HORIZONTAL);// 设置图例垂直对齐方式为顶部legend.setVerticalAlignment(LegendVerticalAlignment.TOP);// 设置图例水平对齐方式为左对齐legend.setHorizontalAlignment(LegendHorizontalAlignment.LEFT);}
  • 绑定图表数据
  // 生成数据this.lineData = this.getLineData();// TODO 知识点:将数据与图表配置类绑定this.model.setData(this.lineData);

高性能知识点

不涉及

工程结构&模块类型

  health                                       // 运动健康场景实践案例|---model                                         |   |---BasicDataSource.ets                  // 数据类型文件|---view|   |---BarCharts.ets                        // 柱状图组件|   |---MpCharts.ets                         // 图表列表页面|   |---LineCharts.ets                       // 曲线图组件

模块依赖

@ohos/routermodule(动态路由)

参考资料

@ohos/barchart(柱状图配置)

MpChart

鸿蒙全栈开发全新学习指南

也为了积极培养鸿蒙生态人才,让大家都能学习到鸿蒙开发最新的技术,针对一些在职人员、0基础小白、应届生/计算机专业、鸿蒙爱好者等人群,整理了一套纯血版鸿蒙(HarmonyOS Next)全栈开发技术的学习路线【包含了大厂APP实战项目开发】

本路线共分为四个阶段:

第一阶段:鸿蒙初中级开发必备技能

第二阶段:鸿蒙南北双向高工技能基础:gitee.com/MNxiaona/733GH

第三阶段:应用开发中高级就业技术

第四阶段:全网首发-工业级南向设备开发就业技术:gitee.com/MNxiaona/733GH

《鸿蒙 (Harmony OS)开发学习手册》(共计892页)

如何快速入门?

1.基本概念
2.构建第一个ArkTS应用
3.……

开发基础知识:gitee.com/MNxiaona/733GH

1.应用基础知识
2.配置文件
3.应用数据管理
4.应用安全管理
5.应用隐私保护
6.三方应用调用管控机制
7.资源分类与访问
8.学习ArkTS语言
9.……

基于ArkTS 开发

1.Ability开发
2.UI开发
3.公共事件与通知
4.窗口管理
5.媒体
6.安全
7.网络与链接
8.电话服务
9.数据管理
10.后台任务(Background Task)管理
11.设备管理
12.设备使用信息统计
13.DFX
14.国际化开发
15.折叠屏系列
16.……

鸿蒙开发面试真题(含参考答案):gitee.com/MNxiaona/733GH

鸿蒙入门教学视频:

美团APP实战开发教学:gitee.com/MNxiaona/733GH

写在最后

  • 如果你觉得这篇内容对你还蛮有帮助,我想邀请你帮我三个小忙:
  • 点赞,转发,有你们的 『点赞和评论』,才是我创造的动力。
  • 关注小编,同时可以期待后续文章ing🚀,不定期分享原创知识。
  • 想要获取更多完整鸿蒙最新学习资源,请移步前往小编:gitee.com/MNxiaona/733GH

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

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

相关文章

C++青少年简明教程:C++程序结构

C青少年简明教程&#xff1a;C程序结构 一个简单的C程序源码如下&#xff1a; #include <iostream> using namespace std;int main() {cout << "Hello World" << endl;return 0; }下面解析一下。 1. #include <iostream> 这是一条预处理…

html中用frameset对窗口进行划分

html中&#xff0c;一般有<head><body>等部分&#xff0c;在用<frameset>对窗口进行区域划分时&#xff0c;<body>标签对就不再需要了。直接删除就可以了。 请看下面的示例&#xff1a; 由于使用frameset进行窗口划分时&#xff0c;对于电脑屏幕的划分…

HarmonyOS开发案例:【UIAbility内和UIAbility间页面的跳转】

UIAbility内和UIAbility间页面的跳转&#xff08;ArkTS&#xff09; 介绍 基于Stage模型下的UIAbility开发&#xff0c;实现UIAbility内和UIAbility间页面的跳转。包含如下功能&#xff1a; UIAbility内页面的跳转。跳转到指定UIAbility的首页。跳转到指定UIAbility的指定页…

[猫头虎分享21天微信小程序基础入门教程]第6天:与服务器进行数据交互

[猫头虎分享21天微信小程序基础入门教程]第6天&#xff1a;与服务器进行数据交互 第6天&#xff1a;与服务器进行数据交互 &#x1f310; 自我介绍 大家好&#xff0c;我是猫头虎&#xff0c;一名全栈软件工程师。今天我们将继续微信小程序的学习&#xff0c;重点了解如何与服…

Ubuntu扩展磁盘分区

Ubuntu扩展磁盘分区 报错Unable to satisfy all constraints on the partition 首先需要保证磁盘具有空闲分区&#xff0c;且与待扩展的分区相邻&#xff0c;比如扩展分区3&#xff0c;那剩余空间应与分区3相邻&#xff0c;如图所示&#xff1a; 然后选中文件系统分区3&#x…

“交个朋友”申请注册商标都已被驳回!

“ 交个朋友”在直播带货界非常有名&#xff0c;普推知产老杨在商标局官网上检索发现&#xff0c;“交个朋友”主体申请了以“交个朋友”四百多个相关商标&#xff0c;基本上都被驳回&#xff0c;其实这样的名称不应提报商标&#xff0c;专业商标人员一看就过不了&#xff0c;还…

C++牛客周赛题目分享(2)小红叕战小紫,小红的数组移动,小红的素数合并,小红的子序列求和

目录 ​编辑 1.前言 2.四道题目 1.小红叕战小紫 1.题目描述 2.输入描述 3.输出描述 4.示例 5.题解与思路 2.小红的数组移动 1.题目描述 2.输入描述 3.输出描述 4.示例 5.题解与思路 3.小红的素数合并 1.题目描述 2.输入描述 3.输出描述 4.示例 5.题解与思…

启动项目时出现SELinux is preventing

问题描述 启动项目时出现SELinux is preventing**** SELinux正在阻止systemd对文件AB.sevice进行读取访问。 我的是启zabbix是报该错&#xff1a; 最终解决方案 方法一&#xff1a;暂时禁用SELinux setenforce 0 方法二&#xff1a;禁用SELinux 在配置文件/etc/sysconfig/…

通过任意文件读取获取weblogic账号密码

对于weblogic获取到账号密码的前提是有任意文件读取存在&#xff0c;当任意文件读取存在时是可以读取配置文件来对账号密码进行解密。weblogic密码使用AES&#xff08;老版本3DES&#xff09;加密&#xff0c;对称加密可解密&#xff0c;只需要找到用户的密文与加密时的密钥即可…

Dread Hunger 海上狼人杀服务器开服教程

1、购买后登录服务器&#xff0c;百度莱卡云 1.1、第一次购买服务器会安装游戏端&#xff0c;大约5分钟左右&#xff0c;如果长时间处于安装状态请联系客服 2、创建端口 点击网络创建第二个端口作为副端口&#xff08;副端口的作用是用于第二局游戏&#xff0c;因为游戏BUG&am…

数字锁相放大器(DLIA)基本原理与Matlab仿真

本文介绍数字锁相放大器&#xff08;DLIA&#xff09;基本原理与Matlab仿真。 1.基本原理 数字锁相放大器&#xff08;DLIA&#xff09;原理框图如下图。 其核心部分为FPGA/DSP内部的相关运算及由正弦参考序列&#xff0c;D/A转换器&#xff0c;低通滤波器构成的DDS&#xff…

vue+springboot实现excel批量数据的导入导出

①后端配置端口&#xff1a;修改UserController UserController&#xff1a; package com.example.springboot.controller;import cn.hutool.core.util.StrUtil; import cn.hutool.poi.excel.ExcelReader; import cn.hutool.poi.excel.ExcelUtil; import cn.hutool.poi.excel.…