areaStyle&&symbolSize

描述:当前是关于Echarts图表中的 折线图 示例。
 
            demo = [
  {
    "x": "北京",
    "y": 40,
    "z":"租房人数"
  },
 
  {
    "x": "广州",
    "y":  100,
    "z":"租房人数"
  },
  {
    "x": "上海",
    "y":  152,
    "z":"买房人数"
    
  },
  {
    "x": "深圳",
    "y": 280,
    "z":"租房人数"
  },
  {
    "x": "杭州",
    "y": 350,
    "z":"租房人数"
  },
  {
    "x": "成都",
    "y":  270,
    "z":"租房人数"
   
  },
  {
    "x": "重庆",
    "y": 220,
    "z":"租房人数"
    
  },
   {
    "x": "重庆",
    "y": 105,
    "z":"买房人数"
    
  },
  {
    "x": "北京",
    "y": 140,
    "z":"买房人数"
  },
 
  {
    "x": "广州",
    "y":  167,
    "z":"买房人数"
  },
  {
    "x": "深圳",
    "y": 204,
    "z":"买房人数"
  },
  {
    "x": "杭州",
    "y": 50,
    "z":"买房人数"
  },
  {
    "x": "上海",
    "y":  62,
    "z":"租房人数"
    
  },
  {
    "x": "南京",
    "y": 90,
    "z":"租房人数"
  },
  {
    "x": "成都",
    "y":  179,
    "z":"买房人数"
   
  },
 
  {
    "x": "南京",
    "y": 119,
    "z":"买房人数"
  }
];

let colorArr = _colors();
let legData = _ledgData();
option = {
		backgroundColor:"#0C1D38",
		color: colorArr,
		legend: {				
			right:'4%',
			show:true,
			itemWidth:8,
			itemHeight:8,
			data:legData
		},
		grid:{
			right:'5%'
			
		},
		xAxis: [{
			type : 'category',
			data : _xAxisData(),
			axisTick: {
				show: false,
				alignWithLabel: true
			},
			axisLabel: { 
				color: 'rgba(255,255,255,0.8)',
				fontSize: 12,
				formatter:function(val){
				    return val
				},
				margin: 15,
			},
			axisLine: _axisLine()
		}],
		yAxis: [{
			type : 'value',
			axisLabel: { 
				color: 'rgba(255,255,255,0.8)',
				fontSize: 12,
				formatter:function(val){
				    return val
				},
				margin: 15,
			},
			axisTick: {
				show: false,
				alignWithLabel: true
			},
			splitLine: { 
				show: true,
				lineStyle: {
					color: 'rgba(255,255,255,0.2)', //坐标轴线颜色
					width: 1
      			}
			},
			axisLine: _axisLine()
		}],
		series : _setSeriesArray()
	
}

function _ledgend(){
		
	let legendDt =  new Set(demo && demo.map(item=>item.z));
	let _data = [];
	if(legendDt){
		for (let x of legendDt) { // 遍历Set
			_data.push(x)
		}
	}
	return _data;
	
}

function _ledgData(){
		
	let legendDt =  new Set(demo && demo.map(item=>item.z));
	let _lgdata = [],lgDt=[];
	if(legendDt){
		for (let x of legendDt) { // 遍历Set
			_lgdata.push(x)
		}
	}
	//console.log(_lgdata);
	_lgdata && _lgdata.forEach((item)=>{  
		
		lgDt.push({
			name: item,
			icon: 'circle',
			textStyle: {
				color: '#fff',
				fontSize:14
			}
		})
	});

	return lgDt;

}

function _setSeriesArray() {
		
	let _point = _icon(),
		areaSty = _areaStyleColor(),
		colors = _colors();
	let dataKinds = _ledgend(),
		dataLg = demo.length,
		kinds = dataKinds.length;  //数据种类数n
	let _xData = _xAxisData();
	let result = [];  //n个数组
		
	let obj = {};
    demo.forEach((item, i) => {
		!obj[item.z] ? obj[item.z] = [item] : obj[item.z].push(item);
	})	
	
	for(var i=0;i<kinds;i++){
		let _data = obj[dataKinds[i]],
			tempArr = [];
		for(var k=0;k<dataLg;k++){
			let _dt = _xData[k];
			_data.map((item)=>{
				if(item.x === _dt){
					tempArr.push(item.y)
				}
			})				
		}
		result.push(tempArr)
		
	}
	//console.log(result);

	//最大值组合
	let	maxArr = [];
	result && result.map((item)=>{
		let tempArr = item.concat(),
			max =  tempArr.sort(_sortNumber).slice(0,1)+'';  //深拷贝
		maxArr.push(max);
	})
	
	//创建series
	let seriesArr = [];
	let _markPoint = _markPointData();
	result && result.map((item,ind)=>{
		
		seriesArr.push({
			name: dataKinds[ind],
			type:'line',
			data:item,
			symbolSize:0,
			markPoint:{
				symbol: `image://${_point[ind]}`,
				symbolSize:(value,params)=>{
					let val = params.data.coord[1] +'';
					let ratio = (maxArr.indexOf(val) === params.seriesIndex)? 40: 25;
					return ratio
				},
				label:{
					normal:{
						show:false
					}
				},
				data:_markPoint[ind]
			},
			lineStyle:{
				normal:{
					color: colors[ind],
					shadowColor:colors[ind],
					shadowBlur: 20,
					shadowOffsetX: 1,
					shadowOffsetY: 0,
					opacity:1
				}
				
			},
			areaStyle: {
				normal:{						
					color: {
						type: 'linear',
						x: 0,
						y: 0,
						x2: 0,
						y2: 1,
						colorStops: [{
							offset: 0, color:areaSty[ind][0]  // 0% 处的颜色
						},{
							offset: 1, color: areaSty[ind][1] // 100% 处的颜色
						}],
						globalCoord: false // 缺省为 false
					}
				}
			}
		})
	})
	
	//console.log("seriesArr",seriesArr);
	return seriesArr;
	
}
	
//数组排序不去重
function _sortNumber(a,b){
	return b-a;
}

function  _markPointData(){
	let dataKinds = _ledgend(),
		dataLg =demo.length,
		kinds = dataKinds.length,
		_xData =_xAxisData(); //数据种类数n
	let arr = [],obj = {},result=[];
	
    demo.forEach((item, i) => {
		!obj[item.z] ? obj[item.z] = [item] : obj[item.z].push(item);
	})	
	
	for(var i=0;i<kinds;i++){
		let _data = obj[dataKinds[i]],
			tempArr = [];
		for(var k=0;k<dataLg;k++){
			let _dt = _xData[k];
			_data.map((item)=>{
				if(item.x === _dt){
					tempArr.push({
						x:item.x,
						y:item.y
					})
				}
			})				
		}
		result.push(tempArr)
		
	}

	for(var n=0;n<kinds;n++){
		let temp = [];
		result[n] && result[n].map((item)=>{
			
		 	temp.push({
		 		name:'p',
		 		coord:[item.x,item.y]
		 	})
		})
		arr.push(temp);
	}
	
	return arr
	
}
	
function _xAxisData() {
	let xData =  new Set(demo &&demo.map(item=>item.x));
	let _data = [];
	if(xData){
		for (let x of xData) { // 遍历Set
			_data.push(x)
		}
	}
	//console.log(_data);
	return _data;
	
}
	
function _axisLine() {
	return {
		show: false,
		lineStyle: {
			color: 'rgba(255,255,255,0.2)', //坐标轴线颜色
			width: 2
			
  		}
	}
}

function _icon(){
	const orange = '';
    const blue = '';
	const orRed = '';
	const green = '';
	
	return [orange,blue,orRed,green]
}
function _colors(){
	return ['#f3972f','#327bfa','#f85b2c','#70e8c2']
}
function _areaStyleColor(){
		
	return [ 
		['rgba(243,151,47,0.3)','rgba(243,151,47,0.1)'],
		['rgba(50,123,250,0.3)','rgba(50,123,250,0.1)'],
		['rgba(248,91,44,0.3)','rgba(248,91,44,0.1)'],
		['rgba(112,232,194,0.3)','rgba(112,232,194,0.1)']
	];
}