|
@@ -76,6 +76,9 @@ var TitlefontSizeValue = 32;
|
|
var pieFontSize = 14;
|
|
var pieFontSize = 14;
|
|
var PieMaxWidth = 100;
|
|
var PieMaxWidth = 100;
|
|
|
|
|
|
|
|
+var pointRadiusValue = 0;
|
|
|
|
+var pointHoverRadiusValue = 0;
|
|
|
|
+
|
|
|
|
|
|
var chart_bgimg_url = "url(./img/bg06.webp)";
|
|
var chart_bgimg_url = "url(./img/bg06.webp)";
|
|
|
|
|
|
@@ -409,12 +412,12 @@ send_data_compare.addEventListener("click", function () {
|
|
}
|
|
}
|
|
if (chartType === 'line') {
|
|
if (chartType === 'line') {
|
|
const colors = [
|
|
const colors = [
|
|
- 'rgba(130, 163, 63, 1)',
|
|
|
|
- 'rgba(47, 72, 123, 1)',
|
|
|
|
- '#df8c49',
|
|
|
|
- '#72598f',
|
|
|
|
- '#489fb6',
|
|
|
|
- '#99b0d5'
|
|
|
|
|
|
+ '#82a33f', // rgba already
|
|
|
|
+ '#2f487b', // rgba already
|
|
|
|
+ '#df8c49', // hex #df8c49
|
|
|
|
+ '#72598f', // hex #72598f
|
|
|
|
+ '#489fb6', // hex #489fb6
|
|
|
|
+ '#99b0d5' // hex #99b0d5
|
|
];
|
|
];
|
|
|
|
|
|
let colorIndex = 0;
|
|
let colorIndex = 0;
|
|
@@ -481,14 +484,24 @@ send_data_compare.addEventListener("click", function () {
|
|
|
|
|
|
const color = getRandomColor();
|
|
const color = getRandomColor();
|
|
|
|
|
|
|
|
+ if (response.data.data.length < 15) {
|
|
|
|
+ pointRadiusValue = 5;
|
|
|
|
+ pointHoverRadiusValue = 8;
|
|
|
|
+
|
|
|
|
+ togglePoints.checked = true;
|
|
|
|
+ }
|
|
|
|
+
|
|
const newDataset = {
|
|
const newDataset = {
|
|
label: stockName,
|
|
label: stockName,
|
|
backgroundColor: color,
|
|
backgroundColor: color,
|
|
- pointRadius: 0,
|
|
|
|
|
|
+ pointRadius: pointRadiusValue,
|
|
pointHoverRadius: 0,
|
|
pointHoverRadius: 0,
|
|
pointBorderColor: '#fff',
|
|
pointBorderColor: '#fff',
|
|
|
|
+ pointBorderWidth: 3,
|
|
|
|
+ pointHoverRadiusValue: 8,
|
|
borderColor: color,
|
|
borderColor: color,
|
|
data: stock2Normalized,
|
|
data: stock2Normalized,
|
|
|
|
+
|
|
fill: false
|
|
fill: false
|
|
};
|
|
};
|
|
|
|
|
|
@@ -1438,8 +1451,7 @@ function getDatalabelsConfig(dataLength) {
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
-var pointRadiusValue = 0;
|
|
|
|
-var pointHoverRadiusValue = 0;
|
|
|
|
|
|
+
|
|
|
|
|
|
function getDatalabelsConfig(isEnabled) {
|
|
function getDatalabelsConfig(isEnabled) {
|
|
if (!isEnabled) {
|
|
if (!isEnabled) {
|
|
@@ -1577,6 +1589,7 @@ function createChart(chartType, data, labels) {
|
|
|
|
|
|
legend: {
|
|
legend: {
|
|
display: false,
|
|
display: false,
|
|
|
|
+ fullSize: true
|
|
},
|
|
},
|
|
|
|
|
|
},
|
|
},
|
|
@@ -1638,6 +1651,30 @@ function createChart(chartType, data, labels) {
|
|
bottom: 10,
|
|
bottom: 10,
|
|
}
|
|
}
|
|
},
|
|
},
|
|
|
|
+ onClick: function (event, elements) {
|
|
|
|
+ console.log()
|
|
|
|
+ if (elements.length > 0) {
|
|
|
|
+ const element = elements[0];
|
|
|
|
+ selectedDatasetIndex = element.datasetIndex;
|
|
|
|
+
|
|
|
|
+ const currentColor = myChart.data.datasets[selectedDatasetIndex].borderColor;
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ const colorValue = currentColor;
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ colorInput.value = colorValue;
|
|
|
|
+
|
|
|
|
+ // 获取当前线条颜色并更新 colorPicker
|
|
|
|
+
|
|
|
|
+ // colorInput.value = rgbToHex(currentColor);
|
|
|
|
+
|
|
|
|
+ // console.log('當前顏色', colorValue);
|
|
|
|
+
|
|
|
|
+ colorInput.disabled = false; // 启用 colorPicker
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
|
|
},
|
|
},
|
|
});
|
|
});
|
|
@@ -1664,6 +1701,8 @@ function createChart(chartType, data, labels) {
|
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+
|
|
|
|
+
|
|
// createChart(chartType);
|
|
// createChart(chartType);
|
|
|
|
|
|
// createChart(chartType)
|
|
// createChart(chartType)
|
|
@@ -1797,13 +1836,9 @@ toggleUnit.addEventListener('change', function () {
|
|
// 單位
|
|
// 單位
|
|
// =========================
|
|
// =========================
|
|
var unitInput = document.getElementById('unit_data');
|
|
var unitInput = document.getElementById('unit_data');
|
|
-
|
|
|
|
var unit_value = document.querySelector('.unit');
|
|
var unit_value = document.querySelector('.unit');
|
|
-
|
|
|
|
var unit_value_box = document.querySelector('#unit_box');
|
|
var unit_value_box = document.querySelector('#unit_box');
|
|
|
|
|
|
-
|
|
|
|
-
|
|
|
|
// console.log('單位', unitInput)
|
|
// console.log('單位', unitInput)
|
|
|
|
|
|
unitInput.addEventListener('input', function () {
|
|
unitInput.addEventListener('input', function () {
|
|
@@ -1822,9 +1857,6 @@ unitInput.addEventListener('input', function () {
|
|
|
|
|
|
});
|
|
});
|
|
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-
|
|
|
|
// ==========================
|
|
// ==========================
|
|
|
|
|
|
// y軸字體大小-折線圖
|
|
// y軸字體大小-折線圖
|
|
@@ -1851,7 +1883,6 @@ YfontSize.addEventListener('input', function () {
|
|
var XfontSize = document.getElementById('XfontSize');
|
|
var XfontSize = document.getElementById('XfontSize');
|
|
|
|
|
|
XfontSize.addEventListener('input', function () {
|
|
XfontSize.addEventListener('input', function () {
|
|
-
|
|
|
|
XfontSizeValue = XfontSize.value;
|
|
XfontSizeValue = XfontSize.value;
|
|
console.log(XfontSizeValue)
|
|
console.log(XfontSizeValue)
|
|
if (myChart) {
|
|
if (myChart) {
|
|
@@ -1861,7 +1892,6 @@ XfontSize.addEventListener('input', function () {
|
|
});
|
|
});
|
|
// ==========================
|
|
// ==========================
|
|
|
|
|
|
-
|
|
|
|
// x軸字體大小-柱狀圖
|
|
// x軸字體大小-柱狀圖
|
|
// ==========================
|
|
// ==========================
|
|
var XfontSizeBar = document.getElementById('XfontSizeBar');
|
|
var XfontSizeBar = document.getElementById('XfontSizeBar');
|
|
@@ -1876,7 +1906,6 @@ XfontSizeBar.addEventListener('input', function () {
|
|
// y軸字體大小-柱狀圖
|
|
// y軸字體大小-柱狀圖
|
|
// ==========================
|
|
// ==========================
|
|
|
|
|
|
-
|
|
|
|
var YfontSizeBar = document.getElementById('YfontSizeBar');
|
|
var YfontSizeBar = document.getElementById('YfontSizeBar');
|
|
YfontSizeBar.addEventListener('input', function () {
|
|
YfontSizeBar.addEventListener('input', function () {
|
|
extractAndGenerateChart(dataArray);
|
|
extractAndGenerateChart(dataArray);
|
|
@@ -1903,13 +1932,20 @@ colorInputBar.addEventListener('input', function () {
|
|
|
|
|
|
// 線條粗細
|
|
// 線條粗細
|
|
// =========================
|
|
// =========================
|
|
|
|
+
|
|
|
|
+function updateLineWidth(borderWidthValue) {
|
|
|
|
+ myChart.data.datasets.forEach(dataset => {
|
|
|
|
+ dataset.borderWidth = parseFloat(borderWidthValue);
|
|
|
|
+ });
|
|
|
|
+ myChart.update();
|
|
|
|
+}
|
|
var rangeInput = document.getElementById('borderWidthRange');
|
|
var rangeInput = document.getElementById('borderWidthRange');
|
|
|
|
|
|
-var rangeInputSpan = document.getElementById('borderWidthRangeValue');
|
|
|
|
|
|
+// var rangeInputSpan = document.getElementById('borderWidthRangeValue');
|
|
|
|
|
|
var borderWidthValue;
|
|
var borderWidthValue;
|
|
|
|
|
|
-rangeInputSpan.textContent = rangeInput.value;
|
|
|
|
|
|
+// rangeInputSpan.textContent = rangeInput.value;
|
|
|
|
|
|
|
|
|
|
// 添加事件监听器,当滑动条的值发生改变时更新显示的值
|
|
// 添加事件监听器,当滑动条的值发生改变时更新显示的值
|
|
@@ -1918,13 +1954,10 @@ rangeInput.addEventListener('input', function () {
|
|
borderWidthValue = rangeInput.value;
|
|
borderWidthValue = rangeInput.value;
|
|
|
|
|
|
console.log(borderWidthValue);
|
|
console.log(borderWidthValue);
|
|
- rangeInputSpan.textContent = borderWidthValue;
|
|
|
|
|
|
|
|
- if (myChart) {
|
|
|
|
- myChart.destroy();
|
|
|
|
- }
|
|
|
|
|
|
+ // rangeInputSpan.textContent = borderWidthValue;
|
|
|
|
|
|
- createChart(chartType, data, labels);
|
|
|
|
|
|
+ updateLineWidth(borderWidthValue);
|
|
// myChart.data.datasets[0].borderWidth = borderWidthValue;
|
|
// myChart.data.datasets[0].borderWidth = borderWidthValue;
|
|
|
|
|
|
});
|
|
});
|
|
@@ -1936,21 +1969,52 @@ rangeInput.addEventListener('input', function () {
|
|
|
|
|
|
|
|
|
|
const colorInput = document.getElementById('borderColorInput');
|
|
const colorInput = document.getElementById('borderColorInput');
|
|
-
|
|
|
|
|
|
+let selectedDatasetIndex = null;
|
|
|
|
|
|
// 添加事件监听器,当颜色选择发生变化时触发
|
|
// 添加事件监听器,当颜色选择发生变化时触发
|
|
colorInput.addEventListener('input', function () {
|
|
colorInput.addEventListener('input', function () {
|
|
// 获取当前选择的颜色值
|
|
// 获取当前选择的颜色值
|
|
- chartColor = colorInput.value;
|
|
|
|
|
|
+ // chartColor = colorInput.value;
|
|
|
|
+ // if (myChart) {
|
|
|
|
+ // myChart.destroy();
|
|
|
|
+ // }
|
|
|
|
+ if (selectedDatasetIndex !== null) {
|
|
|
|
+ const newColor = colorInput.value;
|
|
|
|
+ myChart.data.datasets[selectedDatasetIndex].borderColor = newColor;
|
|
|
|
+ myChart.data.datasets[selectedDatasetIndex].backgroundColor = newColor;
|
|
|
|
|
|
- if (myChart) {
|
|
|
|
- myChart.destroy();
|
|
|
|
|
|
+ myChart.update(); // 更新图表
|
|
|
|
+ // createChart(chartType, data, labels);
|
|
}
|
|
}
|
|
|
|
+ // console.log(chartColor);
|
|
|
|
+ // createChart(chartType, data, labels);
|
|
|
|
+});
|
|
|
|
|
|
|
|
+function rgbToHex(rgb) {
|
|
|
|
+ const rgbArr = rgb.match(/\d+/g);
|
|
|
|
+ return `#${((1 << 24) + (parseInt(rgbArr[0]) << 16) + (parseInt(rgbArr[1]) << 8) + parseInt(rgbArr[2])).toString(16).slice(1)}`;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+function hexToRgba(hex, alpha = 1) {
|
|
|
|
+ // 移除 HEX 颜色值的 # 符号
|
|
|
|
+ hex = hex.replace(/^#/, '');
|
|
|
|
+
|
|
|
|
+ // 处理 3 位 HEX 颜色值(如 #fff)
|
|
|
|
+ if (hex.length === 3) {
|
|
|
|
+ hex = hex.split('').map(function (hex) {
|
|
|
|
+ return hex + hex;
|
|
|
|
+ }).join('');
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ // 解析 HEX 颜色值
|
|
|
|
+ const r = parseInt(hex.substring(0, 2), 16);
|
|
|
|
+ const g = parseInt(hex.substring(2, 4), 16);
|
|
|
|
+ const b = parseInt(hex.substring(4, 6), 16);
|
|
|
|
+
|
|
|
|
+ // 返回 RGBA 颜色值
|
|
|
|
+ return `rgba(${r}, ${g}, ${b}, ${alpha})`;
|
|
|
|
+}
|
|
|
|
|
|
- console.log(chartColor);
|
|
|
|
- createChart(chartType, data, labels);
|
|
|
|
-});
|
|
|
|
|
|
|
|
// =========================
|
|
// =========================
|
|
|
|
|
|
@@ -1962,7 +2026,6 @@ colorInput.addEventListener('input', function () {
|
|
// =========================
|
|
// =========================
|
|
// JavaScript
|
|
// JavaScript
|
|
document.addEventListener("DOMContentLoaded", function () {
|
|
document.addEventListener("DOMContentLoaded", function () {
|
|
-
|
|
|
|
// 獲取所有帶有 templateImg class 的圖像元素
|
|
// 獲取所有帶有 templateImg class 的圖像元素
|
|
var templateImgs = document.querySelectorAll('.templateImg');
|
|
var templateImgs = document.querySelectorAll('.templateImg');
|
|
|
|
|