对比图更新

qianming 4 years ago
parent a43f966c69
commit e8a86fe649

@ -1,6 +1,6 @@
/* /*
* @Descripttion: 柱状堆叠图 * @Descripttion: 柱状堆叠图
* @version: * @version:
* @Author: qianlishi * @Author: qianlishi
* @Date: 2021-08-29 07:37:09 * @Date: 2021-08-29 07:37:09
* @LastEditors: qianlishi * @LastEditors: qianlishi
@ -350,7 +350,8 @@ export const widgetBarStack = {
required: false, required: false,
placeholder: '', placeholder: '',
value: '#fff', value: '#fff',
}, { },
{
type: 'el-switch', type: 'el-switch',
label: '分割线显示', label: '分割线显示',
name: 'isShowSplitLineY', name: 'isShowSplitLineY',
@ -364,7 +365,6 @@ export const widgetBarStack = {
required: false, required: false,
placeholder: '', placeholder: '',
value: '#fff', value: '#fff',
} }
], ],
}, },

@ -160,13 +160,29 @@ export const widgetLineCompare = {
value: true, value: true,
}, },
{ {
type: 'el-input-number', type: 'el-input-text',
label: '数值间隔', label: '坐标名',
name: 'splitNumberX', name: 'xName',
required: false, required: false,
placeholder: '', placeholder: '',
value: '' value: ''
}, },
{
type: 'vue-color',
label: '坐标名颜色',
name: 'nameColorX',
required: false,
placeholder: '',
value: '#fff',
},
{
type: 'el-input-number',
label: '坐标字号',
name: 'nameFontSizeX',
required: false,
placeholder: '',
value: 14,
},
{ {
type: 'el-switch', type: 'el-switch',
label: '数值居中', label: '数值居中',
@ -191,6 +207,14 @@ export const widgetLineCompare = {
placeholder: '', placeholder: '',
value: 14, value: 14,
}, },
{
type: 'el-input-number',
label: '数值间隔',
name: 'splitNumberX',
required: false,
placeholder: '',
value: ''
},
{ {
type: 'el-switch', type: 'el-switch',
label: '刻度线', label: '刻度线',
@ -228,9 +252,40 @@ export const widgetLineCompare = {
placeholder: '', placeholder: '',
value: true, value: true,
}, },
{
type: 'el-input-text',
label: '坐标名',
name: 'textNameYTop',
require: false,
placeholder: '',
value: ''
},{
type: 'vue-color',
label: '坐标名颜色',
name: 'nameColorYTop',
required: false,
placeholder: '',
value: '#fff',
},
{ {
type: 'el-input-number', type: 'el-input-number',
label: '数值间隔', label: '坐标字号',
name: 'namefontSizeYTop',
required: false,
placeholder: '',
value: 14,
},
{
type: 'el-switch',
label: '缩放',
name: 'scaleYTop',
required: false,
placeholder: '',
value: true,
},
{
type: 'el-input-number',
label: '数值切分',
name: 'splitNumberYTop', name: 'splitNumberYTop',
required: false, required: false,
placeholder: '', placeholder: '',
@ -239,7 +294,7 @@ export const widgetLineCompare = {
{ {
type: 'vue-color', type: 'vue-color',
label: '数值颜色', label: '数值颜色',
name: 'XcolorRight', name: 'colorYTop',
required: false, required: false,
placeholder: '', placeholder: '',
value: '#fff', value: '#fff',
@ -247,7 +302,7 @@ export const widgetLineCompare = {
{ {
type: 'el-input-number', type: 'el-input-number',
label: '数值字号', label: '数值字号',
name: 'fontSizeXRight', name: 'fontSizeYTop',
required: false, required: false,
placeholder: '', placeholder: '',
value: 14, value: 14,
@ -255,31 +310,31 @@ export const widgetLineCompare = {
{ {
type: 'el-switch', type: 'el-switch',
label: '刻度线', label: '刻度线',
name: 'tickLineRight', name: 'tickLineYTop',
require: false, require: false,
placeholder: '', placeholder: '',
value: false, value: true,
}, },
{ {
type: 'el-switch', type: 'el-switch',
label: 'X轴线', label: 'y轴线',
name: 'xLineRight', name: 'lineYTop',
require: false, require: false,
placeholder: '', placeholder: '',
value: false, value: true,
}, },
{ {
type: 'vue-color', type: 'vue-color',
label: '轴颜色', label: '轴颜色',
name: 'lineColorXRight', name: 'lineColorYTop',
required: false, required: false,
placeholder: '', placeholder: '',
value: '#fff', value: '#fff',
}, },
{ {
type: 'el-switch', type: 'el-switch',
label: '分割线', label: '分割线',
name: 'SplitLineRight', name: 'splitLineYTop',
require: false, require: false,
placeholder: '', placeholder: '',
value: false, value: false,
@ -287,7 +342,7 @@ export const widgetLineCompare = {
{ {
type: 'vue-color', type: 'vue-color',
label: '分割线颜色', label: '分割线颜色',
name: 'SplitLineColorRight', name: 'splitLineColorYTop',
required: false, required: false,
placeholder: '', placeholder: '',
value: '#fff', value: '#fff',
@ -295,85 +350,127 @@ export const widgetLineCompare = {
{ {
type: 'el-input-number', type: 'el-input-number',
label: '分割线宽度', label: '分割线宽度',
name: 'SplitLinefontSizeRight', name: 'splitLinefontSizeYTop',
required: false, required: false,
placeholder: '', placeholder: '',
value: 1, value: 1,
}, },
{
type: 'el-switch',
label: '边框线',
name: 'frameLineRight',
require: false,
placeholder: '',
value: false,
},
], ],
}, },
{ {
name: '下Y轴设置', name: '下y轴设置',
list: [ list: [
{ {
type: 'el-switch', type: 'el-switch',
label: '显示', label: '显示',
name: 'hideY', name: 'isShowYBottom',
required: false, required: false,
placeholder: '', placeholder: '',
value: true, value: true,
}, },
{ {
type: 'el-input-text',
label: '坐标名',
name: 'textNameYBottom',
require: false,
placeholder: '',
value: ''
},{
type: 'vue-color', type: 'vue-color',
label: '数值颜色', label: '坐标名颜色',
name: 'colorY', name: 'nameColorYBottom',
required: false, required: false,
placeholder: '', placeholder: '',
value: '#fff', value: '#fff',
}, },
{ {
type: 'el-input-number', type: 'el-input-number',
label: '数值字号', label: '坐标字号',
name: 'fontSizeY', name: 'namefontSizeYBottom',
required: false, required: false,
placeholder: '', placeholder: '',
value: 14, value: 14,
}, },
{ {
type: 'el-select', type: 'el-switch',
label: '数值对齐', label: '缩放',
name: 'textAlign', name: 'scaleYBottom',
required: false, required: false,
placeholder: '', placeholder: '',
selectOptions: [ value: true,
{code: 'center', name: '居中'}, },
{code: 'left', name: '左对齐'}, {
{code: 'right', name: '右对齐'}, type: 'el-input-number',
], label: '数值切分',
value: 'center' name: 'splitNumberYBottom',
required: false,
placeholder: '',
value: ''
},
{
type: 'vue-color',
label: '数值颜色',
name: 'colorYBottom',
required: false,
placeholder: '',
value: '#fff',
},
{
type: 'el-input-number',
label: '数值字号',
name: 'fontSizeYBottom',
required: false,
placeholder: '',
value: 14,
}, },
{ {
type: 'el-switch', type: 'el-switch',
label: '刻度线', label: '刻度线',
name: 'tickLineY', name: 'tickLineYBottom',
require: false, require: false,
placeholder: '', placeholder: '',
value: false, value: true,
}, },
{ {
type: 'el-switch', type: 'el-switch',
label: 'Y轴线', label: 'y轴线',
name: 'lineY', name: 'lineYBottom',
require: false, require: false,
placeholder: '', placeholder: '',
value: false, value: true,
}, },
{ {
type: 'vue-color', type: 'vue-color',
label: '轴颜色', label: '轴颜色',
name: 'lineColorY', name: 'lineColorYBottom',
required: false,
placeholder: '',
value: '#fff',
},
{
type: 'el-switch',
label: '分割线',
name: 'splitLineYBottom',
require: false,
placeholder: '',
value: false,
},
{
type: 'vue-color',
label: '分割线颜色',
name: 'splitLineColorYBottom',
required: false, required: false,
placeholder: '', placeholder: '',
value: '#fff', value: '#fff',
}, },
{
type: 'el-input-number',
label: '分割线宽度',
name: 'splitLinefontSizeYBottom',
required: false,
placeholder: '',
value: 1,
},
], ],
}, },
{ {
@ -444,11 +541,19 @@ export const widgetLineCompare = {
list: [ list: [
{ {
type: 'el-slider', type: 'el-slider',
label: '左边距(像素)', label: '左边距(像素)',
name: 'marginLeftRight', name: 'marginLeft',
required: false, required: false,
placeholder: '', placeholder: '',
value: 10, value: 20,
},
{
type: 'el-slider',
label: '右边距(像素)',
name: 'marginRight',
required: false,
placeholder: '',
value: 50,
}, },
{ {
type: 'el-slider', type: 'el-slider',
@ -464,7 +569,7 @@ export const widgetLineCompare = {
name: 'marginBottom', name: 'marginBottom',
required: false, required: false,
placeholder: '', placeholder: '',
value: 10, value: 40,
}, },
], ],
}, },

@ -265,11 +265,11 @@ export default {
editorOptions() { editorOptions() {
this.setOptionsTitle(); this.setOptionsTitle();
this.setOptionsX(); this.setOptionsX();
// this.setOptionsXRight(); this.setOptionsYTop();
// this.setOptionsY(); this.setOptionsYBottom();
// this.setOptionsTop(); // this.setOptionsTop();
// this.setOptionsTooltip(); // this.setOptionsTooltip();
// this.setOptionsGrid(); this.setOptionsGrid();
// this.setOptionsLegend(); // this.setOptionsLegend();
// this.setOptionsColor(); // this.setOptionsColor();
this.setOptionsData(); this.setOptionsData();
@ -294,6 +294,11 @@ export default {
const xAxis0 = { const xAxis0 = {
gridIndex: 0, gridIndex: 0,
show: optionsSetup.isShowX, show: optionsSetup.isShowX,
name: optionsSetup.xName, //
nameTextStyle: {
color: optionsSetup.nameColorX,
fontSize: optionsSetup.nameFontSizeX
},
type: 'category', type: 'category',
boundaryGap: optionsSetup.boundaryX, // boundaryGap: optionsSetup.boundaryX, //
axisLine: { //x线 axisLine: { //x线
@ -337,64 +342,90 @@ export default {
this.options.xAxis[0] = xAxis0; this.options.xAxis[0] = xAxis0;
this.options.xAxis[1] = xAxis1; this.options.xAxis[1] = xAxis1;
}, },
// X // y
setOptionsXRight() { setOptionsYTop() {
const optionsSetup = this.optionsSetup; const optionsSetup = this.optionsSetup;
const xAxisRight = { const yAxis = {
gridIndex: 2, gridIndex: 0,
splitNumber: optionsSetup.splitNumberRight, splitNumber: optionsSetup.splitNumberYTop,
type: 'value', show: optionsSetup.isShowYTop,
axisLine: {//X线 scale: optionsSetup.scaleYTop, //
show: optionsSetup.xLineRight, name: optionsSetup.textNameYTop, //
lineStyle: { nameTextStyle: {
color: optionsSetup.lineColorXRight, color: optionsSetup.nameColorYTop,
fontSize: optionsSetup.namefontSizeYTop
},
axisLabel: {
show: true,
textStyle: {
color: optionsSetup.colorYTop,
fontSize: optionsSetup.fontSizeYTop,
}, },
}, },
axisTick: { axisTick: { //
show: optionsSetup.tickLineRight, show: optionsSetup.tickLineYTop,
}, },
position: 'bottom', axisLine: { // 线
axisLabel: { // x show: optionsSetup.lineYTop,
show: optionsSetup.hideXRight, lineStyle: {
textStyle: { color: optionsSetup.lineColorYTop,
color: optionsSetup.XcolorRight, },
fontSize: optionsSetup.fontSizeXRight
}
}, },
splitLine: { // 线 splitLine: {
show: optionsSetup.SplitLineRight, show: optionsSetup.splitLineYTop,
lineStyle: { lineStyle: {
color: optionsSetup.SplitLineColorRight, width: optionsSetup.splitLinefontSizeYTop,
width: optionsSetup.SplitLinefontSizeRight, color: optionsSetup.splitLineColorYTop,
type: 'solid' },
} },
} axisPointer: {
snap: true
},
} }
this.options.xAxis[2] = xAxisRight; this.options.yAxis[0] = yAxis
}, },
// Y // Y
setOptionsY() { setOptionsYBottom() {
const optionsSetup = this.optionsSetup; const optionsSetup = this.optionsSetup;
const axisLine = { const yAxis = {
show: optionsSetup.lineY, gridIndex: 1,
lineStyle: { splitNumber: optionsSetup.splitNumberYBottom,
color: optionsSetup.lineColorY show: optionsSetup.isShowYBottom,
} scale: optionsSetup.scaleYBottom, //
}; name: optionsSetup.textNameYBottom, //
const axisTick = { nameTextStyle: {
show: optionsSetup.tickLineY color: optionsSetup.nameColorYBottom,
}; fontSize: optionsSetup.namefontSizeYBottom
const axisLabel = { },
show: optionsSetup.hideY, inverse: true, //
textStyle: { axisLabel: {
align: optionsSetup.textAlign, show: true,
color: optionsSetup.colorY, textStyle: {
fontSize: optionsSetup.fontSizeY, color: optionsSetup.colorYBottom,
} fontSize: optionsSetup.fontSizeYBottom,
}; },
this.options.yAxis[1]['axisLine'] = axisLine; },
this.options.yAxis[1]['axisTick'] = axisTick; axisTick: { //
this.options.yAxis[1]['axisLabel'] = axisLabel; show: optionsSetup.tickLineYBottom,
},
axisLine: { // 线
show: optionsSetup.lineYBottom,
lineStyle: {
color: optionsSetup.lineColorYBottom,
},
},
splitLine: {
show: optionsSetup.splitLineYBottom,
lineStyle: {
width: optionsSetup.splitLinefontSizeYBottom,
color: optionsSetup.splitLineColorYBottom,
},
},
axisPointer: {
snap: true
},
}
this.options.yAxis[1] = yAxis
}, },
// //
setOptionsTop() { setOptionsTop() {
@ -450,41 +481,22 @@ export default {
this.options.tooltip = tooltip; this.options.tooltip = tooltip;
}, },
// //
getOptionsBottom() {
const optionsSetup = this.optionsSetup;
let bottom = optionsSetup.marginBottom;
if (optionsSetup.hideXLeft) {
bottom = optionsSetup.marginBottom + 15
} else if (optionsSetup.hideXRight) {
bottom = optionsSetup.marginBottom + 15
}
return bottom
},
setOptionsGrid() { setOptionsGrid() {
const optionsSetup = this.optionsSetup; const optionsSetup = this.optionsSetup;
const grid = [ const grid = [
{// {//
show: optionsSetup.frameLineLeft, left: optionsSetup.marginLeft,
left: optionsSetup.marginLeftRight, right: optionsSetup.marginRight,
top: optionsSetup.marginTop, top: optionsSetup.marginTop,
bottom: optionsSetup.marginBottom,
containLabel: true, containLabel: true,
width: '40%' bottom: '50%',
}, },
{// { //
show: false, left: optionsSetup.marginLeft,
left: "51%", right: optionsSetup.marginRight,
top: optionsSetup.marginTop,
bottom: this.getOptionsBottom(),
width: '0%'
},
{//
show: optionsSetup.frameLineRight,
right: optionsSetup.marginLeftRight,
top: optionsSetup.marginTop,
bottom: optionsSetup.marginBottom,
containLabel: true, containLabel: true,
width: '40%' top: '51%',
bottom: optionsSetup.marginBottom,
}, },
] ]
this.options.grid = grid; this.options.grid = grid;

Loading…
Cancel
Save