一.当width 和 height 设置的不对的时候,会出现边框线如图所示:

解决办法:Echarts/index.js文件中

<WebView
ref="chart"
scrollEnabled = {false}
injectedJavaScript = {renderChart(this.props)}
style={{
height: this.props.height || 400,
backgroundColor: 'rgba(0,0,0,0)', // ***********add by yourself*******************
}}
automaticallyAdjustContentInsets={true}
source={require('./tpl.html')}
/>

二 折线区域图设置为渐变色,去掉节点,变成平滑

series: [{
name: 'Clouds',
type: 'line',
// 变成平滑线
smooth:true,
//这句就是去掉点的
symbol:'none',
data: [5, 7, 13, 20, 30],
// 设置为填充样式,把这句去掉的话,即为普通的折线图
areaStyle: {
normal: {
color: {
type: 'linear',
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [
{
offset: 0, color: 'rgba(6,81,222, 0.5)' // 100% 处的颜色
},
{
offset: 0.5, color: 'rgba(6,81,222, 0.2)' // 50% 处的颜色
},
{
offset: 1, color: 'rgba(253,253,253,0.17)' // 0% 处的颜色
}, ],
}
}
},
// 设置为渐变色, 此处设置的是针对网页的
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(
0, 0, 0, 1,
[
{offset: 0, color: 'red'},
{offset: 0.5, color: 'pink'},
{offset: 1, color: '#ddd'}
]
)
}
}
}]

三 环图某一个项,设置为渐变色

data:[
{value:335, name:'正面消息', selected: true, itemStyle: normal: {
color: {
type: 'linear',
x: 0,
y: 0,
x2: 0,
y2: 1,
colorStops: [
{
offset: 0, color: 'rgba(250,79,125,1)' // 100% 处的颜色
},
{
offset: 1, color: 'rgba(244,39,71,1)' // 0% 处的颜色
}, ]
},
}},
{value:180, name:'负面消息', itemStyle: {normal: 'green'}},
]

四 android 打包后,所有的图表显示不出来

1./node_modules/native-echarts/src/components/Echarts/ 目录下的tpl.html 拷贝一份
2./android/app/src/main 创建 assets文件夹
3.把第一步拷贝的文件放到第二步创建的assets文件夹下
4.进入Echarts文件(/node_modules/native-echarts/src/components/Echarts/index) 把WebView的source改为
                    source={{uri: 'file:///android_asset/tpl.html'}}

五 修改图例颜色

react-native-echarts 修改图例颜色首先要修改itemStyle的颜色

六 解决频繁刷新

进入Echarts文件(/node_modules/native-echarts/src/components/Echarts/index)

shouldComponentUpdate(nextProps, nextState) {
const thisProps = this.props || {}
nextProps = nextProps || {}
if (Object.keys(thisProps).length !== Object.keys(nextProps).length) {
return true
}
for (const key in nextProps) {
if (JSON.stringify(thisProps[key]) != JSON.stringify(nextProps[key])) {
// console.log('props', key, thisProps[key], nextProps[key])
return true
}
}
return false
} componentWillReceiveProps(nextProps) {
if(nextProps.option !== this.props.option) { // 解决数据改变时页面闪烁的问题
this.refs.chart.injectJavaScript(renderChart(nextProps,false))
}
}

修改WebView的属性injectedJavaScript

injectedJavaScript = {renderChart(this.props,true)}

进入renderChart文件(/node_modules/native-echarts/src/components/Echarts/renderChart)

export default function renderChart(props, isFirst) {
const height = props.height || 400;
if (isFirst) {
return `
document.getElementById('main').style.height = "${height}px";
myChart = echarts.init(document.getElementById('main'));
myChart.setOption(${toString(props.option)}); `
} else {
return `
document.getElementById('main').style.height = "${height}px";
myChart.setOption(${toString(props.option)}); `
}

七 折线图节点添加点击事件

进入renderChart文件(/node_modules/native-echarts/src/components/Echarts/renderChart)

添加

myChart.on('click' , function (params) {
window.postMessage(params.dataIndex)
});

添加后

if (isFirst) {
return `
document.getElementById('main').style.height = "${height}px";
myChart = echarts.init(document.getElementById('main'));
myChart.setOption(${toString(props.option)});
myChart.on('click' , function (params) {
window.postMessage(params.dataIndex)
});
`
} else {
return `
document.getElementById('main').style.height = "${height}px";
myChart.setOption(${toString(props.option)});
myChart.on('click' , function (params) {
window.postMessage(params.dataIndex)
});
`
}

进入Echart文件(/node_modules/native-echarts/src/components/Echarts/index)

WebView添加属性

                        onMessage={this.onMessage}

添加事件

// 添加点击事件
onMessage = (event) => {
if (this.props.onNodePress) {
console.log(event.nativeEvent)
this.props.onNodePress(event.nativeEvent.data)
}
}

最终修改后

进入Echarts文件(/node_modules/native-echarts/src/components/Echarts/index)

import React, { Component } from 'react';
import { WebView, View, StyleSheet,Platform } from 'react-native';
import renderChart from './renderChart';
import renderChartNoFirst from './renderChart'
import echarts from './echarts.min'; export default class App extends Component {
// 预防过渡渲染 shouldComponentUpdate(nextProps, nextState) {
const thisProps = this.props || {}
nextProps = nextProps || {}
if (Object.keys(thisProps).length !== Object.keys(nextProps).length) {
return true
}
for (const key in nextProps) {
if (JSON.stringify(thisProps[key]) != JSON.stringify(nextProps[key])) {
// console.log('props', key, thisProps[key], nextProps[key])
return true
}
}
return false
} componentWillReceiveProps(nextProps) {
if(nextProps.option !== this.props.option) { // 解决数据改变时页面闪烁的问题
this.refs.chart.injectJavaScript(renderChart(nextProps,false))
}
} // 添加点击事件
onMessage = (event) => {
if (this.props.onNodePress) {
console.log(event.nativeEvent)
this.props.onNodePress(event.nativeEvent.data)
}
} render() {
if (Platform.OS == 'android'){
return (
<View style={{flex: 1, height: this.props.height || 400,}}>
<WebView
ref="chart"
scrollEnabled = {false}
injectedJavaScript = {renderChart(this.props,true)}
onMessage={this.onMessage}
style={{
height: this.props.height || 400,
backgroundColor: 'rgba(0,0,0,0)',
}}
//source={require('./tpl.html')}
// 解决安卓打包不显示问题
source={{uri: 'file:///android_asset/tpl.html'}}
/>
</View>
);
}else{
return (
<View style={{flex: 1, height: this.props.height || 400,}}>
<WebView
ref="chart"
scrollEnabled = {false}
scalesPageToFit={false}
injectedJavaScript = {renderChart(this.props,true)}
onMessage={this.onMessage}
style={{
height: this.props.height || 400,
backgroundColor: 'rgba(0,0,0,0)',
}}
source={require('./tpl.html')}
/>
</View>
);
} }
}

进入renderChart文件(/node_modules/native-echarts/src/components/Echarts/renderChart)

import echarts from './echarts.min';
import toString from '../../util/toString'; var myChart = null;
export default function renderChart(props, isFirst) {
const height = props.height || 400;
if (isFirst) {
return `
document.getElementById('main').style.height = "${height}px";
myChart = echarts.init(document.getElementById('main'));
myChart.setOption(${toString(props.option)});
myChart.on('click' , function (params) {
window.postMessage(params.dataIndex)
});
`
} else {
return `
document.getElementById('main').style.height = "${height}px";
myChart.setOption(${toString(props.option)});
myChart.on('click' , function (params) {
window.postMessage(params.dataIndex)
});
`
}
}

使用

onChartNodePress(data) {
console.log(data)
this.setState({
selectedNodeIndex: data,
})
} <Echarts option={option} width={width} height={177}
onNodePress={(data) => this.onChartNodePress(data)}
/>

android 双击图表会缩小

/node_modules/native-echarts/src/components/Echarts/index.js

Line 24

scalesPageToFit={false} 

替换为
scalesPageToFit={Platform.OS === 'android'}

native-echarts 问题总结的更多相关文章

  1. react native中使用echarts

    开发平台:mac pro node版本:v8.11.2 npm版本:6.4.1 react-native版本:0.57.8 native-echarts版本:^0.5.0 目标平台:android端收 ...

  2. react native使用百度echarts显示图表

    echarts是百度推出的免费开源的图表组件,功能丰富,涵盖各行业图表.公司项目做h5项目用了不少,最近公司翻新h5页面,用react-native改造,来达到增强用户体验效果的目的.项目中遇到了一些 ...

  3. React native 之 图标库ECharts的使用

    github地址:https://github.com/somonus/react-native-echarts 官网:https://www.echartsjs.com/zh/tutorial.ht ...

  4. 使用Echarts实现动态曲线图表

    最近做的一个在线气象观测网站要实现一个需求:使用图表展示最近五天温湿度等气象要素的曲线变化 具体效果参考:http://www.weatherobserve.com/showInfoIndex.jsp ...

  5. 【微信小程序项目实践总结】30分钟从陌生到熟悉 web app 、native app、hybrid app比较 30分钟ES6从陌生到熟悉 【原创】浅谈内存泄露 HTML5 五子棋 - JS/Canvas 游戏 meta 详解,html5 meta 标签日常设置 C#中回滚TransactionScope的使用方法和原理

    [微信小程序项目实践总结]30分钟从陌生到熟悉 前言 我们之前对小程序做了基本学习: 1. 微信小程序开发07-列表页面怎么做 2. 微信小程序开发06-一个业务页面的完成 3. 微信小程序开发05- ...

  6. ECharts(中国地图篇)的使用

    代码html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <me ...

  7. 【React自制全家桶】一、Webstrom+React+Ant Design+echarts搭建react项目

    前言 一.React是Facebook推出的一个前端框架,之前被用于著名的社交媒体Instagram中,后来由于取得了不错的反响,于是Facebook决定将其开源.出身名门的React也不负众望,成功 ...

  8. 基于React Native的跨三端应用架构实践

    作者|陈子涵 编辑|覃云 “一次编写, 到处运行”(Write once, run anywhere ) 是很多前端团队孜孜以求的目标.实现这个目标,不但能以最快的速度,将应用推广到各个渠道,而且还能 ...

  9. 📝 没 2 年 React Native 开发经验,你都遇不到这些坑

    如果你喜欢我的文章,希望点赞 收藏 评论 三连支持一下,谢谢你,这对我真的很重要! React Native 开发时,如果只是写些简单的页面,基本上按着官方文档 reactnative.dev就能写出 ...

  10. 一起来玩echarts系列(一)------箱线图的分析与绘制

    一.箱线图 Box-plot 箱线图一般被用作显示数据分散情况.具体是计算一组数据的中位数.25%分位数.75%分位数.上边界.下边界,来将数据从大到小排列,直观展示数据整体的分布情况. 大部分正常数 ...

随机推荐

  1. IQueryable.Where中动态生成多个并或筛选Expression<Func<T, bool>>

    直接上图

  2. 自定义new和delete

    #include "stdafx.h" #include <stdlib.h> #include <malloc.h> #include <iostr ...

  3. 洛谷P3324 [SDOI2015]星际战争 题解

    题目链接: https://www.luogu.org/problemnew/show/P3324 分析: 因为本题的时间点较多,不能枚举,但发现有单调性,于是二分答案,二分使用的时间TTT 每个攻击 ...

  4. Spring+SpringMVC+mybatis maven pom文件

    pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w ...

  5. Java多线程笔记总结

    1.线程的三种创建方式 对比三种方式: 通过继承Thread类实现 通过实现Runnable接口 实现Callable接口 第1种方式无法继承其他类,第2,3种可以继承其他类: 第2,3种方式多线程可 ...

  6. JDBC秒变C3P0连接池——再加连接解耦

    从JDBC连接到C3P0数据库连接池 在Java开发中,使用JDBC操作数据库的四个步骤如下:   ①加载数据库驱动程序(Class.forName("数据库驱动类");)   ② ...

  7. drf初体验

    快速开始 安装 pip install djangorestframework 创建django项目 django-admin startproject mydrf 创建APP cd mydrf py ...

  8. Netty源码解析---服务端启动

    Netty源码解析---服务端启动 一个简单的服务端代码: public class SimpleServer { public static void main(String[] args) { N ...

  9. win10+Anaconda3+CUDA9.0+CUDNN7.1+TensorFlow-gpu1.9+Pycharm

    想在win10上运行下YOLO的例子,要先配置环境,折腾了两天,终于好了,整理下自己觉得有用且正确的流程. win10+Anaconda3+CUDA9.0+CUDNN7.1+TensorFlow1.9 ...

  10. C#文件下载流程

    private bool DownloadPicture(string picUrl, string savePath, int timeOut)         {             bool ...