rapid-spreadjs 1.0.17 → 1.0.19

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs.min.js","sources":["../src/utils/common.ts","../node_modules/.pnpm/@rollup+plugin-typescript@1_ccba8aa16c5fc04bbd7ba036697931a3/node_modules/tslib/tslib.es6.js","../src/utils/echarts-all.ts","../src/utils/echarts.ts","../src/utils/sheet.ts","../src/utils/wookbook.ts"],"sourcesContent":["/**\r\n * 公用工具函数属性\r\n */\r\nexport const CommonUtils = {\r\n /**\r\n * 获取列的英文字母\r\n * @param colIndex 列的索引\r\n * @returns 返回英文字母\r\n */\r\n getColLetterName: (colIndex: number): string => {\r\n colIndex += 1;\r\n\r\n let letter = \"\";\r\n while (colIndex > 0) {\r\n const remainder = (colIndex - 1) % 26;\r\n letter = String.fromCharCode(remainder + 65) + letter;\r\n colIndex = Math.floor((colIndex - 1) / 26);\r\n }\r\n\r\n return letter.toUpperCase();\r\n },\r\n};\r\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","import * as math from 'mathjs';\r\nimport { type EChartsUtilsConfigModel } from '../types/echarts';\r\n\r\n/**\r\n * 公用方法,如:修约计算等\r\n */\r\nconst EChartsUtilsComm = {\r\n /**\r\n * 计算常规修约\r\n * @param roundingVal 修约值\r\n * @param accuracy 修约精度\r\n * @return 返回修约结果\r\n */\r\n getRound: (roundingVal, accuracy) => {\r\n // 验证修约的值是否为负数,为负数的话,取绝对值进行修约\r\n const valIsNegative = roundingVal < 0;\r\n if (valIsNegative) {\r\n roundingVal = Math.abs(roundingVal);\r\n }\r\n\r\n // 修约精度为0的时候\r\n if (accuracy == 0) {\r\n // 得到字符串形式\r\n let inputValStr = roundingVal.toString();\r\n\r\n // 判断是否有小数点,没有则直接返回换算后的修约值\r\n if (inputValStr.indexOf('.') == -1) {\r\n return valIsNegative ? -roundingVal : roundingVal;\r\n }\r\n\r\n // 获取整数数字部分和小数部分字符串\r\n let intVal = parseInt(inputValStr.split('.')[0]);\r\n let decimalStr = inputValStr.split('.')[1];\r\n\r\n // 小数部分大于或等于0.5的话,就给整数部分加1后返回,否则返回整数部分\r\n if (parseFloat(`0.${decimalStr}`) >= 0.5) {\r\n return valIsNegative ? -(intVal + 1) : intVal + 1;\r\n } else {\r\n return valIsNegative ? -intVal : intVal;\r\n }\r\n }\r\n\r\n // 系数\r\n let coefficient = 1 / accuracy;\r\n\r\n // 换算后的修约值(=修约值*系数)\r\n // 注意:此处使用到了toFixed,目的是可能会存在精度的问题\r\n let roundingValCal = Number((roundingVal * coefficient).toFixed(8));\r\n\r\n /**\r\n * 计算修约结果函数\r\n * @param inputVal 换算后的修约值\r\n * @returns 返回修约结果\r\n */\r\n const calcRoundingRet = (inputVal: number): number => {\r\n // 得到字符串形式\r\n let inputValStr = inputVal.toString();\r\n\r\n // 判断是否有小数点,没有则直接返回换算后的修约值\r\n if (inputValStr.indexOf('.') == -1) {\r\n return inputVal;\r\n }\r\n\r\n // 获取整数数字部分和小数部分字符串\r\n let intVal = parseInt(inputValStr.split('.')[0]);\r\n let decimalStr = inputValStr.split('.')[1];\r\n\r\n // 获取小数部分的第一位数字\r\n let decimalStrFirst = parseInt(decimalStr.substring(0, 1));\r\n\r\n // 大于等于6的时候,入\r\n if (decimalStrFirst >= 6) {\r\n return intVal + 1;\r\n }\r\n // 小于等于4的时候,舍\r\n else if (decimalStrFirst <= 4) {\r\n return intVal;\r\n }\r\n\r\n // 小数部分为5,并且只有一位小数的时候,前面的整数部分如果是奇数则入,反之则舍\r\n else if (decimalStrFirst == 5 && decimalStr.length == 1) {\r\n return intVal % 2 != 0 ? intVal + 1 : intVal;\r\n }\r\n\r\n // 小数部分为5,并且小数位数大于一位的时候,则入\r\n else if (decimalStrFirst == 5 && decimalStr.length > 1) {\r\n return intVal + 1;\r\n }\r\n\r\n return inputVal;\r\n };\r\n\r\n // 返回最终修约结果(=修约结果/系数)\r\n const retNum = calcRoundingRet(roundingValCal) / coefficient;\r\n\r\n //获取修约精度中的小数位数\r\n let accuracyStr = accuracy + '';\r\n\r\n // 如果修约精度中没有小数,则直接返回\r\n if (accuracyStr.indexOf('.') == -1) {\r\n return valIsNegative ? -retNum : retNum;\r\n } else {\r\n const retNumStr = retNum + '';\r\n\r\n // 补位的0的字符串\r\n let zeroStr = '';\r\n\r\n // 结果为整数的时候,需要补充小数点后面的小数位数为0,如:34→34.0\r\n if (retNumStr.indexOf('.') == -1) {\r\n let zeroStr = '';\r\n for (let index = 0; index < accuracyStr.split('.')[1].length; index++) {\r\n zeroStr += '0';\r\n }\r\n\r\n return (valIsNegative ? '-' : '') + `${retNum}.${zeroStr}`;\r\n }\r\n // 结果为小数的时候,需要补充修约精度的位数,如:0.3修约精度为0.01,则最终应该返回0.30\r\n else {\r\n const xsPart = retNumStr.split('.')[1];\r\n\r\n if (accuracyStr.split('.')[1].length > xsPart.length) {\r\n for (let index = 0; index < accuracyStr.split('.')[1].length - xsPart.length; index++) {\r\n zeroStr += '0';\r\n }\r\n }\r\n\r\n return (valIsNegative ? '-' : '') + `${retNum}${zeroStr}`;\r\n }\r\n }\r\n },\r\n /**\r\n * 实现Excel中TREND(返回线性回归拟合线的一组纵坐标值[y值])公式的计算\r\n * @param x x轴数据集合\r\n * @param y y轴数据集合\r\n * @param xVal x轴的值\r\n * @returns\r\n */\r\n calcTrend: (x: Array<number>, y: Array<number>, xVal: number) => {\r\n let n = x.length;\r\n let sumX = 0,\r\n sumY = 0,\r\n sumXY = 0,\r\n sumXX = 0;\r\n for (let i = 0; i < n; i++) {\r\n sumX += x[i];\r\n sumY += y[i];\r\n sumXY += x[i] * y[i];\r\n sumXX += x[i] * x[i];\r\n }\r\n let slope = (n * sumXY - sumX * sumY) / (n * sumXX - sumX * sumX);\r\n let intercept = (sumY - slope * sumX) / n;\r\n\r\n let predictedY = slope * xVal + intercept;\r\n\r\n if (slope + '' == 'NaN') {\r\n return { y: '', gs: '', xl: '', jj: '' };\r\n }\r\n\r\n //返回y轴趋势数据,以及公式\r\n return { y: predictedY, gs: `${slope}*x+${intercept}`, xl: slope, jj: intercept };\r\n },\r\n /**\r\n * 过滤掉数组中的null、空字符串或/符号等,并返回新的数组\r\n * @param dataSource 原始数组\r\n */\r\n filterNullEmptyErrArray: (dataSource: Array<any>) => {\r\n let retArr = dataSource.filter((item) => item != null && item != undefined && (item._error == null || item._error == undefined) && item != '/');\r\n\r\n return retArr;\r\n },\r\n};\r\n\r\n/**\r\n * 所有统计图表的ECharts配置\r\n */\r\nexport const EChartsUtilsAll = {\r\n /**\r\n * 沥青混合料-目标配合比设计-毛体积密度\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart10: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineJson = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n let xDataSource = xDataArr[0],\r\n yDataSource = yDataArr[0];\r\n\r\n // 原始数据\r\n let dxsJs = chartExtJson != null ? chartExtJson.dxsJs : 5,\r\n xData: any[] = [],\r\n yData: any[] = [];\r\n\r\n // 处理原始数据为空的值,不然参与mathjs计算会报错\r\n xDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n xData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n xData.push(item);\r\n }\r\n }\r\n });\r\n yDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n yData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n yData.push(item);\r\n }\r\n }\r\n });\r\n\r\n // y轴没有任何数据的时候,不参与绘制图表\r\n if (yData.length == 0) {\r\n return;\r\n }\r\n\r\n // 检查x轴的数据有多少个0,大于1个的时候,就不绘制图形\r\n let zeroCount = 0;\r\n xData.forEach((item) => {\r\n if (item == 0) {\r\n zeroCount++;\r\n }\r\n });\r\n // if (zeroCount > 1) {\r\n // \treturn;\r\n // }\r\n\r\n if (dxsJs >= yData.length) {\r\n dxsJs = yData.length - 1;\r\n }\r\n\r\n let xMin = Math.min(...xData),\r\n xMax = Math.max(...xData),\r\n yMin = Math.min(...yData),\r\n yMax = Math.max(...yData),\r\n /*xAxisMax = 5.5,\r\n xAxisMin = 3.5,\r\n yAxisMax = 2.35,\r\n yAxisMin = 2.25,\r\n */\r\n xAxisMax = xMax,\r\n xAxisMin = xMin,\r\n yAxisMax = Number(EChartsUtilsComm.getRound(yMax + 0.05, 0.01)),\r\n yAxisMin = Number(EChartsUtilsComm.getRound(yMin - 0.05, 0.01)),\r\n seriesData = [],\r\n upperLimit = null, // 上限\r\n lowerLimit = null,\r\n showLine = true; // 是否显示辅助线\r\n\r\n let points: any = [];\r\n xData.forEach((item, index) => {\r\n points.push([item, yData[index]]);\r\n });\r\n\r\n // 构造范德蒙德矩阵的函数\r\n function vandermondeMatrix(x, N) {\r\n const matrix = [];\r\n for (let i = 0; i < x.length; i++) {\r\n const row = [];\r\n for (let j = 0; j <= N; j++) {\r\n // 注意这里从0到N,包含N\r\n row.push(math.pow(x[i], j));\r\n }\r\n matrix.push(row);\r\n }\r\n return math.matrix(matrix);\r\n }\r\n\r\n // 构造原始的范德蒙德矩阵\r\n const vandermonde_matrix = vandermondeMatrix(xData, dxsJs); // 注意这里N=4,因为我们从0开始计数\r\n\r\n // 使用最小二乘法求解\r\n const A = vandermonde_matrix;\r\n const AT = math.transpose(A);\r\n const ATA = math.multiply(AT, A);\r\n const ATb = math.multiply(AT, math.matrix(yData));\r\n\r\n // 解线性方程组\r\n // const result = math.lusolve(ATA, ATb);\r\n // const coefficients = result.valueOf();\r\n\r\n let result: any = null,\r\n coefficients: any = [];\r\n try {\r\n result = math.lusolve(ATA, ATb);\r\n coefficients = result.valueOf();\r\n } catch (err) {\r\n for (let index = 0; index < xData.length; index++) {\r\n coefficients.push([0]);\r\n }\r\n console.log('无法解决该线性系统');\r\n }\r\n\r\n function funequation(x) {\r\n let y = 0;\r\n coefficients.forEach((item, index) => {\r\n //fx^0\r\n //fx^0+ax^1\r\n //fx^0+ax^1+bx^2\r\n //fx^0+ax^1+bx^2+cx^3\r\n //fx^0+x^1+x^2+x^3+x^4\r\n y += item * x ** index;\r\n });\r\n return y;\r\n }\r\n // console.log('计算公式:', coefficients);\r\n\r\n function lagrangeInterpolation(points, x) {\r\n let result = 0;\r\n for (let i = 0; i < points.length; i++) {\r\n let term = points[i][1];\r\n let xi = points[i][0];\r\n for (let j = 0; j < points.length; j++) {\r\n if (j !== i) {\r\n let xj = points[j][0];\r\n term *= (x - xj) / (xi - xj);\r\n }\r\n }\r\n result += term;\r\n }\r\n return result;\r\n }\r\n let arrX = [];\r\n let arrY = [];\r\n for (let i = xMin; i <= xMax; i += 0.01) {\r\n let temp = Number(EChartsUtilsComm.getRound(i, 0.01));\r\n //arrY.push(lagrangeInterpolation(points, temp));\r\n arrY.push(funequation(temp));\r\n arrX.push(temp);\r\n }\r\n let max = Math.max(...arrY);\r\n\r\n // 找到最大值的索引\r\n let maxIndex = arrY.findIndex((value) => value === max);\r\n\r\n // console.log('最大点数据:', arrX[maxIndex], max);\r\n\r\n let title = '', // config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n arrX.forEach((item, index) => {\r\n if (xData.includes(item)) {\r\n seriesData.push({ value: [item, arrY[index]] });\r\n } else {\r\n seriesData.push({\r\n value: [item, arrY[index]],\r\n symbol: 'none',\r\n });\r\n }\r\n });\r\n // 计算峰值\r\n const peakvalue = [arrX[maxIndex], Number(EChartsUtilsComm.getRound(max, 0.001))],\r\n coordX = [peakvalue[0], yAxisMin];\r\n\r\n // console.log('x范围:', xMin, xMax);\r\n // 输出开始和结束范围\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlKs != null && chartExtJson.lqhhlKs != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlKs.row, chartExtJson.lqhhlKs.col, xMin);\r\n sheet.setValue(chartExtJson.lqhhlJs.row, chartExtJson.lqhhlJs.col, xMax);\r\n }\r\n if (chartExtJson.lqhhlSc1 != null && chartExtJson.lqhhlSc1 != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlSc1.row, chartExtJson.lqhhlSc1.col, arrX[maxIndex]);\r\n }\r\n }\r\n\r\n let lineData = [];\r\n let pointData = [];\r\n if (showLine) {\r\n lineData = [\r\n [\r\n {\r\n coord: coordX,\r\n lineStyle: {\r\n color: '#333', // X轴\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: peakvalue,\r\n },\r\n ],\r\n ];\r\n pointData = [\r\n {\r\n xAxis: peakvalue[0],\r\n yAxis: peakvalue[1],\r\n symbolOffset: [0, 15],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n if (Number(data.data.xAxis) == 0 && Number(data.data.yAxis) == 0) {\r\n return '';\r\n } else {\r\n return '( ' + data.data.xAxis + ',' + data.data.yAxis + ')';\r\n }\r\n //return '( ' + data.data.xAxis + ',' + data.data.yAxis + ')';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n {\r\n xAxis: peakvalue[0],\r\n yAxis: yAxisMin,\r\n symbolOffset: [0, 40],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n return 'a1';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n ];\r\n }\r\n\r\n // 判断数据是否为/\r\n let yValIsAllNull = false;\r\n seriesData.forEach((item) => {\r\n yValIsAllNull = item.value.every((ele) => {\r\n return ele == 0;\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,// 是否显示外边框线\r\n // borderColor: '#f00',// 外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: !yValIsAllNull ? 16 : 20,\r\n containLabel: true,\r\n },\r\n // 提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n //console.log(datas,\" datas\")\r\n return datas && datas.length > 0\r\n ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + Number(EChartsUtilsComm.getRound(datas[0].value[1], 0.001))\r\n : datas[0].data;\r\n },\r\n },\r\n // 顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n // 图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, // 显示\r\n },\r\n selectedMode: 'multiple', // 用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, // 使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 40 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', // '#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n // splitNumber: 10, // 设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n // 设置y轴箭头效果\r\n show: true, // y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, // 平滑的线条\r\n // 设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', // 符号类型\r\n symbolSize: 6, // 符号大小 lineJson.lineColor\r\n // 线条的颜色\r\n lineStyle: {\r\n color: lineJson[0].lineColor,\r\n // 线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n // 线条上数据点的颜色\r\n itemStyle: {\r\n color: lineJson[0].lineColor,\r\n },\r\n data: seriesData,\r\n markPoint: {\r\n data: pointData,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'], // 去掉箭头\r\n itemStyle: {\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n width: 2,\r\n },\r\n },\r\n data: lineData,\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 沥青混合料-目标配合比设计-稳定度\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart11: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineJson = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n let xDataSource = xDataArr[0],\r\n yDataSource = yDataArr[0];\r\n\r\n // 原始数据\r\n let dxsJs = chartExtJson != null ? chartExtJson.dxsJs : 5,\r\n xData = [],\r\n yData = [];\r\n\r\n // 处理原始数据为空的值,不然参与mathjs计算会报错\r\n xDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n xData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n xData.push(item);\r\n }\r\n }\r\n });\r\n yDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n yData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n yData.push(item);\r\n }\r\n }\r\n });\r\n\r\n // y轴没有任何数据的时候,不参与绘制图表\r\n if (yData.length == 0) {\r\n return;\r\n }\r\n\r\n // 检查x轴的数据有多少个0,大于1个的时候,就不绘制图形\r\n let zeroCount = 0;\r\n xData.forEach((item) => {\r\n if (item == 0) {\r\n zeroCount++;\r\n }\r\n });\r\n // if (zeroCount > 1) {\r\n // \treturn;\r\n // }\r\n\r\n if (dxsJs >= yData.length) {\r\n dxsJs = yData.length - 1;\r\n }\r\n\r\n let xMin = Math.min(...xData),\r\n xMax = Math.max(...xData),\r\n yMin = Math.min(...yData),\r\n yMax = Math.max(...yData),\r\n xAxisMax = xMax,\r\n xAxisMin = xMin,\r\n yAxisMax = Math.ceil(yMax + 2),\r\n yAxisMin = Math.floor(yMin - 2),\r\n seriesData = [],\r\n upperLimit = null, // 上限\r\n lowerLimit = 7.5, // 下限\r\n showLine = true; // 是否显示辅助线\r\n\r\n // 获取单元格中的上限和下限\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSx != null && chartExtJson.lqhhlSx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlSx.row, chartExtJson.lqhhlSx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n upperLimit = curVal;\r\n }\r\n }\r\n if (chartExtJson.lqhhlXx != null && chartExtJson.lqhhlXx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlXx.row, chartExtJson.lqhhlXx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n lowerLimit = curVal;\r\n }\r\n }\r\n }\r\n\r\n if (upperLimit != null && upperLimit > yAxisMax) {\r\n yAxisMax = upperLimit + 2;\r\n }\r\n if (lowerLimit != null && lowerLimit > yAxisMax) {\r\n yAxisMin = lowerLimit - 2;\r\n }\r\n\r\n let points = [];\r\n xData.forEach((item, index) => {\r\n points.push([item, yData[index]]);\r\n });\r\n\r\n // 构造范德蒙德矩阵的函数\r\n function vandermondeMatrix(x, N) {\r\n const matrix = [];\r\n for (let i = 0; i < x.length; i++) {\r\n const row = [];\r\n for (let j = 0; j <= N; j++) {\r\n // 注意这里从0到N,包含N\r\n row.push(math.pow(x[i], j));\r\n }\r\n matrix.push(row);\r\n }\r\n return math.matrix(matrix);\r\n }\r\n\r\n // 构造原始的范德蒙德矩阵\r\n const vandermonde_matrix = vandermondeMatrix(xData, dxsJs); // 注意这里N=4,因为我们从0开始计数\r\n\r\n // 使用最小二乘法求解\r\n const A = vandermonde_matrix;\r\n const AT = math.transpose(A);\r\n const ATA = math.multiply(AT, A);\r\n const ATb = math.multiply(AT, math.matrix(yData));\r\n\r\n // 解线性方程组\r\n // const result = math.lusolve(ATA, ATb);\r\n // const coefficients = result.valueOf();\r\n\r\n let result: any = null,\r\n coefficients: any = [];\r\n try {\r\n result = math.lusolve(ATA, ATb);\r\n coefficients = result.valueOf();\r\n } catch (err) {\r\n for (let index = 0; index < xData.length; index++) {\r\n coefficients.push([0]);\r\n }\r\n console.log('无法解决该线性系统');\r\n }\r\n\r\n function funequation(x) {\r\n let y = 0;\r\n coefficients.forEach((item, index) => {\r\n //fx^0\r\n //fx^0+ax^1\r\n //fx^0+ax^1+bx^2\r\n //fx^0+ax^1+bx^2+cx^3\r\n //fx^0+x^1+x^2+x^3+x^4\r\n y += item * x ** index;\r\n });\r\n return y;\r\n }\r\n\r\n // console.log('计算公式:', coefficients);\r\n\r\n function lagrangeInterpolation(points, x) {\r\n let result = 0;\r\n for (let i = 0; i < points.length; i++) {\r\n let term = points[i][1];\r\n let xi = points[i][0];\r\n for (let j = 0; j < points.length; j++) {\r\n if (j !== i) {\r\n let xj = points[j][0];\r\n term *= (x - xj) / (xi - xj);\r\n }\r\n }\r\n result += term;\r\n }\r\n return result;\r\n }\r\n let arrX = [];\r\n let arrY = [];\r\n for (let i = xMin; i <= xMax; i += 0.01) {\r\n let temp = Number(EChartsUtilsComm.getRound(i, 0.01));\r\n // arrY.push(lagrangeInterpolation(points, temp));\r\n arrY.push(funequation(temp));\r\n arrX.push(temp);\r\n }\r\n let max = Math.max(...arrY);\r\n\r\n // 找到最大值的索引\r\n let maxIndex = arrY.findIndex((value) => value === max);\r\n\r\n // console.log('最大点数据:', arrX[maxIndex], max);\r\n\r\n let title = '', // config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n arrX.forEach((item, index) => {\r\n if (xData.includes(item)) {\r\n seriesData.push({ value: [item, arrY[index]] });\r\n } else {\r\n seriesData.push({\r\n value: [item, arrY[index]],\r\n symbol: 'none',\r\n });\r\n }\r\n });\r\n\r\n // 计算两条线段是否有交点\r\n function ifHaveIntersectionPoint(y1, y2, y3, y4) {\r\n if ((y1 >= y3 && y2 <= y4) || (y1 <= y3 && y2 >= y4)) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n // 获取两点和香交线最接近的点\r\n function getIntersectionPoint(y1, y2, y) {\r\n if (Math.abs(y1 - y) > Math.abs(y2 - y)) {\r\n return 0;\r\n }\r\n return -1;\r\n }\r\n let upperIntersectionPoint = [],\r\n lowerIntersectionPoint = [];\r\n let upperIntersectionPointTrend = []; // 上限交点趋势(向上相交(1) 还是向下相交(0))\r\n let lowerIntersectionPointTrend = []; // 下限交点趋势\r\n arrX.forEach((item, index) => {\r\n if (index > 0) {\r\n // 上限交点\r\n if (upperLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], upperLimit, upperLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], upperLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n upperIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n // 向下趋势\r\n upperIntersectionPointTrend.push(0);\r\n } else {\r\n upperIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n // 下限交点\r\n if (lowerLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit, lowerLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n lowerIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n // 向下趋势\r\n lowerIntersectionPointTrend.push(0);\r\n } else {\r\n lowerIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n let validX1 = xMin,\r\n validX2 = xMax;\r\n if (upperIntersectionPoint.length == 0 && lowerIntersectionPoint.length > 0) {\r\n // 上限无交点,下限有交点\r\n if (lowerIntersectionPointTrend[0] == 0) {\r\n // 下限向下相交\r\n validX1 = xMin;\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n // 下限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n if (lowerIntersectionPoint.length == 1) {\r\n // 只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = lowerIntersectionPoint[1][0];\r\n }\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length == 0) {\r\n // 上限有交点,下限无交点\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n // 上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n if (upperIntersectionPoint.length == 1) {\r\n // 只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = upperIntersectionPoint[1][0];\r\n }\r\n } else {\r\n // 上限向上相交\r\n validX1 = xMin;\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length > 0) {\r\n // 上下限都有交点,情况太多,我们只取中间\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n // 上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n // 上限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n }\r\n\r\n // console.log('x范围:', validX1, validX2);\r\n // 输出开始和结束范围\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlKs != null && chartExtJson.lqhhlKs != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlKs.row, chartExtJson.lqhhlKs.col, validX1);\r\n sheet.setValue(chartExtJson.lqhhlJs.row, chartExtJson.lqhhlJs.col, validX2);\r\n }\r\n if (chartExtJson.lqhhlSc1 != null && chartExtJson.lqhhlSc1 != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlSc1.row, chartExtJson.lqhhlSc1.col, arrX[maxIndex]);\r\n }\r\n }\r\n\r\n // 峰值\r\n const peakvalue = [arrX[maxIndex], Number(EChartsUtilsComm.getRound(max, 0.001))];\r\n\r\n let lineData = [];\r\n let pointData = [];\r\n if (showLine) {\r\n lineData = [\r\n [\r\n {\r\n coord: [peakvalue[0], yAxisMin],\r\n lineStyle: {\r\n color: '#333', // X轴\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: peakvalue,\r\n },\r\n ],\r\n ];\r\n pointData = [\r\n {\r\n xAxis: peakvalue[0],\r\n yAxis: peakvalue[1],\r\n symbolOffset: [0, 15],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n if (Number(data.data.xAxis) == 0 && Number(data.data.yAxis) == 0) {\r\n return '';\r\n } else {\r\n return '( ' + data.data.xAxis + ',' + data.data.yAxis + ')';\r\n }\r\n //return '( ' + data.data.xAxis + ',' + data.data.yAxis + ')';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n {\r\n xAxis: peakvalue[0],\r\n yAxis: yAxisMin,\r\n symbolOffset: [0, 40],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n return 'a2';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n ];\r\n }\r\n\r\n if (upperLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, upperLimit],\r\n lineStyle: {\r\n color: '#333', //上限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, upperLimit],\r\n },\r\n ]);\r\n }\r\n\r\n if (lowerLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, lowerLimit],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, lowerLimit],\r\n },\r\n ]);\r\n }\r\n\r\n //判断数据是否为/\r\n let yValIsAllNull = false;\r\n seriesData.forEach((item) => {\r\n yValIsAllNull = item.value.every((ele) => {\r\n return ele == 0;\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: !yValIsAllNull ? 16 : 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n //console.log(datas,\" datas\")\r\n return datas && datas.length > 0\r\n ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + Number(EChartsUtilsComm.getRound(datas[0].value[1], 0.001))\r\n : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineJson[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineJson[0].lineColor,\r\n },\r\n data: seriesData,\r\n markPoint: {\r\n data: pointData,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'], //去掉箭头\r\n itemStyle: {\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n width: 2,\r\n },\r\n },\r\n data: lineData,\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 沥青混合料-目标配合比设计-空隙率\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart12: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineJson = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n let xDataSource = xDataArr[0], // [3.5, 4, 4.5, 5, 5.5],\r\n yDataSource = yDataArr[0]; // [8.8, 5.9, 4.1, 3.3, 2.6];\r\n\r\n //原始数据\r\n let dxsJs = chartExtJson != null ? chartExtJson.dxsJs : 5,\r\n xData = [],\r\n yData = [];\r\n\r\n //处理原始数据为空的值,不然参与mathjs计算会报错\r\n xDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n xData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n xData.push(item);\r\n }\r\n }\r\n });\r\n yDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n yData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n yData.push(item);\r\n }\r\n }\r\n });\r\n\r\n //y轴没有任何数据的时候,不参与绘制图表\r\n if (yData.length == 0) {\r\n return;\r\n }\r\n\r\n //检查x轴的数据有多少个0,大于1个的时候,就不绘制图形\r\n let zeroCount = 0;\r\n xData.forEach((item) => {\r\n if (item == 0) {\r\n zeroCount++;\r\n }\r\n });\r\n // if (zeroCount > 1) {\r\n // \treturn;\r\n // }\r\n\r\n if (dxsJs >= yData.length) {\r\n dxsJs = yData.length - 1;\r\n }\r\n\r\n let xMin = Math.min(...xData),\r\n xMax = Math.max(...xData),\r\n yMin = Math.min(...yData),\r\n yMax = Math.max(...yData),\r\n /*\r\n\t\t\txAxisMax = 5.5,\r\n xAxisMin = 3.5,\r\n yAxisMax = 10,\r\n yAxisMin = 0,\r\n\t\t\t*/\r\n xAxisMax = xMax,\r\n xAxisMin = xMin,\r\n yAxisMax = Math.ceil(yMax + 2),\r\n yAxisMin = Math.floor(yMin - 2),\r\n seriesData = [],\r\n upperLimit = 5, //上限\r\n lowerLimit = 3, //下限\r\n showLine = true; //是否显示辅助线\r\n\r\n //获取单元格中的上限和下限\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSx != null && chartExtJson.lqhhlSx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlSx.row, chartExtJson.lqhhlSx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n upperLimit = curVal;\r\n }\r\n }\r\n if (chartExtJson.lqhhlXx != null && chartExtJson.lqhhlXx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlXx.row, chartExtJson.lqhhlXx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n lowerLimit = curVal;\r\n }\r\n }\r\n }\r\n\r\n if (upperLimit != null && upperLimit > yAxisMax) {\r\n yAxisMax = upperLimit + 2;\r\n }\r\n if (lowerLimit != null && lowerLimit > yAxisMax) {\r\n yAxisMin = lowerLimit - 2;\r\n }\r\n\r\n let points = [];\r\n xData.forEach((item, index) => {\r\n points.push([item, yData[index]]);\r\n });\r\n\r\n // 构造范德蒙德矩阵的函数\r\n function vandermondeMatrix(x, N) {\r\n const matrix = [];\r\n for (let i = 0; i < x.length; i++) {\r\n const row = [];\r\n for (let j = 0; j <= N; j++) {\r\n // 注意这里从0到N,包含N\r\n row.push(math.pow(x[i], j));\r\n }\r\n matrix.push(row);\r\n }\r\n return math.matrix(matrix);\r\n }\r\n\r\n // 构造原始的范德蒙德矩阵\r\n const vandermonde_matrix = vandermondeMatrix(xData, dxsJs); // 注意这里N=4,因为我们从0开始计数\r\n\r\n // 使用最小二乘法求解\r\n const A = vandermonde_matrix;\r\n const AT = math.transpose(A);\r\n const ATA = math.multiply(AT, A);\r\n const ATb = math.multiply(AT, math.matrix(yData));\r\n\r\n // 解线性方程组\r\n // const result = math.lusolve(ATA, ATb);\r\n // const coefficients = result.valueOf();\r\n let result: any = null,\r\n coefficients: any = [];\r\n try {\r\n result = math.lusolve(ATA, ATb);\r\n coefficients = result.valueOf();\r\n } catch (err) {\r\n for (let index = 0; index < xData.length; index++) {\r\n coefficients.push([0]);\r\n }\r\n console.log('无法解决该线性系统');\r\n }\r\n\r\n function funequation(x) {\r\n let y = 0;\r\n coefficients.forEach((item, index) => {\r\n //fx^0\r\n //fx^0+ax^1\r\n //fx^0+ax^1+bx^2\r\n //fx^0+ax^1+bx^2+cx^3\r\n //fx^0+x^1+x^2+x^3+x^4\r\n y += item * x ** index;\r\n });\r\n return y;\r\n }\r\n\r\n // console.log('计算公式:', coefficients);\r\n\r\n function lagrangeInterpolation(points, x) {\r\n let result = 0;\r\n for (let i = 0; i < points.length; i++) {\r\n let term = points[i][1];\r\n let xi = points[i][0];\r\n for (let j = 0; j < points.length; j++) {\r\n if (j !== i) {\r\n let xj = points[j][0];\r\n term *= (x - xj) / (xi - xj);\r\n }\r\n }\r\n result += term;\r\n }\r\n return result;\r\n }\r\n let arrX = [];\r\n let arrY = [];\r\n for (let i = xMin; i <= xMax; i += 0.01) {\r\n let temp = Number(EChartsUtilsComm.getRound(i, 0.01));\r\n //arrY.push(lagrangeInterpolation(points, temp));\r\n arrY.push(funequation(temp));\r\n arrX.push(temp);\r\n }\r\n\r\n let title = '', // config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //计算两条线段是否有交点\r\n function ifHaveIntersectionPoint(y1, y2, y3, y4) {\r\n if ((y1 >= y3 && y2 <= y4) || (y1 <= y3 && y2 >= y4)) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n //获取两点和香交线最接近的点\r\n function getIntersectionPoint(y1, y2, y) {\r\n if (Math.abs(y1 - y) > Math.abs(y2 - y)) {\r\n return 0;\r\n }\r\n return -1;\r\n }\r\n let upperIntersectionPoint = [],\r\n lowerIntersectionPoint = [];\r\n let upperIntersectionPointTrend = []; //上限交点趋势(向上相交(1) 还是向下相交(0))\r\n let lowerIntersectionPointTrend = []; //下限交点趋势\r\n arrX.forEach((item, index) => {\r\n if (xData.includes(item)) {\r\n seriesData.push({ value: [item, arrY[index]] });\r\n } else {\r\n seriesData.push({\r\n value: [item, arrY[index]],\r\n symbol: 'none',\r\n });\r\n }\r\n if (index > 0) {\r\n //上限交点\r\n if (upperLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], upperLimit, upperLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], upperLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n upperIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n upperIntersectionPointTrend.push(0);\r\n } else {\r\n upperIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n //下限交点\r\n if (lowerLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit, lowerLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n lowerIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n lowerIntersectionPointTrend.push(0);\r\n } else {\r\n lowerIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n let validX1 = xMin,\r\n validX2 = xMax;\r\n if (upperIntersectionPoint.length == 0 && lowerIntersectionPoint.length > 0) {\r\n //上限无交点,下限有交点\r\n if (lowerIntersectionPointTrend[0] == 0) {\r\n //下限向下相交\r\n validX1 = xMin;\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //下限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n if (lowerIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = lowerIntersectionPoint[1][0];\r\n }\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length == 0) {\r\n //上限有交点,下限无交点\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n if (upperIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = upperIntersectionPoint[1][0];\r\n }\r\n } else {\r\n //上限向上相交\r\n validX1 = xMin;\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length > 0) {\r\n //上下限都有交点,情况太多,我们只取中间\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //上限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n }\r\n\r\n // console.log('x范围:', validX1, validX2);\r\n //输出开始和结束范围\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlKs != null && chartExtJson.lqhhlKs != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlKs.row, chartExtJson.lqhhlKs.col, validX1);\r\n sheet.setValue(chartExtJson.lqhhlJs.row, chartExtJson.lqhhlJs.col, validX2);\r\n }\r\n }\r\n\r\n let lineData = [];\r\n let pointData = [];\r\n if (showLine) {\r\n if (upperIntersectionPoint.length > 0) {\r\n upperIntersectionPoint.forEach((item, index) => {\r\n lineData.push([\r\n {\r\n coord: [item[0], yAxisMin],\r\n lineStyle: {\r\n color: '#333', //上限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [item[0], upperLimit],\r\n },\r\n ]);\r\n });\r\n }\r\n if (lowerIntersectionPoint.length > 0) {\r\n lowerIntersectionPoint.forEach((item, index) => {\r\n lineData.push([\r\n {\r\n coord: [item[0], yAxisMin],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [item[0], lowerLimit],\r\n },\r\n ]);\r\n });\r\n }\r\n\r\n //上下线交点分别只有一个才求平均值\r\n if (upperIntersectionPoint.length == 1 && lowerIntersectionPoint.length == 1) {\r\n const avg = ((upperIntersectionPoint[0][0] + lowerIntersectionPoint[0][0]) / 2).toFixed(2);\r\n const avgXIndex = arrX.findIndex((n) => n == avg);\r\n // console.log('输出:', avg, avgXIndex);\r\n //输出\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSc1 != null && chartExtJson.lqhhlSc1 != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlSc1.row, chartExtJson.lqhhlSc1.col, avg);\r\n }\r\n }\r\n lineData.push([\r\n {\r\n coord: [avg, yAxisMin],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [avg, arrY[avgXIndex]],\r\n },\r\n ]);\r\n pointData.push({\r\n xAxis: avg,\r\n yAxis: yAxisMin,\r\n symbolOffset: [0, 40],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n return 'a3';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n });\r\n }\r\n }\r\n\r\n if (upperLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, upperLimit],\r\n lineStyle: {\r\n color: '#333', //上限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, upperLimit],\r\n },\r\n ]);\r\n }\r\n\r\n if (lowerLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, lowerLimit],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, lowerLimit],\r\n },\r\n ]);\r\n }\r\n\r\n //判断数据是否为/\r\n let yValIsAllNull = false;\r\n seriesData.forEach((item) => {\r\n yValIsAllNull = item.value.every((ele) => {\r\n return ele == 0;\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: !yValIsAllNull ? 16 : 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n //console.log(datas,\" datas\")\r\n return datas && datas.length > 0\r\n ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + Number(EChartsUtilsComm.getRound(datas[0].value[1], 0.001))\r\n : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineJson[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineJson[0].lineColor,\r\n },\r\n data: seriesData,\r\n markPoint: {\r\n data: pointData,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'], //去掉箭头\r\n itemStyle: {\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n width: 2,\r\n },\r\n },\r\n data: lineData,\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 沥青混合料-目标配合比设计-流值\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart13: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineJson = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n let xDataSource = xDataArr[0], // [3.5, 4, 4.5, 5, 5.5],\r\n yDataSource = yDataArr[0]; // [2.2, 2.5, 2.9, 3.4, 4.2];\r\n\r\n //原始数据\r\n let dxsJs = chartExtJson != null ? chartExtJson.dxsJs : 5,\r\n xData = [],\r\n yData = [];\r\n\r\n //处理原始数据为空的值,不然参与mathjs计算会报错\r\n xDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n xData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n xData.push(item);\r\n }\r\n }\r\n });\r\n yDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n yData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n yData.push(item);\r\n }\r\n }\r\n });\r\n\r\n //y轴没有任何数据的时候,不参与绘制图表\r\n if (yData.length == 0) {\r\n return;\r\n }\r\n\r\n //检查x轴的数据有多少个0,大于1个的时候,就不绘制图形\r\n let zeroCount = 0;\r\n xData.forEach((item) => {\r\n if (item == 0) {\r\n zeroCount++;\r\n }\r\n });\r\n // if (zeroCount > 1) {\r\n // \treturn;\r\n // }\r\n\r\n if (dxsJs >= yData.length) {\r\n dxsJs = yData.length - 1;\r\n }\r\n\r\n let xMin = Math.min(...xData),\r\n xMax = Math.max(...xData),\r\n yMin = Math.min(...yData),\r\n yMax = Math.max(...yData),\r\n /*\r\n xAxisMax = 5.5,\r\n xAxisMin = 3.5,\r\n yAxisMax = 5,\r\n yAxisMin = 1,\r\n\t\t\t*/\r\n xAxisMax = xMax,\r\n xAxisMin = xMin,\r\n yAxisMax = Math.ceil(yMax + 1),\r\n yAxisMin = Math.floor(yMin - 1),\r\n seriesData = [],\r\n upperLimit = null, //上限\r\n lowerLimit = 2, //下限\r\n showLine = true; //是否显示辅助线\r\n\r\n //获取单元格中的上限和下限\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSx != null && chartExtJson.lqhhlSx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlSx.row, chartExtJson.lqhhlSx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n upperLimit = curVal;\r\n }\r\n }\r\n if (chartExtJson.lqhhlXx != null && chartExtJson.lqhhlXx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlXx.row, chartExtJson.lqhhlXx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n lowerLimit = curVal;\r\n }\r\n }\r\n }\r\n\r\n if (upperLimit != null && upperLimit > yAxisMax) {\r\n yAxisMax = upperLimit + 1;\r\n }\r\n if (lowerLimit != null && lowerLimit > yAxisMax) {\r\n yAxisMin = lowerLimit - 1;\r\n }\r\n\r\n let points = [];\r\n xData.forEach((item, index) => {\r\n points.push([item, yData[index]]);\r\n });\r\n\r\n // 构造范德蒙德矩阵的函数\r\n function vandermondeMatrix(x, N) {\r\n const matrix = [];\r\n for (let i = 0; i < x.length; i++) {\r\n const row = [];\r\n for (let j = 0; j <= N; j++) {\r\n // 注意这里从0到N,包含N\r\n row.push(math.pow(x[i], j));\r\n }\r\n matrix.push(row);\r\n }\r\n return math.matrix(matrix);\r\n }\r\n\r\n // 构造原始的范德蒙德矩阵\r\n const vandermonde_matrix = vandermondeMatrix(xData, dxsJs); // 注意这里N=4,因为我们从0开始计数\r\n\r\n // 使用最小二乘法求解\r\n const A = vandermonde_matrix;\r\n const AT = math.transpose(A);\r\n const ATA = math.multiply(AT, A);\r\n const ATb = math.multiply(AT, math.matrix(yData));\r\n\r\n // 解线性方程组\r\n // const result = math.lusolve(ATA, ATb);\r\n // const coefficients = result.valueOf();\r\n\r\n let result: any = null,\r\n coefficients: any = [];\r\n try {\r\n result = math.lusolve(ATA, ATb);\r\n coefficients = result.valueOf();\r\n } catch (err) {\r\n for (let index = 0; index < xData.length; index++) {\r\n coefficients.push([0]);\r\n }\r\n console.log('无法解决该线性系统');\r\n }\r\n\r\n function funequation(x) {\r\n let y = 0;\r\n coefficients.forEach((item, index) => {\r\n //fx^0\r\n //fx^0+ax^1\r\n //fx^0+ax^1+bx^2\r\n //fx^0+ax^1+bx^2+cx^3\r\n //fx^0+x^1+x^2+x^3+x^4\r\n y += item * x ** index;\r\n });\r\n return y;\r\n }\r\n\r\n // console.log('计算公式:', coefficients);\r\n\r\n function lagrangeInterpolation(points, x) {\r\n let result = 0;\r\n for (let i = 0; i < points.length; i++) {\r\n let term = points[i][1];\r\n let xi = points[i][0];\r\n for (let j = 0; j < points.length; j++) {\r\n if (j !== i) {\r\n let xj = points[j][0];\r\n term *= (x - xj) / (xi - xj);\r\n }\r\n }\r\n result += term;\r\n }\r\n return result;\r\n }\r\n let arrX = [];\r\n let arrY = [];\r\n for (let i = xMin; i <= xMax; i += 0.01) {\r\n let temp = Number(EChartsUtilsComm.getRound(i, 0.01));\r\n //arrY.push(lagrangeInterpolation(points, temp));\r\n arrY.push(funequation(temp));\r\n arrX.push(temp);\r\n }\r\n let max = Math.max(...arrY);\r\n\r\n // 找到最大值的索引\r\n let maxIndex = arrY.findIndex((value) => value === max);\r\n\r\n // console.log('最大点数据:', arrX[maxIndex], max);\r\n\r\n let title = '', // config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n arrX.forEach((item, index) => {\r\n if (xData.includes(item)) {\r\n seriesData.push({ value: [item, arrY[index]] });\r\n } else {\r\n seriesData.push({\r\n value: [item, arrY[index]],\r\n symbol: 'none',\r\n });\r\n }\r\n });\r\n\r\n //计算两条线段是否有交点\r\n function ifHaveIntersectionPoint(y1, y2, y3, y4) {\r\n if ((y1 >= y3 && y2 <= y4) || (y1 <= y3 && y2 >= y4)) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n //获取两点和香交线最接近的点\r\n function getIntersectionPoint(y1, y2, y) {\r\n if (Math.abs(y1 - y) > Math.abs(y2 - y)) {\r\n return 0;\r\n }\r\n return -1;\r\n }\r\n let upperIntersectionPoint = [],\r\n lowerIntersectionPoint = [];\r\n let upperIntersectionPointTrend = []; //上限交点趋势(向上相交(1) 还是向下相交(0))\r\n let lowerIntersectionPointTrend = []; //下限交点趋势\r\n arrX.forEach((item, index) => {\r\n if (index > 0) {\r\n //上限交点\r\n if (upperLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], upperLimit, upperLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], upperLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n upperIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n upperIntersectionPointTrend.push(0);\r\n } else {\r\n upperIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n //下限交点\r\n if (lowerLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit, lowerLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n lowerIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n lowerIntersectionPointTrend.push(0);\r\n } else {\r\n lowerIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n let validX1 = xMin,\r\n validX2 = xMax;\r\n if (upperIntersectionPoint.length == 0 && lowerIntersectionPoint.length > 0) {\r\n //上限无交点,下限有交点\r\n if (lowerIntersectionPointTrend[0] == 0) {\r\n //下限向下相交\r\n validX1 = xMin;\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //下限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n if (lowerIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = lowerIntersectionPoint[1][0];\r\n }\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length == 0) {\r\n //上限有交点,下限无交点\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n if (upperIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = upperIntersectionPoint[1][0];\r\n }\r\n } else {\r\n //上限向上相交\r\n validX1 = xMin;\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length > 0) {\r\n //上下限都有交点,情况太多,我们只取中间\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //上限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n }\r\n\r\n // console.log('x范围:', validX1, validX2);\r\n //输出开始和结束范围\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlKs != null && chartExtJson.lqhhlKs != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlKs.row, chartExtJson.lqhhlKs.col, validX1);\r\n sheet.setValue(chartExtJson.lqhhlJs.row, chartExtJson.lqhhlJs.col, validX2);\r\n }\r\n }\r\n\r\n let lineData = [];\r\n let pointData = [];\r\n if (showLine) {\r\n lineData = [];\r\n pointData = [];\r\n }\r\n\r\n if (upperLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, upperLimit],\r\n lineStyle: {\r\n color: '#333', //上限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, upperLimit],\r\n },\r\n ]);\r\n }\r\n\r\n if (lowerLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, lowerLimit],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, lowerLimit],\r\n },\r\n ]);\r\n }\r\n\r\n //判断数据是否为/\r\n let yValIsAllNull = false;\r\n seriesData.forEach((item) => {\r\n yValIsAllNull = item.value.every((ele) => {\r\n return ele == 0;\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: !yValIsAllNull ? 16 : 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n //console.log(datas,\" datas\")\r\n return datas && datas.length > 0\r\n ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + Number(EChartsUtilsComm.getRound(datas[0].value[1], 0.001))\r\n : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 25 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineJson[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineJson[0].lineColor,\r\n },\r\n data: seriesData,\r\n markPoint: {\r\n data: pointData,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'], //去掉箭头\r\n itemStyle: {\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n width: 2,\r\n },\r\n },\r\n data: lineData,\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 沥青混合料-目标配合比设计-矿料间隙率\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart14: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineJson = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n let xDataSource = xDataArr[0], // [3.5, 4, 4.5, 5, 5.5],\r\n yDataSource = yDataArr[0]; // [16.1, 15.2, 14.6, 14.8, 16];\r\n\r\n //原始数据\r\n let dxsJs = chartExtJson != null ? chartExtJson.dxsJs : 5,\r\n xData = [],\r\n yData = [];\r\n\r\n //处理原始数据为空的值,不然参与mathjs计算会报错\r\n xDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n xData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n xData.push(item);\r\n }\r\n }\r\n });\r\n yDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n yData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n yData.push(item);\r\n }\r\n }\r\n });\r\n\r\n //y轴没有任何数据的时候,不参与绘制图表\r\n if (yData.length == 0) {\r\n return;\r\n }\r\n\r\n //检查x轴的数据有多少个0,大于1个的时候,就不绘制图形\r\n let zeroCount = 0;\r\n xData.forEach((item) => {\r\n if (item == 0) {\r\n zeroCount++;\r\n }\r\n });\r\n // if (zeroCount > 1) {\r\n // \treturn;\r\n // }\r\n\r\n if (dxsJs >= yData.length) {\r\n dxsJs = yData.length - 1;\r\n }\r\n\r\n let xMin = Math.min(...xData),\r\n xMax = Math.max(...xData),\r\n yMin = Math.min(...yData),\r\n yMax = Math.max(...yData),\r\n /*\r\n\t\t\txAxisMax = 5.5,\r\n xAxisMin = 3.5,\r\n yAxisMax = 19.0,\r\n yAxisMin = 13.0,\r\n\t\t\t*/\r\n xAxisMax = xMax,\r\n xAxisMin = xMin,\r\n yAxisMax = Math.ceil(yMax + 1),\r\n yAxisMin = Math.floor(yMin - 1),\r\n seriesData = [],\r\n upperLimit = null, //上限\r\n lowerLimit = 13.5, //下限\r\n showLine = true; //是否显示辅助线\r\n\r\n //获取单元格中的上限和下限\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSx != null && chartExtJson.lqhhlSx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlSx.row, chartExtJson.lqhhlSx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n upperLimit = curVal;\r\n }\r\n }\r\n if (chartExtJson.lqhhlXx != null && chartExtJson.lqhhlXx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlXx.row, chartExtJson.lqhhlXx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n lowerLimit = curVal;\r\n }\r\n }\r\n }\r\n\r\n if (upperLimit != null && upperLimit > yAxisMax) {\r\n yAxisMax = upperLimit + 1;\r\n }\r\n if (lowerLimit != null && lowerLimit > yAxisMax) {\r\n yAxisMin = lowerLimit - 1;\r\n }\r\n\r\n let points = [];\r\n xData.forEach((item, index) => {\r\n points.push([item, yData[index]]);\r\n });\r\n\r\n // 构造范德蒙德矩阵的函数\r\n function vandermondeMatrix(x, N) {\r\n const matrix = [];\r\n for (let i = 0; i < x.length; i++) {\r\n const row = [];\r\n for (let j = 0; j <= N; j++) {\r\n // 注意这里从0到N,包含N\r\n row.push(math.pow(x[i], j));\r\n }\r\n matrix.push(row);\r\n }\r\n return math.matrix(matrix);\r\n }\r\n\r\n // 构造原始的范德蒙德矩阵\r\n const vandermonde_matrix = vandermondeMatrix(xData, dxsJs); // 注意这里N=4,因为我们从0开始计数\r\n\r\n // 使用最小二乘法求解\r\n const A = vandermonde_matrix;\r\n const AT = math.transpose(A);\r\n const ATA = math.multiply(AT, A);\r\n const ATb = math.multiply(AT, math.matrix(yData));\r\n\r\n // 解线性方程组\r\n // const result = math.lusolve(ATA, ATb);\r\n // const coefficients = result.valueOf();\r\n\r\n let result: any = null,\r\n coefficients: any = [];\r\n try {\r\n result = math.lusolve(ATA, ATb);\r\n coefficients = result.valueOf();\r\n } catch (err) {\r\n for (let index = 0; index < xData.length; index++) {\r\n coefficients.push([0]);\r\n }\r\n console.log('无法解决该线性系统');\r\n }\r\n\r\n function funequation(x) {\r\n let y = 0;\r\n coefficients.forEach((item, index) => {\r\n //fx^0\r\n //fx^0+ax^1\r\n //fx^0+ax^1+bx^2\r\n //fx^0+ax^1+bx^2+cx^3\r\n //fx^0+x^1+x^2+x^3+x^4\r\n y += item * x ** index;\r\n });\r\n return y;\r\n }\r\n\r\n // console.log('计算公式:', coefficients);\r\n\r\n function lagrangeInterpolation(points, x) {\r\n let result = 0;\r\n for (let i = 0; i < points.length; i++) {\r\n let term = points[i][1];\r\n let xi = points[i][0];\r\n for (let j = 0; j < points.length; j++) {\r\n if (j !== i) {\r\n let xj = points[j][0];\r\n term *= (x - xj) / (xi - xj);\r\n }\r\n }\r\n result += term;\r\n }\r\n return result;\r\n }\r\n let arrX = [];\r\n let arrY = [];\r\n for (let i = xMin; i <= xMax; i += 0.01) {\r\n let temp = Number(EChartsUtilsComm.getRound(i, 0.01));\r\n //arrY.push(lagrangeInterpolation(points, temp));\r\n arrY.push(funequation(temp));\r\n arrX.push(temp);\r\n }\r\n let max = Math.max(...arrY);\r\n\r\n // 找到最大值的索引\r\n let maxIndex = arrY.findIndex((value) => value === max);\r\n\r\n // console.log('最大点数据:', arrX[maxIndex], max);\r\n\r\n let title = '', // config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n arrX.forEach((item, index) => {\r\n if (xData.includes(item)) {\r\n seriesData.push({ value: [item, arrY[index]] });\r\n } else {\r\n seriesData.push({\r\n value: [item, arrY[index]],\r\n symbol: 'none',\r\n });\r\n }\r\n });\r\n\r\n //计算两条线段是否有交点\r\n function ifHaveIntersectionPoint(y1, y2, y3, y4) {\r\n if ((y1 >= y3 && y2 <= y4) || (y1 <= y3 && y2 >= y4)) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n //获取两点和香交线最接近的点\r\n function getIntersectionPoint(y1, y2, y) {\r\n if (Math.abs(y1 - y) > Math.abs(y2 - y)) {\r\n return 0;\r\n }\r\n return -1;\r\n }\r\n let upperIntersectionPoint = [],\r\n lowerIntersectionPoint = [];\r\n let upperIntersectionPointTrend = []; //上限交点趋势(向上相交(1) 还是向下相交(0))\r\n let lowerIntersectionPointTrend = []; //下限交点趋势\r\n arrX.forEach((item, index) => {\r\n if (index > 0) {\r\n //上限交点\r\n if (upperLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], upperLimit, upperLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], upperLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n upperIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n upperIntersectionPointTrend.push(0);\r\n } else {\r\n upperIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n //下限交点\r\n if (lowerLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit, lowerLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n lowerIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n lowerIntersectionPointTrend.push(0);\r\n } else {\r\n lowerIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n let validX1 = xMin,\r\n validX2 = xMax;\r\n if (upperIntersectionPoint.length == 0 && lowerIntersectionPoint.length > 0) {\r\n //上限无交点,下限有交点\r\n if (lowerIntersectionPointTrend[0] == 0) {\r\n //下限向下相交\r\n validX1 = xMin;\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //下限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n if (lowerIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = lowerIntersectionPoint[1][0];\r\n }\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length == 0) {\r\n //上限有交点,下限无交点\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n if (upperIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = upperIntersectionPoint[1][0];\r\n }\r\n } else {\r\n //上限向上相交\r\n validX1 = xMin;\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length > 0) {\r\n //上下限都有交点,情况太多,我们只取中间\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //上限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n }\r\n\r\n // console.log('x范围:', validX1, validX2);\r\n //输出开始和结束范围\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlKs != null && chartExtJson.lqhhlKs != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlKs.row, chartExtJson.lqhhlKs.col, validX1);\r\n sheet.setValue(chartExtJson.lqhhlJs.row, chartExtJson.lqhhlJs.col, validX2);\r\n }\r\n }\r\n\r\n let lineData = [];\r\n let pointData = [];\r\n if (showLine) {\r\n lineData = [];\r\n pointData = [];\r\n }\r\n\r\n if (upperLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, upperLimit],\r\n lineStyle: {\r\n color: '#333', //上限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, upperLimit],\r\n },\r\n ]);\r\n }\r\n\r\n if (lowerLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, lowerLimit],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, lowerLimit],\r\n },\r\n ]);\r\n }\r\n\r\n //判断数据是否为/\r\n let yValIsAllNull = false;\r\n seriesData.forEach((item) => {\r\n yValIsAllNull = item.value.every((ele) => {\r\n return ele == 0;\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: !yValIsAllNull ? 16 : 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n //console.log(datas,\" datas\")\r\n return datas && datas.length > 0\r\n ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + Number(EChartsUtilsComm.getRound(datas[0].value[1], 0.001))\r\n : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineJson[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineJson[0].lineColor,\r\n },\r\n data: seriesData,\r\n markPoint: {\r\n data: pointData,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'], //去掉箭头\r\n itemStyle: {\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n width: 2,\r\n },\r\n },\r\n data: lineData,\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 沥青混合料-目标配合比设计-有效沥青饱和度\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart15: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineJson = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n let xDataSource = xDataArr[0], // [3.5, 4, 4.5, 5, 5.5],\r\n yDataSource = yDataArr[0]; // [40.1, 59.8, 66.8, 74.5, 78.2];\r\n\r\n //原始数据\r\n let dxsJs = chartExtJson != null ? chartExtJson.dxsJs : 5,\r\n xData = [],\r\n yData = [];\r\n\r\n //处理原始数据为空的值,不然参与mathjs计算会报错\r\n xDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n xData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n xData.push(item);\r\n }\r\n }\r\n });\r\n yDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n yData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n yData.push(item);\r\n }\r\n }\r\n });\r\n\r\n //y轴没有任何数据的时候,不参与绘制图表\r\n if (yData.length == 0) {\r\n return;\r\n }\r\n\r\n //检查x轴的数据有多少个0,大于1个的时候,就不绘制图形\r\n let zeroCount = 0;\r\n xData.forEach((item) => {\r\n if (item == 0) {\r\n zeroCount++;\r\n }\r\n });\r\n // if (zeroCount > 1) {\r\n // \treturn;\r\n // }\r\n\r\n if (dxsJs >= yData.length) {\r\n dxsJs = yData.length - 1;\r\n }\r\n\r\n let xMin = Math.min(...xData),\r\n xMax = Math.max(...xData),\r\n yMin = Math.min(...yData),\r\n yMax = Math.max(...yData),\r\n /*\r\n\t\t\txAxisMax = 5.5,\r\n xAxisMin = 3.5,\r\n yAxisMax = 80,\r\n yAxisMin = 30,\r\n\t\t\t*/\r\n xAxisMax = xMax,\r\n xAxisMin = xMin,\r\n yAxisMax = Math.ceil(yMax + 10),\r\n yAxisMin = Math.floor(yMin - 10),\r\n seriesData = [],\r\n upperLimit = 75, //上限\r\n lowerLimit = 60, //下限\r\n showLine = true; //是否显示辅助线\r\n\r\n //获取单元格中的上限和下限\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSx != null && chartExtJson.lqhhlSx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlSx.row, chartExtJson.lqhhlSx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n upperLimit = curVal;\r\n }\r\n }\r\n if (chartExtJson.lqhhlXx != null && chartExtJson.lqhhlXx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlXx.row, chartExtJson.lqhhlXx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n lowerLimit = curVal;\r\n }\r\n }\r\n }\r\n\r\n if (upperLimit != null && upperLimit > yAxisMax) {\r\n yAxisMax = upperLimit + 10;\r\n }\r\n if (lowerLimit != null && lowerLimit > yAxisMax) {\r\n yAxisMin = lowerLimit - 10;\r\n }\r\n\r\n let points = [];\r\n xData.forEach((item, index) => {\r\n points.push([item, yData[index]]);\r\n });\r\n\r\n // 构造范德蒙德矩阵的函数\r\n function vandermondeMatrix(x, N) {\r\n const matrix = [];\r\n for (let i = 0; i < x.length; i++) {\r\n const row = [];\r\n for (let j = 0; j <= N; j++) {\r\n // 注意这里从0到N,包含N\r\n row.push(math.pow(x[i], j));\r\n }\r\n matrix.push(row);\r\n }\r\n return math.matrix(matrix);\r\n }\r\n\r\n // 构造原始的范德蒙德矩阵\r\n const vandermonde_matrix = vandermondeMatrix(xData, dxsJs); // 注意这里N=4,因为我们从0开始计数\r\n\r\n // 使用最小二乘法求解\r\n const A = vandermonde_matrix;\r\n const AT = math.transpose(A);\r\n const ATA = math.multiply(AT, A);\r\n const ATb = math.multiply(AT, math.matrix(yData));\r\n\r\n // 解线性方程组\r\n // const result = math.lusolve(ATA, ATb);\r\n // const coefficients = result.valueOf();\r\n\r\n let result: any = null,\r\n coefficients: any = [];\r\n try {\r\n result = math.lusolve(ATA, ATb);\r\n coefficients = result.valueOf();\r\n } catch (err) {\r\n for (let index = 0; index < xData.length; index++) {\r\n coefficients.push([0]);\r\n }\r\n console.log('无法解决该线性系统');\r\n }\r\n\r\n function funequation(x) {\r\n let y = 0;\r\n coefficients.forEach((item, index) => {\r\n //fx^0\r\n //fx^0+ax^1\r\n //fx^0+ax^1+bx^2\r\n //fx^0+ax^1+bx^2+cx^3\r\n //fx^0+x^1+x^2+x^3+x^4\r\n y += item * x ** index;\r\n });\r\n return y;\r\n }\r\n\r\n // console.log('计算公式:', coefficients);\r\n\r\n function lagrangeInterpolation(points, x) {\r\n let result = 0;\r\n for (let i = 0; i < points.length; i++) {\r\n let term = points[i][1];\r\n let xi = points[i][0];\r\n for (let j = 0; j < points.length; j++) {\r\n if (j !== i) {\r\n let xj = points[j][0];\r\n term *= (x - xj) / (xi - xj);\r\n }\r\n }\r\n result += term;\r\n }\r\n return result;\r\n }\r\n let arrX = [];\r\n let arrY = [];\r\n for (let i = xMin; i <= xMax; i += 0.01) {\r\n let temp = Number(EChartsUtilsComm.getRound(i, 0.01));\r\n //arrY.push(lagrangeInterpolation(points, temp));\r\n arrY.push(funequation(temp));\r\n arrX.push(temp);\r\n }\r\n\r\n let title = '', // config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //计算两条线段是否有交点\r\n function ifHaveIntersectionPoint(y1, y2, y3, y4) {\r\n if ((y1 >= y3 && y2 <= y4) || (y1 <= y3 && y2 >= y4)) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n //获取两点和香交线最接近的点\r\n function getIntersectionPoint(y1, y2, y) {\r\n if (Math.abs(y1 - y) > Math.abs(y2 - y)) {\r\n return 0;\r\n }\r\n return -1;\r\n }\r\n let upperIntersectionPoint = [],\r\n lowerIntersectionPoint = [];\r\n let upperIntersectionPointTrend = []; //上限交点趋势(向上相交(1) 还是向下相交(0))\r\n let lowerIntersectionPointTrend = []; //下限交点趋势\r\n arrX.forEach((item, index) => {\r\n if (xData.includes(item)) {\r\n seriesData.push({ value: [item, arrY[index]] });\r\n } else {\r\n seriesData.push({\r\n value: [item, arrY[index]],\r\n symbol: 'none',\r\n });\r\n }\r\n if (index > 0) {\r\n //上限交点\r\n if (upperLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], upperLimit, upperLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], upperLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n upperIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n upperIntersectionPointTrend.push(0);\r\n } else {\r\n upperIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n //下限交点\r\n if (upperLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit, lowerLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n lowerIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n lowerIntersectionPointTrend.push(0);\r\n } else {\r\n lowerIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n }\r\n });\r\n let validX1 = xMin,\r\n validX2 = xMax;\r\n if (upperIntersectionPoint.length == 0 && lowerIntersectionPoint.length > 0) {\r\n //上限无交点,下限有交点\r\n if (lowerIntersectionPointTrend[0] == 0) {\r\n //下限向下相交\r\n validX1 = xMin;\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //下限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n if (lowerIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = lowerIntersectionPoint[1][0];\r\n }\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length == 0) {\r\n //上限有交点,下限无交点\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n if (upperIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = upperIntersectionPoint[1][0];\r\n }\r\n } else {\r\n //上限向上相交\r\n validX1 = xMin;\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length > 0) {\r\n //上下限都有交点,情况太多,我们只取中间\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //上限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n }\r\n\r\n // console.log('x范围:', validX1, validX2);\r\n //输出开始和结束范围\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlKs != null && chartExtJson.lqhhlKs != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlKs.row, chartExtJson.lqhhlKs.col, validX1);\r\n sheet.setValue(chartExtJson.lqhhlJs.row, chartExtJson.lqhhlJs.col, validX2);\r\n }\r\n }\r\n\r\n let lineData = [];\r\n let pointData = [];\r\n if (showLine) {\r\n if (upperIntersectionPoint.length > 0) {\r\n upperIntersectionPoint.forEach((item, index) => {\r\n lineData.push([\r\n {\r\n coord: [item[0], yAxisMin],\r\n lineStyle: {\r\n color: '#333', //上限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [item[0], upperLimit],\r\n },\r\n ]);\r\n });\r\n }\r\n if (lowerIntersectionPoint.length > 0) {\r\n lowerIntersectionPoint.forEach((item, index) => {\r\n lineData.push([\r\n {\r\n coord: [item[0], yAxisMin],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [item[0], lowerLimit],\r\n },\r\n ]);\r\n });\r\n }\r\n //上下线交点分别只有一个才求平均值\r\n if (upperIntersectionPoint.length == 1 && lowerIntersectionPoint.length == 1) {\r\n const avg = ((upperIntersectionPoint[0][0] + lowerIntersectionPoint[0][0]) / 2).toFixed(2);\r\n const avgXIndex = arrX.findIndex((n) => n == avg);\r\n // console.log('输出:', avg, avgXIndex);\r\n //输出\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSc1 != null && chartExtJson.lqhhlSc1 != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlSc1.row, chartExtJson.lqhhlSc1.col, avg);\r\n }\r\n }\r\n lineData.push([\r\n {\r\n coord: [avg, yAxisMin],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [avg, arrY[avgXIndex]],\r\n },\r\n ]);\r\n pointData.push({\r\n xAxis: avg,\r\n yAxis: yAxisMin,\r\n symbolOffset: [0, 40],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n return 'a4';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n });\r\n }\r\n }\r\n\r\n if (upperLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, upperLimit],\r\n lineStyle: {\r\n color: '#333', //上限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, upperLimit],\r\n },\r\n ]);\r\n }\r\n\r\n if (lowerLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, lowerLimit],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, lowerLimit],\r\n },\r\n ]);\r\n }\r\n\r\n //判断数据是否为/\r\n let yValIsAllNull = false;\r\n seriesData.forEach((item) => {\r\n yValIsAllNull = item.value.every((ele) => {\r\n return ele == 0;\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: !yValIsAllNull ? 16 : 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n //console.log(datas,\" datas\")\r\n return datas && datas.length > 0\r\n ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + Number(EChartsUtilsComm.getRound(datas[0].value[1], 0.001))\r\n : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineJson[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineJson[0].lineColor,\r\n },\r\n data: seriesData,\r\n markPoint: {\r\n data: pointData,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'], //去掉箭头\r\n itemStyle: {\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n width: 2,\r\n },\r\n },\r\n data: lineData,\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 沥青混合料-目标配合比设计-汇总\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart16: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineJson = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n // let lines = [\r\n // \t[3.5, 5.5],\r\n // \t[3.5, 5.5],\r\n // \t[4.21, 5.27],\r\n // \t[3.5, 5.5],\r\n // \t[3.5, 5.5],\r\n // \t[4.01, 5.03],\r\n // ],\r\n\r\n //原始数据\r\n let lines = [\r\n [\r\n sheet.getValue(chartExtJson.lqhhlHz[0].row, chartExtJson.lqhhlHz[0].col),\r\n sheet.getValue(chartExtJson.lqhhlHz[1].row, chartExtJson.lqhhlHz[1].col),\r\n ],\r\n [\r\n sheet.getValue(chartExtJson.lqhhlHz[2].row, chartExtJson.lqhhlHz[2].col),\r\n sheet.getValue(chartExtJson.lqhhlHz[3].row, chartExtJson.lqhhlHz[3].col),\r\n ],\r\n [\r\n sheet.getValue(chartExtJson.lqhhlHz[4].row, chartExtJson.lqhhlHz[4].col),\r\n sheet.getValue(chartExtJson.lqhhlHz[5].row, chartExtJson.lqhhlHz[5].col),\r\n ],\r\n [\r\n sheet.getValue(chartExtJson.lqhhlHz[6].row, chartExtJson.lqhhlHz[6].col),\r\n sheet.getValue(chartExtJson.lqhhlHz[7].row, chartExtJson.lqhhlHz[7].col),\r\n ],\r\n [\r\n sheet.getValue(chartExtJson.lqhhlHz[8].row, chartExtJson.lqhhlHz[8].col),\r\n sheet.getValue(chartExtJson.lqhhlHz[9].row, chartExtJson.lqhhlHz[9].col),\r\n ],\r\n [\r\n sheet.getValue(chartExtJson.lqhhlHz[10].row, chartExtJson.lqhhlHz[10].col),\r\n sheet.getValue(chartExtJson.lqhhlHz[11].row, chartExtJson.lqhhlHz[11].col),\r\n ],\r\n ],\r\n xData = xDataArr[0], // [3.5, 4, 4.5, 5, 5.5],\r\n xAxisMax = 5.5,\r\n xAxisMin = 3.5,\r\n yAxisMin = 0,\r\n yAxisMax = 6,\r\n yData = [0, 1, 2, 3, 4, 5, 6],\r\n yAxisData = ['VFA', 'VMA', '流值', '稳定度', '空隙率', '密度'],\r\n seriesData = [],\r\n showLine = true; //是否显示辅助线\r\n\r\n const title = 'OAC',\r\n xName = '油石比(%)',\r\n yName = 'VFA(%)',\r\n legendName = '图例1';\r\n let lineData = [];\r\n let pointData = [];\r\n let xMin = Math.max(...lines.map((item) => item[0]));\r\n let xMax = Math.min(...lines.map((item) => item[1]));\r\n\r\n lines.forEach((item, index) => {\r\n lineData.push([\r\n {\r\n coord: [item[0], lines.length - index],\r\n lineStyle: {\r\n color: lineJson[0].lineColor,\r\n type: 'solid',\r\n width: 2,\r\n },\r\n },\r\n {\r\n coord: [item[1], lines.length - index],\r\n },\r\n ]);\r\n });\r\n if (showLine && xMin <= xMax) {\r\n //最小\r\n lineData.push([\r\n {\r\n coord: [xMin, 0],\r\n lineStyle: {\r\n color: '#333',\r\n type: 'dashed',\r\n width: 2,\r\n },\r\n },\r\n {\r\n coord: [xMin, 6],\r\n },\r\n ]);\r\n //最大\r\n lineData.push([\r\n {\r\n coord: [xMax, 0],\r\n lineStyle: {\r\n color: '#333',\r\n type: 'dashed',\r\n width: 2,\r\n },\r\n },\r\n {\r\n coord: [xMax, 6],\r\n },\r\n ]);\r\n pointData = [\r\n {\r\n xAxis: xMin,\r\n yAxis: 0,\r\n symbolOffset: [0, 40],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n return 'OACmin';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n {\r\n xAxis: xMax,\r\n yAxis: 0,\r\n symbolOffset: [0, 40],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n return 'OACmax';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n ];\r\n }\r\n\r\n if (xMin <= xMax) {\r\n //平均值\r\n const avg = (xMin + xMax) / 2;\r\n lineData.push([\r\n {\r\n coord: [avg, 0],\r\n lineStyle: {\r\n color: '#333',\r\n type: 'dashed',\r\n width: 2,\r\n },\r\n },\r\n {\r\n coord: [avg, 6],\r\n },\r\n ]);\r\n pointData.push({\r\n xAxis: avg,\r\n yAxis: 0,\r\n symbolOffset: [0, 40],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n return 'OAC2';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n });\r\n }\r\n\r\n if (isNaN(xMin)) {\r\n xMin = 0;\r\n }\r\n if (isNaN(xMax)) {\r\n xMax = 0;\r\n }\r\n // console.log('输出:', xMin, xMax);\r\n //输出\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSc1 != null && chartExtJson.lqhhlSc1 != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlSc1.row, chartExtJson.lqhhlSc1.col, xMin);\r\n }\r\n if (chartExtJson.lqhhlSc2 != null && chartExtJson.lqhhlSc2 != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlSc2.row, chartExtJson.lqhhlSc2.col, xMax);\r\n }\r\n }\r\n\r\n //判断数据是否为/\r\n let yValIsAllNull = false;\r\n lines.forEach((item) => {\r\n yValIsAllNull = item.every((ele) => {\r\n return ele == '/';\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: 10,\r\n right: 10,\r\n bottom: !yValIsAllNull ? 16 : 20,\r\n containLabel: true,\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n axisLabel: {\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n if (data == 0) {\r\n return '';\r\n } else {\r\n return yAxisData[data - 1];\r\n }\r\n },\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n // data: seriesData,\r\n markPoint: {\r\n data: pointData,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'], //去掉箭头\r\n data: lineData,\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 击实\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart30: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n //设置是否选择校正jsIsJz的默认值\r\n if (chartExtJson != null && (chartExtJson.jsIsJz == null || chartExtJson.jsIsJz == undefined)) {\r\n chartExtJson.jsIsJz = true;\r\n }\r\n // console.log(config);\r\n\r\n let isTwoLine = xDataArr.length == 2;\r\n\r\n let xDataSource1 = xDataArr[0], // [1.6, 2.4, 3.5, 4.6, 5.3],\r\n xDataSource2 = isTwoLine ? xDataArr[1] : [], // [1.5, 2.4, 3.6, 4.3, 5.4],\r\n yDataSource1 = yDataArr[0], // [2.25, 2.29, 2.34, 2.29, 2.23],\r\n yDataSource2 = isTwoLine ? yDataArr[1] : []; // [2.27, 2.32, 2.36, 2.33, 2.26];\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n const lineFunc = (xDataSource, yDataSource, isShowMarkPoint, isShowMarkLine, isTwoLineData) => {\r\n //原始数据\r\n let dxsJs = chartExtJson != null ? chartExtJson.dxsJs : 5,\r\n xData = [],\r\n yData = [],\r\n seriesData = []; //处理原始数据为空的值,不然参与mathjs计算会报错\r\n\r\n //处理原始数据为空的值,不然参与mathjs计算会报错\r\n xDataSource.forEach((item, index) => {\r\n if (\r\n /^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item) &&\r\n item != 0 &&\r\n /^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(yDataSource[index]) &&\r\n yDataSource[index] != 0\r\n ) {\r\n xData.push(item);\r\n yData.push(yDataSource[index]);\r\n }\r\n });\r\n\r\n //y轴没有任何数据的时候,不参与绘制图表\r\n if (yData.length == 0) {\r\n return;\r\n }\r\n\r\n if (dxsJs >= yData.length) {\r\n dxsJs = yData.length - 1;\r\n }\r\n\r\n let xMin = Math.min(...xData),\r\n xMax = Math.max(...xData),\r\n yMin = Math.min(...yData),\r\n yMax = Math.max(...yData),\r\n xAxisMax = Math.ceil(xMax + 0.1),\r\n xAxisMin = Math.trunc(xMin - 0.1),\r\n yAxisMax = Number(EChartsUtilsComm.getRound(yMax + 0.02, 0.01)),\r\n yAxisMin = Number(EChartsUtilsComm.getRound(yMin - 0.02, 0.01));\r\n\r\n //如果界面设置了校正最佳含水率和最大干密度,则显示界面中的顶点坐标(此时就不显示辅助线了)\r\n let cellValJzZjhsl, cellValJzZdgmd;\r\n if (chartExtJson != null && chartExtJson.jsIsJz) {\r\n if (chartExtJson.jsZjhslJz != null && chartExtJson.jsZjhslJz != undefined) {\r\n cellValJzZjhsl = sheet.getValue(chartExtJson.jsZjhslJz.row, chartExtJson.jsZjhslJz.col);\r\n }\r\n if (chartExtJson.jsZdgmdJz != null && chartExtJson.jsZdgmdJz != undefined) {\r\n cellValJzZdgmd = sheet.getValue(chartExtJson.jsZdgmdJz.row, chartExtJson.jsZdgmdJz.col);\r\n }\r\n\r\n //如果界面输入的最大干密度大于了y轴最大值,则需要重新设置y轴的最大值\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(cellValJzZdgmd) && cellValJzZdgmd > yAxisMax) {\r\n yAxisMax = Number(EChartsUtilsComm.getRound(cellValJzZdgmd + 0.02, 0.01));\r\n }\r\n }\r\n\r\n let points = [];\r\n xData.forEach((item, index) => {\r\n points.push([item, yData[index]]);\r\n });\r\n\r\n // 构造范德蒙德矩阵的函数\r\n function vandermondeMatrix(x, N) {\r\n const matrix = [];\r\n for (let i = 0; i < x.length; i++) {\r\n const row = [];\r\n for (let j = 0; j <= N; j++) {\r\n // 注意这里从0到N,包含N\r\n row.push(math.pow(x[i], j));\r\n }\r\n matrix.push(row);\r\n }\r\n return math.matrix(matrix);\r\n }\r\n\r\n // 构造原始的范德蒙德矩阵\r\n const vandermonde_matrix = vandermondeMatrix(xData, dxsJs); // 注意这里N=4,因为我们从0开始计数\r\n\r\n // 使用最小二乘法求解\r\n const A = vandermonde_matrix;\r\n const AT = math.transpose(A);\r\n const ATA = math.multiply(AT, A);\r\n\r\n const ATb = math.multiply(AT, math.matrix(yData));\r\n\r\n // 解线性方程组\r\n let result: any = null,\r\n coefficients: any = [];\r\n try {\r\n result = math.lusolve(ATA, ATb);\r\n coefficients = result.valueOf();\r\n } catch (err) {\r\n for (let index = 0; index < xData.length; index++) {\r\n coefficients.push([0]);\r\n }\r\n // console.log('无法解决该线性系统');\r\n }\r\n // const result = math.lusolve(ATA, ATb);\r\n // const coefficients = result.valueOf();\r\n\r\n function funequation(x) {\r\n let y = 0;\r\n coefficients.forEach((item, index) => {\r\n //fx^0\r\n //fx^0+ax^1\r\n //fx^0+ax^1+bx^2\r\n //fx^0+ax^1+bx^2+cx^3\r\n //fx^0+x^1+x^2+x^3+x^4\r\n y += item * x ** index;\r\n });\r\n return y;\r\n }\r\n\r\n // console.log('计算公式:', coefficients);\r\n\r\n function lagrangeInterpolation(points, x) {\r\n let result = 0;\r\n for (let i = 0; i < points.length; i++) {\r\n let term = points[i][1];\r\n let xi = points[i][0];\r\n for (let j = 0; j < points.length; j++) {\r\n if (j !== i) {\r\n let xj = points[j][0];\r\n term *= (x - xj) / (xi - xj);\r\n }\r\n }\r\n result += term;\r\n }\r\n return result;\r\n }\r\n // x=[3.5, 4, 4.5, 5, 5.5,6 ],y= [2.262, 2.321, 2.319, 2.292, 2.285, 2.28]\r\n\r\n let arrX = [];\r\n let arrY = [];\r\n for (let i = xMin; i <= xMax; i += 0.01) {\r\n let temp = Number(EChartsUtilsComm.getRound(i, 0.01));\r\n //重新设置i,防止i丢失精度\r\n i = Number(temp);\r\n //arrY.push(lagrangeInterpolation(points, temp));\r\n arrY.push(funequation(temp));\r\n arrX.push(temp);\r\n }\r\n let max = Math.max(...arrY);\r\n\r\n // 找到最大值的索引\r\n let maxIndex = arrY.findIndex((value) => value === max);\r\n\r\n // console.log('最大点数据:', arrX[maxIndex], max);\r\n // console.log(chartExtJson);\r\n\r\n //默认输出精度\r\n let outJdZjhsl = 0.01,\r\n outJdZdgmd = 0.001;\r\n\r\n //顶点数据\r\n let outValZjhsl = 0,\r\n outValZdgmd = 0;\r\n\r\n //设置Sheet单元格的值(最佳含水率和最大干密度)\r\n if (chartExtJson != null) {\r\n // console.log(4444, chartExtJson.jsZjhsl.row, chartExtJson.jsZjhsl.col, arrX[maxIndex]);\r\n\r\n if (chartExtJson.jsZjhslJd != null && chartExtJson.jsZjhslJd != undefined) {\r\n outJdZjhsl = chartExtJson.jsZjhslJd;\r\n }\r\n if (chartExtJson.jsZdgmdJd != null && chartExtJson.jsZdgmdJd != undefined) {\r\n outJdZdgmd = chartExtJson.jsZdgmdJd;\r\n }\r\n\r\n if (arrX[maxIndex] == 0 && max == 0) {\r\n sheet.setValue(chartExtJson.jsZjhsl.row, chartExtJson.jsZjhsl.col, '/');\r\n sheet.setValue(chartExtJson.jsZdgmd.row, chartExtJson.jsZdgmd.col, '/');\r\n } else {\r\n outValZjhsl = EChartsUtilsComm.getRound(arrX[maxIndex], outJdZjhsl);\r\n outValZdgmd = EChartsUtilsComm.getRound(max, outJdZdgmd);\r\n\r\n sheet.setValue(chartExtJson.jsZjhsl.row, chartExtJson.jsZjhsl.col, outValZjhsl);\r\n sheet.setValue(chartExtJson.jsZdgmd.row, chartExtJson.jsZdgmd.col, outValZdgmd);\r\n }\r\n }\r\n\r\n arrX.forEach((item, index) => {\r\n if (xData.includes(item)) {\r\n seriesData.push({ value: [item, arrY[index]] });\r\n } else {\r\n seriesData.push({\r\n value: [item, arrY[index]],\r\n symbol: 'none',\r\n });\r\n }\r\n });\r\n\r\n //xData.forEach((item, index) => {\r\n //seriesData.push([item, yData[index]]);\r\n //});\r\n\r\n //计算峰值----目前没有公式 值写死的\r\n const peakvalue = [arrX[maxIndex], Number(EChartsUtilsComm.getRound(max, outJdZdgmd))],\r\n coordX = [peakvalue[0], yAxisMin],\r\n coordY = [xAxisMin, peakvalue[1]];\r\n\r\n let markPointObj = {\r\n data: [\r\n {\r\n xAxis: EChartsUtilsComm.getRound(peakvalue[0], outJdZjhsl),\r\n yAxis: EChartsUtilsComm.getRound(peakvalue[1], outJdZdgmd),\r\n symbolOffset: [0, 15],\r\n symbol: 'circle',\r\n symbolSize: 6,\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n if (Number(data.data.xAxis) == 0 && Number(data.data.yAxis) == 0) {\r\n return '';\r\n } else {\r\n return '( ' + data.data.xAxis + ',' + data.data.yAxis + ')';\r\n }\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n ],\r\n },\r\n markLineObj = {\r\n symbol: ['none', 'none'], //去掉箭头\r\n itemStyle: {\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n width: 2,\r\n },\r\n },\r\n data: [\r\n [\r\n {\r\n coord: coordX,\r\n lineStyle: {\r\n color: '#333', //X轴\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: peakvalue,\r\n },\r\n ],\r\n [\r\n {\r\n coord: coordY,\r\n lineStyle: {\r\n color: '#333', //y轴\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: peakvalue,\r\n },\r\n ],\r\n ],\r\n };\r\n\r\n //如果界面设置了校正最佳含水率和最大干密度,则显示界面中的顶点坐标(此时就不显示辅助线了)\r\n if (chartExtJson.jsIsJz && /^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(cellValJzZjhsl) && /^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(cellValJzZdgmd)) {\r\n markLineObj = null;\r\n markPointObj.data[0].label = null;\r\n markPointObj.data[0].symbolOffset = null;\r\n markPointObj.data[0].itemStyle.color = '#F56C6C';\r\n markPointObj.data[0].xAxis = cellValJzZjhsl;\r\n markPointObj.data[0].yAxis = cellValJzZdgmd;\r\n markLineObj = null;\r\n }\r\n\r\n let seriesDataObj = {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[isTwoLineData ? 1 : 0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n type: isTwoLineData ? 'dotted' : 'solid',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[isTwoLineData ? 1 : 0].lineColor,\r\n },\r\n data: seriesData,\r\n markPoint: isShowMarkPoint ? markPointObj : null,\r\n markLine: isShowMarkLine ? markLineObj : null,\r\n };\r\n\r\n return {\r\n xAxisMin: xAxisMin,\r\n xAxisMax: xAxisMax,\r\n yAxisMin: yAxisMin,\r\n yAxisMax: yAxisMax,\r\n xData: xData,\r\n seriesDataObj: seriesDataObj,\r\n maxPointData: [arrX[maxIndex], max],\r\n };\r\n };\r\n\r\n let xAxisMin = 0,\r\n xAxisMax = 0,\r\n yAxisMin = 0,\r\n yAxisMax = 0,\r\n xData = [],\r\n seriesData = [],\r\n maxPointDataX = 0,\r\n maxPointDataY = 0;\r\n\r\n let lineObj1 = lineFunc(xDataSource1, yDataSource1, !isTwoLine, !isTwoLine, false),\r\n lineObj2;\r\n if (isTwoLine) {\r\n lineObj2 = lineFunc(xDataSource2, yDataSource2, false, false, true);\r\n }\r\n\r\n //此处的作用是,有可能x和y轴的数据都为空,造成lineObj1为undefined,避免报错\r\n if (lineObj1 == undefined || lineObj1 == null) {\r\n return;\r\n }\r\n\r\n //一条线的时候\r\n if (!isTwoLine) {\r\n xAxisMin = lineObj1.xAxisMin;\r\n xAxisMax = lineObj1.xAxisMax;\r\n yAxisMin = lineObj1.yAxisMin;\r\n yAxisMax = lineObj1.yAxisMax;\r\n xData = lineObj1.xData;\r\n seriesData.push(lineObj1.seriesDataObj);\r\n }\r\n //2条线的时候\r\n else {\r\n if (lineObj2 == undefined || lineObj2 == null) {\r\n return;\r\n }\r\n\r\n xAxisMax = lineObj1.xAxisMax;\r\n if (lineObj2.xAxisMax > xAxisMax) {\r\n xAxisMax = lineObj2.xAxisMax;\r\n }\r\n xAxisMin = lineObj1.xAxisMin;\r\n if (lineObj2.xAxisMin < xAxisMin) {\r\n xAxisMin = lineObj2.xAxisMin;\r\n }\r\n yAxisMax = lineObj1.yAxisMax;\r\n if (lineObj2.yAxisMax > yAxisMax) {\r\n yAxisMax = lineObj2.yAxisMax;\r\n }\r\n yAxisMin = lineObj1.yAxisMin;\r\n if (lineObj2.yAxisMin < yAxisMin) {\r\n yAxisMin = lineObj2.yAxisMin;\r\n }\r\n\r\n lineObj1.xData.forEach((item) => {\r\n xData.push(item);\r\n });\r\n lineObj2.xData.forEach((item) => {\r\n xData.push(item);\r\n });\r\n\r\n seriesData.push(lineObj1.seriesDataObj);\r\n seriesData.push(lineObj2.seriesDataObj);\r\n\r\n maxPointDataX = (lineObj1.maxPointData[0] + lineObj2.maxPointData[0]) / 2;\r\n maxPointDataY = (lineObj1.maxPointData[1] + lineObj2.maxPointData[1]) / 2;\r\n\r\n // console.log(\r\n // \t\"两条线最大点的平均值:\",\r\n // \tmaxPointDataX,\r\n // \tmaxPointDataY\r\n // );\r\n\r\n //默认输出精度\r\n let outJdZjhsl = 0.01,\r\n outJdZdgmd = 0.001;\r\n\r\n //顶点数据\r\n let outValZjhsl = 0,\r\n outValZdgmd = 0;\r\n\r\n //设置Sheet单元格的值(最佳含水率和最大干密度)\r\n if (chartExtJson != null) {\r\n // console.log(4444, chartExtJson.jsZjhsl.row, chartExtJson.jsZjhsl.col, arrX[maxIndex]);\r\n\r\n if (chartExtJson.jsZjhslJd != null && chartExtJson.jsZjhslJd != undefined) {\r\n outJdZjhsl = chartExtJson.jsZjhslJd;\r\n }\r\n if (chartExtJson.jsZdgmdJd != null && chartExtJson.jsZdgmdJd != undefined) {\r\n outJdZdgmd = chartExtJson.jsZdgmdJd;\r\n }\r\n\r\n if (maxPointDataX == 0 && maxPointDataY == 0) {\r\n sheet.setValue(chartExtJson.jsZjhsl.row, chartExtJson.jsZjhsl.col, '/');\r\n sheet.setValue(chartExtJson.jsZdgmd.row, chartExtJson.jsZdgmd.col, '/');\r\n } else {\r\n outValZjhsl = EChartsUtilsComm.getRound(maxPointDataX, outJdZjhsl);\r\n outValZdgmd = EChartsUtilsComm.getRound(maxPointDataY, outJdZdgmd);\r\n\r\n sheet.setValue(chartExtJson.jsZjhsl.row, chartExtJson.jsZjhsl.col, outValZjhsl);\r\n sheet.setValue(chartExtJson.jsZdgmd.row, chartExtJson.jsZdgmd.col, outValZdgmd);\r\n }\r\n }\r\n }\r\n\r\n //判断数据是否为/,‘’,null,undefined\r\n let yValIsAllNull = false;\r\n seriesData.forEach((item) => {\r\n yValIsAllNull = item.data[0].value.every((ele) => {\r\n return ele == 0;\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n //console.log(datas,\" datas\")\r\n return datas && datas.length > 0\r\n ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + Number(EChartsUtilsComm.getRound(datas[0].value[1], 0.001))\r\n : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 40 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: seriesData,\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 筛分\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart50: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = '', //config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName;\r\n\r\n // x轴原始数据、y轴原始数据、y轴原始数据(上限)、y轴原始数据(下限)\r\n const xDataSourceOld = xDataArr[0],\r\n yDataSourceOld = yDataArr[0],\r\n yDataSourceSxOld = yDataArr[1],\r\n yDataSourceXxOld = yDataArr[2];\r\n const allData: any[] = [];\r\n xDataSourceOld.forEach((item, index) => {\r\n allData.push({\r\n x: item,\r\n y: yDataSourceOld[index],\r\n ySx: yDataSourceSxOld[index],\r\n yXx: yDataSourceXxOld[index],\r\n });\r\n });\r\n allData.sort(function (a, b) {\r\n return a.x - b.x;\r\n });\r\n\r\n const xDataSource: any[] = [],\r\n yDataSource: any[] = [],\r\n yDataSourceSx: any[] = [],\r\n yDataSourceXx: any[] = [];\r\n\r\n // 记录上限或下限中值为null的个数\r\n let sxValNullCount = 0;\r\n yDataSourceSxOld.forEach((item, index) => {\r\n if (item == null || item == '/') {\r\n sxValNullCount++;\r\n }\r\n });\r\n\r\n // 如果上限或下限值中的所有值都为null,则只展示筛分曲线的折线\r\n if (sxValNullCount == yDataSourceSxOld.length) {\r\n allData.forEach((item, index) => {\r\n xDataSource.push(item.x);\r\n yDataSource.push(item.y);\r\n yDataSourceSx.push(item.ySx);\r\n yDataSourceXx.push(item.yXx);\r\n });\r\n } else {\r\n // 只获取上限或下限中值不为null的点\r\n allData.forEach((item, index) => {\r\n if (item.ySx != null && item.ySx != '/' && item.yXx != null && item.yXx != '/') {\r\n xDataSource.push(item.x);\r\n yDataSource.push(item.y);\r\n yDataSourceSx.push(item.ySx);\r\n yDataSourceXx.push(item.yXx);\r\n }\r\n });\r\n }\r\n\r\n // x轴需要的数据(x轴原始数据的0.45次方,并修约0.01)、x轴需要的上限数据(x轴原始数据的0.45次方,并修约0.01)、x轴需要的下限数据(x轴原始数据的0.45次方,并修约0.01)、标记线需要的数据\r\n let xData: any[] = [],\r\n xDataSx: any[] = [],\r\n xDataXx: any[] = [],\r\n markLineData: any[] = [];\r\n\r\n // x和y轴的字体大小\r\n const xyFontSize = 10;\r\n\r\n // 组装数据\r\n xDataSource.forEach((item, index) => {\r\n // 得到x轴原始数据的0.45次方值,并修约0.001\r\n const val045 = Number(EChartsUtilsComm.getRound(item ** 0.45, 0.001));\r\n\r\n xData.push([val045, yDataSource[index]]);\r\n markLineData.push({\r\n name: item + '',\r\n xAxis: val045,\r\n label: {\r\n show: xDataSource.length >= 6 && index % 2 != 0 && index < 6 ? false : true, // 控制x轴的名称某些点是否显示,避免重叠的情况\r\n fontSize: xyFontSize,\r\n },\r\n });\r\n\r\n xDataSx.push([val045, yDataSourceSx[index]]);\r\n xDataXx.push([val045, yDataSourceXx[index]]);\r\n });\r\n\r\n /**\r\n * 获取series需要的3条线配置\r\n * @param type 线类型(1:筛分曲线、2:上限、3:下限)\r\n * @param data 对应的坐标点数据\r\n */\r\n const getLineObj = (type, data) => {\r\n const name = type == 1 ? '筛分曲线' : type == 2 ? '上限' : '下限';\r\n const symbol = type == 1 ? 'rect' : type == 2 ? 'triangle' : 'circle';\r\n const lineType = type == 1 ? 'solid' : type == 2 ? 'dotted' : [10, 5];\r\n const color = type == 1 ? lineData[0].lineColor : type == 2 ? lineData[1].lineColor : lineData[2].lineColor; //type == 1 ? '#F56C6C' : type == 2 ? '#409EFF' : '#000';\r\n\r\n let obj = {\r\n name: name,\r\n type: 'line',\r\n smooth: true, // 平滑的线条\r\n // 设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: symbol,\r\n symbolSize: 5,\r\n z: 10, // 控制曲线的浮动层级,避免在markLine下方被遮住\r\n // 线条的颜色\r\n lineStyle: {\r\n color: color,\r\n // 线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n type: lineType,\r\n },\r\n // 线条上数据点的颜色\r\n itemStyle: {\r\n color: color,\r\n },\r\n data: data,\r\n connectNulls: true, // 是否连接空数据\r\n markLine: {\r\n symbol: '', // 取消箭头\r\n silent: true, // 取消鼠标hover事件\r\n label: {\r\n // 标线的文本,模拟x轴显示的内容\r\n position: 'start', // 改变label位置\r\n //rotate: 45, // 设置文字旋转度数(注意:ECharts官网文档居然没有rotate这个属性的说明)\r\n // backgroundColor:'#fff'\r\n // color:'#f00',// 文字颜色\r\n formatter: (data) => {\r\n return data.name;\r\n },\r\n },\r\n lineStyle: { color: '#e0e6f1', type: 'solid' },\r\n data: markLineData,\r\n },\r\n };\r\n\r\n return obj;\r\n };\r\n\r\n // 验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item[1] == null || item[1] == undefined || item[1] == '/') {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n }\r\n if (\r\n yDataSourceSxOld.some((item) => item != null && item != undefined && item != '/') ||\r\n yDataSourceXxOld.some((item) => item != null && item != undefined && item != '/')\r\n ) {\r\n yValIsAllNull = false;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,// 是否显示外边框线\r\n // borderColor: '#f00',// 外边框线颜色\r\n top: 20,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 35,\r\n containLabel: true,\r\n },\r\n // 提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n if (datas && datas[0].data.length > 1) {\r\n let xObj = markLineData.filter((item) => item.xAxis == datas[0].data[0]);\r\n\r\n return datas[0].seriesName + '(' + xObj[0].name + ')' + ':' + datas[0].data[1];\r\n } else {\r\n return datas[0].data;\r\n }\r\n },\r\n },\r\n // 顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 5,\r\n textStyle: {\r\n fontSize: 18,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n // 图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n left: 'center',\r\n data: ['筛分曲线', '上限', '下限'],\r\n selected: {\r\n 筛分曲线: true, // 显示\r\n 上限: true, // 显示\r\n 下限: true, // 显示\r\n },\r\n selectedMode: 'multiple', // 用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n axisTick: { show: false }, // 隐藏刻度线\r\n axisLabel: { show: false }, // 隐藏刻度值\r\n // 网格线,参考文档:https://echarts.apache.org/zh/option.html#xAxis.splitLine\r\n splitLine: {\r\n show: false, // 隐藏分割线\r\n },\r\n min: xData.length > 0 ? (xData[0][0] > 0.2 ? xData[0][0] - 0.2 : 0) : null, //控制x轴的最小值\r\n max: xData.length > 0 ? xData[xData.length - 1][0] + 0.1 : null,\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', // '#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n splitNumber: 10, // 设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLabel: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n ],\r\n series: [getLineObj(1, xData), getLineObj(2, xDataSx), getLineObj(3, xDataXx)],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 界限含水率\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart70: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n //此图形排除了图形数据不正确的情况,如果数据不对,则直接返回{}\r\n if (\r\n xDataArr[0].some((item) => item == null || item == '' || item == undefined) ||\r\n yDataArr[0].some((item) => item == null || item == '' || item == undefined)\r\n ) {\r\n return {};\r\n }\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n let xData = xDataArr[0], // [22.9, 32.4, 36.9],\r\n yData = yDataArr[0], // [2.2, 11.6, 19.8],\r\n ztzl = 100, //锥体质量(g),100或76\r\n cllx = '砂类土', //材料类型,砂类土或细粒土\r\n logx = [], // c,b,a\r\n logy = [];\r\n\r\n //获取锥体质量和材料类型\r\n if (chartExtJson != null) {\r\n let curZtzl = sheet.getValue(chartExtJson.jxhslZtzl.row, chartExtJson.jxhslZtzl.col),\r\n curCllx = sheet.getValue(chartExtJson.jxhslCllx.row, chartExtJson.jxhslCllx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curZtzl)) {\r\n curZtzl = Number(curZtzl);\r\n if (curZtzl == 100 || curZtzl == 76) {\r\n ztzl = curZtzl;\r\n }\r\n }\r\n if (curCllx == '砂类土' || curCllx == '细粒土') {\r\n cllx = curCllx;\r\n }\r\n }\r\n\r\n // console.log(ztzl, cllx);\r\n\r\n //先求对数\r\n for (const item1 of xData) {\r\n logx.push(Math.log(item1));\r\n }\r\n for (const item2 of yData) {\r\n logy.push(Math.log(item2));\r\n }\r\n //求ab / ac 斜率 公式k=y2-y1 / x2-x1\r\n let abk = (logy[2] - logy[1]) / (logx[2] - logx[1]);\r\n let ack = (logy[2] - logy[0]) / (logx[2] - logx[0]);\r\n\r\n const xMax = Math.max.apply(Math, xData),\r\n xMin = Math.min.apply(Math, xData),\r\n xAxisMax = xMax + 1,\r\n xAxisMin = xMin - 0.3,\r\n yMax = Math.max.apply(Math, yData),\r\n yMin = Math.min.apply(Math, yData),\r\n yAxisMax = yMax + 1,\r\n yAxisMin = yMin - 2,\r\n dropName = ['C', 'B', 'A'],\r\n seriesData = [];\r\n\r\n xData.forEach((item, index) => {\r\n seriesData.push([item, yData[index], dropName[index]]);\r\n });\r\n\r\n //求ab / ac 延长线方法\r\n function getYOnLine(point1, point2, point3X) {\r\n const logX1 = Math.log(point1[0]);\r\n const logY1 = Math.log(point1[1]);\r\n const logX2 = Math.log(point2[0]);\r\n const logY2 = Math.log(point2[1]);\r\n const slope = (logY2 - logY1) / (logX2 - logX1);\r\n const logPoint3X = Math.log(point3X);\r\n const logY = logY1 + slope * (logPoint3X - logX1);\r\n return Math.exp(logY);\r\n }\r\n\r\n let point3X = 20;\r\n let abd3 = getYOnLine([xData[2], yData[2]], [xData[1], yData[1]], point3X);\r\n let zero_ab = [20, abd3];\r\n let acd3 = getYOnLine([xData[2], yData[2]], [xData[0], yData[0]], point3X);\r\n let zero_ac = [20, acd3];\r\n\r\n // console.log(zero_ab, 'zero_ab');\r\n // console.log(zero_ac, 'zero_ac');\r\n\r\n //第一次计算D-y值,代入A点的X坐标\r\n function HpCoordinates(wl) {\r\n let hp;\r\n if (cllx == '砂类土') {\r\n //砂类土\r\n hp = 29.6 - 1.22 * wl + 0.017 * wl * wl - 0.0000744 * wl * wl * wl;\r\n } else {\r\n //细粒土\r\n hp = wl / (0.524 * wl - 7.606);\r\n }\r\n return hp;\r\n }\r\n\r\n let coordX = [];\r\n let coordY = [];\r\n let point_hp = [];\r\n\r\n let Dy = HpCoordinates(xData[2]);\r\n let Dylog = Math.log(Dy);\r\n let hp0_xab = (abk * logx[2] - (logy[2] - Dylog)) / abk;\r\n let hp0_xac = (ack * logx[2] - (logy[2] - Dylog)) / ack;\r\n if (hp0_xab - hp0_xac >= 2) {\r\n //return '超差!';\r\n }\r\n let hp0_xcenter = Math.exp((hp0_xab + hp0_xac) / 2);\r\n let Dxlog = Math.log(hp0_xcenter);\r\n let adk = (logy[2] - Dylog) / (logx[2] - Dxlog); //AD 斜率\r\n\r\n //输出的hp、wl和wp\r\n let scHp, scWl, scWp;\r\n\r\n //判断锥数\r\n if (ztzl == 76) {\r\n //计算wl ad直线上y=17时,对应的x值\r\n let wly = Math.log(17);\r\n let wlx = (adk * logx[2] - (logy[2] - wly)) / adk;\r\n let wl = Math.exp(wlx);\r\n\r\n //计算WP:ad直线上y=2时,对应的x值\r\n let wpy = Math.log(2);\r\n let wpx = (adk * logx[2] - (logy[2] - wpy)) / adk;\r\n let wp = Math.exp(wpx);\r\n\r\n point_hp = [hp0_xcenter, Dy];\r\n coordX = [hp0_xcenter, yAxisMin];\r\n coordY = [xAxisMin, Dy];\r\n seriesData.push([hp0_xcenter, Dy, 'Hp']);\r\n\r\n scHp = Dy;\r\n scWl = wl;\r\n scWp = wp;\r\n // console.log('输出:', wp, wl, Dy);\r\n } else if (ztzl == 100) {\r\n //计算wl的值----先求AD斜率再代入y=20,求X (X即Wl的值)\r\n let wly = Math.log(20);\r\n let wlx = (adk * logx[2] - (logy[2] - wly)) / adk;\r\n let wl = Math.exp(wlx);\r\n\r\n //第二次计算hp值\r\n let hpy2 = HpCoordinates(wl);\r\n let hpylog2 = Math.log(hpy2);\r\n let hp0_xab2 = (abk * logx[2] - (logy[2] - hpylog2)) / abk;\r\n let hp0_xac2 = (ack * logx[2] - (logy[2] - hpylog2)) / ack;\r\n\r\n let hp0_xcenter2 = Math.exp((hp0_xab2 + hp0_xac2) / 2);\r\n let wp = hp0_xcenter2;\r\n\r\n point_hp = [hp0_xcenter2, hpy2];\r\n\r\n coordX = [hp0_xcenter2, yAxisMin];\r\n coordY = [xAxisMin, hpy2];\r\n seriesData.push([hp0_xcenter2, hpy2, 'Hp']);\r\n\r\n scHp = hpy2;\r\n scWl = wl;\r\n scWp = wp;\r\n // console.log('输出:', wp, wl, hpy2);\r\n }\r\n\r\n //判断是否是一个数字\r\n if (isNaN(scHp) || isNaN(scWl) || isNaN(scWp)) {\r\n scHp = 0;\r\n scWl = 0;\r\n scWp = 0;\r\n }\r\n\r\n //设置Sheet单元格的值(输出hp、wl和wp)\r\n if (chartExtJson != null) {\r\n //默认输出精度\r\n let outJdHp = 0.01,\r\n outJdWl = 0.01,\r\n outJdWp = 0.01;\r\n if (chartExtJson.jxhslScHpJd != null && chartExtJson.jxhslScHpJd != undefined) {\r\n outJdHp = chartExtJson.jxhslScHpJd;\r\n }\r\n if (chartExtJson.jxhslScWlJd != null && chartExtJson.jxhslScWlJd != undefined) {\r\n outJdWl = chartExtJson.jxhslScWlJd;\r\n }\r\n if (chartExtJson.jxhslScWpJd != null && chartExtJson.jxhslScWpJd != undefined) {\r\n outJdWp = chartExtJson.jxhslScWpJd;\r\n }\r\n\r\n if (chartExtJson.jxhslScHp != null && chartExtJson.jxhslScHp != undefined) {\r\n if (scHp == 0) {\r\n sheet.setValue(chartExtJson.jxhslScHp.row, chartExtJson.jxhslScHp.col, '/');\r\n } else {\r\n sheet.setValue(chartExtJson.jxhslScHp.row, chartExtJson.jxhslScHp.col, EChartsUtilsComm.getRound(scHp, outJdHp));\r\n }\r\n }\r\n if (chartExtJson.jxhslScWl != null && chartExtJson.jxhslScWl != undefined) {\r\n if (scWl == 0) {\r\n sheet.setValue(chartExtJson.jxhslScWl.row, chartExtJson.jxhslScWl.col, '/');\r\n } else {\r\n sheet.setValue(chartExtJson.jxhslScWl.row, chartExtJson.jxhslScWl.col, EChartsUtilsComm.getRound(scWl, outJdWl));\r\n }\r\n }\r\n if (chartExtJson.jxhslScWp != null && chartExtJson.jxhslScWp != undefined) {\r\n if (scWp == 0) {\r\n sheet.setValue(chartExtJson.jxhslScWp.row, chartExtJson.jxhslScWp.col, '/');\r\n } else {\r\n sheet.setValue(chartExtJson.jxhslScWp.row, chartExtJson.jxhslScWp.col, EChartsUtilsComm.getRound(scWp, outJdWp));\r\n }\r\n }\r\n }\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item[1] == null || item[1] == undefined || item[1] == '/') {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n }\r\n if (\r\n yData.some((item) => item != null && item != undefined && item != '/') ||\r\n yData.some((item) => item != null && item != undefined && item != '/')\r\n ) {\r\n yValIsAllNull = false;\r\n }\r\n let option = {\r\n grid: {\r\n top: 20,\r\n left: !yValIsAllNull ? 50 : 25,\r\n right: 10,\r\n bottom: 35,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + datas[0].value[1] : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'log',\r\n min: xAxisMin,\r\n max: xAxisMax,\r\n interval: 0,\r\n axisTick: {\r\n show: false,\r\n alignWithLabel: true,\r\n },\r\n splitLine: {\r\n show: false,\r\n },\r\n axisLabel: {\r\n show: false,\r\n },\r\n },\r\n yAxis: {\r\n type: 'log',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n min: yAxisMin,\r\n max: yAxisMax,\r\n interval: 0,\r\n axisTick: {\r\n show: false,\r\n alignWithLabel: true,\r\n },\r\n splitLine: {\r\n show: false,\r\n },\r\n axisLabel: {\r\n show: false,\r\n },\r\n },\r\n series: [\r\n {\r\n name: legendName,\r\n data: seriesData,\r\n type: 'scatter',\r\n symbol: 'circle',\r\n smooth: false,\r\n symbolSize: 6,\r\n label: {\r\n show: true,\r\n formatter: function (param) {\r\n return param.data[2];\r\n },\r\n position: 'right',\r\n minMargin: 2,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'],\r\n silent: true,\r\n label: {\r\n show: true,\r\n position: 'start',\r\n color: '#000000',\r\n },\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n },\r\n data: [\r\n { xAxis: seriesData[0][0] },\r\n { xAxis: seriesData[1][0] },\r\n { xAxis: seriesData[2][0] },\r\n { yAxis: seriesData[0][1] },\r\n { yAxis: seriesData[1][1] },\r\n { yAxis: seriesData[2][1] },\r\n [\r\n {\r\n coord: coordX,\r\n lineStyle: {\r\n color: '#333',\r\n type: 'dashed',\r\n },\r\n },\r\n { coord: point_hp }, //Hp---x\r\n ],\r\n [\r\n {\r\n coord: coordY,\r\n lineStyle: {\r\n color: '#333',\r\n type: 'dashed', //dashed dotted\r\n },\r\n },\r\n { coord: point_hp }, //Hp----y\r\n ],\r\n ],\r\n },\r\n },\r\n {\r\n //a-b连线\r\n type: 'line',\r\n data: [\r\n [xData[2], yData[2]],\r\n [xData[1], yData[1]],\r\n ],\r\n lineStyle: {\r\n color: '#0000FF',\r\n type: 'solid',\r\n width: 1,\r\n },\r\n symbol: 'none',\r\n },\r\n {\r\n //a-b 延长线\r\n type: 'line',\r\n data: [\r\n [xData[1], yData[1]],\r\n [zero_ab[0], zero_ab[1]],\r\n ],\r\n lineStyle: {\r\n color: '#000000',\r\n type: 'dashed',\r\n width: 1,\r\n },\r\n symbol: 'none',\r\n },\r\n {\r\n //a-c连线\r\n type: 'line',\r\n data: [\r\n [xData[2], yData[2]],\r\n [xData[0], yData[0]],\r\n ],\r\n lineStyle: {\r\n color: '#0000FF',\r\n type: 'solid',\r\n width: 1,\r\n },\r\n symbol: 'none',\r\n },\r\n {\r\n //a-c 延长线\r\n type: 'line',\r\n data: [\r\n [xData[0], yData[0]],\r\n [zero_ac[0], zero_ac[1]],\r\n ],\r\n lineStyle: {\r\n color: '#000000',\r\n type: 'dashed',\r\n width: 1,\r\n },\r\n symbol: 'none',\r\n },\r\n {\r\n //a-Hp连线\r\n type: 'line',\r\n data: [[xData[2], yData[2]], point_hp],\r\n lineStyle: {\r\n color: '#0000FF',\r\n type: 'solid',\r\n width: 1,\r\n },\r\n symbol: 'none',\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 水泥、石灰标准曲线\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart90: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n //y轴原始数据\r\n let yDataSource = yDataArr[0]; // [1.2, 5.6, 10.8, 16, 20.8];\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x轴的数据\r\n let xData = xDataArr[0]; // [0, 2, 4, 6, 8];\r\n\r\n //重新处理x轴和y轴的数据,排除x轴后面为0的数据(因为有可能在单元格中,最后一个单元格的值可能没有填,这时候默认传的是0)\r\n let xDataCl = [],\r\n yDataSourceCl = [];\r\n for (let i = 0; i < xData.length; i++) {\r\n if (xData[i] != '/' && (i == 0 || (i > 0 && xData[i] != 0))) {\r\n xDataCl.push(xData[i]);\r\n yDataSourceCl.push(yDataSource[i]);\r\n } else if (i > 0 && xData[i] == 0) {\r\n break;\r\n }\r\n }\r\n xData = xDataCl;\r\n yDataSource = yDataSourceCl;\r\n\r\n //series的data数据、series的markPoint的data数据、series的markLine的data数据\r\n let seriesData = [],\r\n markPointData = [],\r\n markLineData = [...xData];\r\n\r\n //此目的是显示更多的x轴数据\r\n //假设x轴原始数据为[0, 2, 4, 6, 8],在这个数组中没有1、3、5等数据,此时就可以通过下面的方式进行增加\r\n /*\r\n\t\tfor (let i = 0; i < 20; i++) {\r\n\t\t\tif (!markLineData.some((item) => item == i)) {\r\n\t\t\t\tmarkLineData.push(i);\r\n\t\t\t}\r\n\t\t}\r\n\t\t*/\r\n\r\n //获取y轴趋势公式对象\r\n const gsS = EChartsUtilsComm.calcTrend(xData, yDataSource, xData[0]);\r\n\r\n //输出方程表达式\r\n if (chartExtJson != null) {\r\n if (chartExtJson.jxhslSnShScfc != null && chartExtJson.jxhslSnShScfc != undefined) {\r\n // console.log('输出公式:',`Y=${getRound(gsS.xl,0.0001)}X+${getRound(gsS.jj,0.0001)}`)\r\n if (gsS.xl == '' || gsS.jj == '') {\r\n sheet.setValue(chartExtJson.jxhslSnShScfc.row, chartExtJson.jxhslSnShScfc.col, '/');\r\n } else {\r\n sheet.setValue(\r\n chartExtJson.jxhslSnShScfc.row,\r\n chartExtJson.jxhslSnShScfc.col,\r\n `Y=${EChartsUtilsComm.getRound(gsS.xl, 0.0001)}X+${EChartsUtilsComm.getRound(gsS.jj, 0.0001)}`\r\n );\r\n }\r\n }\r\n }\r\n\r\n let yDataCopy = [];\r\n //获取y轴原始数据对应的趋势数据\r\n xData.forEach((item, index) => {\r\n let curYData = Number(EChartsUtilsComm.getRound(eval(gsS.gs.replace('x', item + '')), 0.01));\r\n if (isNaN(curYData)) {\r\n curYData = 0;\r\n }\r\n\r\n seriesData.push([item, curYData]);\r\n yDataCopy.push(curYData);\r\n markPointData.push({\r\n xAxis: item,\r\n yAxis: yDataSource[index],\r\n symbol: 'circle',\r\n symbolSize: 6,\r\n });\r\n\r\n //console.log(curYData, \"curYData\")\r\n });\r\n\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item[1] == 0 || item[1] == null || item[1] == undefined) {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n }\r\n if (yDataCopy.some((item) => item != 0 || item[1] == null || item[1] == undefined)) {\r\n yValIsAllNull = false;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 22,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 35,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].value[0] + ':' + datas[0].value[1] : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n splitLine: { show: false }, // 隐藏分割线\r\n axisLabel: { show: false }, // 隐藏刻度值\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n opacity: 0,\r\n },\r\n data: seriesData,\r\n markPoint: {\r\n data: markPointData,\r\n },\r\n markLine: {\r\n symbol: false, //取消箭头\r\n silent: true, //取消鼠标hover事件\r\n label: {\r\n position: 'start', //改变label位置\r\n formatter: (obj) => obj.value, //格式化显示的x轴标签内容\r\n },\r\n lineStyle: { color: '#ddd', type: 'solid' },\r\n data: markLineData.map((val) => {\r\n return {\r\n xAxis: val,\r\n };\r\n }),\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 延迟时间-强度曲线\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart110: (\r\n config: EChartsUtilsConfigModel,\r\n xDataArr: Array<Array<any>>,\r\n yDataArr: Array<Array<any>>,\r\n xDataArrSource: Array<Array<any>>,\r\n yDataArrSource: Array<Array<any>>\r\n ) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n const xDataSource = xDataArrSource[0]; // ['0.0','1.0','2.0','3.0','4.0','5.0'];\r\n\r\n let xData = [];\r\n xDataSource.forEach((item, index) => {\r\n if (item == '/') {\r\n xData.push(item);\r\n } else {\r\n xData.push(Number(item));\r\n }\r\n });\r\n\r\n //y轴的数据\r\n let yData = yDataArr[0]; // [4.4,4.3,4.3,4.2,4.1,3.7];\r\n let seriesData = [];\r\n xData.forEach((item, index) => {\r\n if (item != '/' && item != undefined && item != null) {\r\n seriesData.push([item, yData[index]]);\r\n }\r\n });\r\n\r\n let yValIsAllNull = false;\r\n if (seriesData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: 25,\r\n right: 15,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'category', //设置x轴为对数坐标轴\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n axisLabel: {\r\n // 使用formatter格式化标签\r\n formatter: function (value) {\r\n let curXName = '';\r\n for (let i = 0; i < xData.length; i++) {\r\n if (xData[i] == value) {\r\n curXName = xDataSource[i];\r\n if (curXName == '/') {\r\n curXName = '';\r\n }\r\n break;\r\n }\r\n }\r\n\r\n return curXName;\r\n },\r\n },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: seriesData,\r\n },\r\n ],\r\n };\r\n return option;\r\n },\r\n /**\r\n * 颗粒组成(筛分法)\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart130: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n // console.log(config);\r\n // console.log(xDataArr);\r\n // console.log(yDataArr);\r\n\r\n //x和y轴的数据\r\n const xData = xDataArr[0], // [60, 40, 20, 10, 5, 2, 1, 0.5, 0.25, 0.075],\r\n yData = yDataArr[0]; // [100.0, 100.0, 88.3, 69.3, 46.7, 27.0, 19.7, 5.6, 0.5, 0.3];\r\n let xMin = 0.01,\r\n xMax = 200;\r\n\r\n let seriesData = [];\r\n xData.forEach((item, index) => {\r\n seriesData.push([item == '筛底' ? 0 : item, yData[index]]);\r\n });\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item[1] == null || item[1] == undefined || item[1] == '/') {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n }\r\n if (yData.some((item) => item != null && item != undefined && item != '/')) {\r\n yValIsAllNull = false;\r\n }\r\n\r\n if (yValIsAllNull) {\r\n xMin = null;\r\n xMax = null;\r\n }\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: 20,\r\n right: 15,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'log', //设置x轴为对数坐标轴\r\n logBase: 10, //可以设置对数轴的底数,默认为10\r\n inverse: true,\r\n min: xMin,\r\n max: xMax,\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: seriesData,\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 回弹模量 (承载板法)\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart150: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n const xData = xDataArr[0], // [25, 50, 100, 150, 200],\r\n yData = yDataArr[0]; // [0.72, 1.07, 1.87, 2.63, 3.48];\r\n\r\n let seriesData = [];\r\n xData.forEach((item, index) => {\r\n seriesData.push([item, yData[index]]);\r\n });\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item[1] == null || item[1] == undefined || item[1] == '/') {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n }\r\n if (yData.some((item) => item != null && item != undefined && item != '/')) {\r\n yValIsAllNull = false;\r\n }\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 55,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 10,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n top: 18,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n splitLine: { show: false }, // 隐藏分割线\r\n axisLabel: { show: false }, // 隐藏刻度值\r\n position: 'top', //设置x轴在顶部显示\r\n },\r\n yAxis: [\r\n //双y轴,目的是使用第二个y轴来配置字符L显示在y轴下方箭头的位置\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n inverse: true, //y轴坐标轴向下\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: seriesData,\r\n markLine: {\r\n symbol: false, //取消箭头\r\n silent: true, //取消鼠标hover事件\r\n label: {\r\n position: 'start', //改变label位置\r\n formatter: (obj) => obj.value, //格式化显示的x轴标签内容\r\n },\r\n lineStyle: { color: '#ddd', type: 'solid' },\r\n data: xData.map((val) => {\r\n return {\r\n xAxis: val,\r\n };\r\n }),\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 土的回弹模量 (强度仪法)\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart170: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n const xData = xDataArr[0], // [25, 50, 100, 150, 200],\r\n yData = yDataArr[0]; // [0.72, 1.07, 1.87, 2.63, 3.48];\r\n\r\n let seriesData = [];\r\n xData.forEach((item, index) => {\r\n seriesData.push([item, yData[index]]);\r\n });\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item[1] == null || item[1] == undefined || item[1] == '/') {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n }\r\n if (yData.some((item) => item != null && item != undefined && item != '/')) {\r\n yValIsAllNull = false;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 55,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 10,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n top: 18,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n splitLine: { show: false }, // 隐藏分割线\r\n axisLabel: { show: false }, // 隐藏刻度值\r\n position: 'top', //设置x轴在顶部显示\r\n },\r\n yAxis: [\r\n //双y轴,目的是使用第二个y轴来配置字符L显示在y轴下方箭头的位置\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n inverse: true, //y轴坐标轴向下\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: seriesData,\r\n markLine: {\r\n symbol: false, //取消箭头\r\n silent: true, //取消鼠标hover事件\r\n label: {\r\n position: 'start', //改变label位置\r\n formatter: (obj) => obj.value, //格式化显示的x轴标签内容\r\n },\r\n lineStyle: { color: '#ddd', type: 'solid' },\r\n data: xData.map((val) => {\r\n return {\r\n xAxis: val,\r\n };\r\n }),\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 28d抗压强度与胶水比关系\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart190: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = '', // config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n let xData = xDataArr[0], // [2.32, 2.5, 2.7],\r\n yData = yDataArr[0]; // [42.5, 47.1, 49.1];\r\n\r\n //处理数据\r\n xData = xData.filter((item) => item != null && item != undefined && item != '/' && (item._code == null || item._code == undefined));\r\n yData = yData.filter((item) => item != null && item != undefined && item != '/' && (item._code == null || item._code == undefined));\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item == null || item == undefined || item == '/') {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n xData = [];\r\n }\r\n if (yData.some((item) => item != null && item != undefined && item != '/')) {\r\n yValIsAllNull = false;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 18,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n axisLabel: {\r\n // 使用formatter格式化标签\r\n formatter: function (value) {\r\n if (value == '/') {\r\n return '';\r\n } else {\r\n return value;\r\n }\r\n },\r\n },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: yData,\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 混凝土拌合物含气量\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart210: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n //x和y轴的原始数据\r\n let xDataSource = xDataArr[0], // [0.093, 0.081, 0.068, 0.063, 0.057, 0.052, 0.049, 0.044, 0.041, 0.038, 0.036],\r\n yDataSource = yDataArr[0]; // [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10];\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //series需要的数据\r\n const seriesData = [];\r\n\r\n for (let i = xDataSource.length - 1; i >= 0; i--) {\r\n const item = xDataSource[i];\r\n\r\n if (item != null && item != undefined && item != '/' && (item._error == null || item._error == undefined)) {\r\n seriesData.push([item, yDataSource[i]]);\r\n }\r\n }\r\n\r\n //x和y轴的字体大小\r\n const xyFontSize = 10;\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xDataSource.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xDataSource.forEach((item) => {\r\n if (item == null || item == undefined || item == '/' || (item._error != null && item._error != undefined)) {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xDataSource.length) {\r\n yValIsAllNull = true;\r\n //xDataSource = [];\r\n }\r\n if (yDataSource.some((item) => item != null && item != undefined && item != '/')) {\r\n yValIsAllNull = false;\r\n }\r\n\r\n const getXline = () => {\r\n let arr = [];\r\n [0, 0.02, 0.04, 0.06, 0.08, 0.1].forEach((val) => {\r\n xDataSource.forEach((item) => {\r\n let obj: any = { xAxis: '' };\r\n\r\n if (item == '/') {\r\n obj.xAxis = '';\r\n arr.push(obj);\r\n } else {\r\n obj.xAxis = val;\r\n arr.push(obj);\r\n }\r\n });\r\n });\r\n\r\n //去重\r\n let uniqueData = arr.filter((item, index, self) => index === self.findIndex((t) => t.xAxis == item.xAxis));\r\n return nullCount == xDataSource.length ? [] : uniqueData;\r\n };\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: !yValIsAllNull && seriesData.length > 0 ? 30 : 25,\r\n right: 10,\r\n bottom: 40,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].value[0] + ':' + datas[0].value[1] : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n splitLine: { show: false }, // 隐藏分割线\r\n axisLabel: { show: false }, // 隐藏刻度值\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull && seriesData.length > 0 ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n axisLabel: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: seriesData,\r\n markLine: {\r\n symbol: false, //取消箭头\r\n silent: true, //取消鼠标hover事件\r\n label: {\r\n position: 'start', //改变label位置\r\n formatter: (obj) => obj.value, //格式化显示的x轴标签内容\r\n fontSize: xyFontSize,\r\n },\r\n lineStyle: { color: '#ddd', type: 'solid' },\r\n data: getXline(),\r\n // data: [0, 0.02, 0.04, 0.06, 0.08, 0.1].map((val) => {\r\n // return {\r\n // xAxis: val,\r\n // }\r\n // }),\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 混凝土拌合物凝结时间\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart230: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n /*\r\n\t\t\t此处需要注意的是,如果单元格A3=A1-A2,就需要将A3=TEXT(A1-A2, \"h\"\":\"\"m\")\r\n\r\n\t\t\tExcel中默认时间相减得到的是天为单位,因此此处使用了TEXT函数来格式化相减的时间差格式\r\n\r\n\t\t\t=TEXT(A1-A2, \"h\"\":\"\"m\")\r\n\t\t\t=INT(A1-A2) & \"天\" & TEXT(A1-A2, \"h\"\"小时\"\"m\"\"分\"\"\")\r\n\r\n\t\t*/\r\n\r\n //折线的数量\r\n let lineCount = xDataArr.length;\r\n\r\n //原始数据\r\n let xDataSource1 = [], // ['6:20', '6:50', '7:20', '7:50', '7:56', '8:26', '8:56', '9:26', '9:56', '10:11'],\r\n xDataSource2 = [], // ['6:27', '6:57', '7:32', '8:02', '8:05', '8:35', '9:05', '9:35', '10:05', '10:22'],\r\n xDataSource3 = [], // ['6:10', '6:40', '7:10', '7:40', '8:03', '8:13', '8:42', '9:12', '9:40', '10:12'],\r\n yDataSource1 = [], // [0.8, 1.2, 2.2, 3.4, 3.6, 7.8, 11.8, 16.6, 24.6, 28.2],\r\n yDataSource2 = [], // [0.8, 1.3, 2.4, 3.4, 3.5, 7.7, 12.2, 16.7, 25, 28.2],\r\n yDataSource3 = []; // [0.7, 1, 1.9, 3, 3.3, 3.5, 8.2, 13.8, 20.2, 28.2];\r\n\r\n //折线1\r\n xDataSource1 = EChartsUtilsComm.filterNullEmptyErrArray(xDataArr[0]); // ['6:20', '6:50', '7:20', '7:50', '7:56', '8:26', '8:56', '9:26', '9:56', '10:11'],\r\n yDataSource1 = EChartsUtilsComm.filterNullEmptyErrArray(yDataArr[0]); // [0.8, 1.2, 2.2, 3.4, 3.6, 7.8, 11.8, 16.6, 24.6, 28.2],\r\n\r\n //折线2\r\n if (lineCount == 2) {\r\n xDataSource2 = EChartsUtilsComm.filterNullEmptyErrArray(xDataArr[1]); // ['6:27', '6:57', '7:32', '8:02', '8:05', '8:35', '9:05', '9:35', '10:05', '10:22'],\r\n yDataSource2 = EChartsUtilsComm.filterNullEmptyErrArray(yDataArr[1]); // [0.8, 1.3, 2.4, 3.4, 3.5, 7.7, 12.2, 16.7, 25, 28.2],\r\n }\r\n //折线3\r\n if (lineCount == 3) {\r\n xDataSource2 = EChartsUtilsComm.filterNullEmptyErrArray(xDataArr[1]); // ['6:27', '6:57', '7:32', '8:02', '8:05', '8:35', '9:05', '9:35', '10:05', '10:22'],\r\n yDataSource2 = EChartsUtilsComm.filterNullEmptyErrArray(yDataArr[1]); // [0.8, 1.3, 2.4, 3.4, 3.5, 7.7, 12.2, 16.7, 25, 28.2],\r\n xDataSource3 = EChartsUtilsComm.filterNullEmptyErrArray(xDataArr[2]); // ['6:10', '6:40', '7:10', '7:40', '8:03', '8:13', '8:42', '9:12', '9:40', '10:12'],\r\n yDataSource3 = EChartsUtilsComm.filterNullEmptyErrArray(yDataArr[2]); // [0.7, 1, 1.9, 3, 3.3, 3.5, 8.2, 13.8, 20.2, 28.2];\r\n }\r\n\r\n //3条线的x轴数据\r\n let xData1 = [],\r\n xData2 = [],\r\n xData3 = [];\r\n\r\n //组装数据\r\n\r\n xDataSource1.forEach((item, index) => {\r\n //js的时间格式\r\n if (typeof item == 'object') {\r\n xData1.push(item.getHours() * 60 + item.getMinutes());\r\n }\r\n //数字\r\n else if (typeof item == 'number') {\r\n xData1.push(item);\r\n }\r\n //文本格式\r\n else {\r\n const curArr = item.split(':');\r\n const curItemMins = Number(curArr[0]) * 60 + Number(curArr[1]);\r\n xData1.push(curItemMins);\r\n }\r\n });\r\n\r\n xDataSource2.forEach((item, index) => {\r\n //js的时间格式\r\n if (typeof item == 'object') {\r\n xData2.push(item.getHours() * 60 + item.getMinutes());\r\n }\r\n //数字\r\n else if (typeof item == 'number') {\r\n xData2.push(item);\r\n }\r\n //文本格式\r\n else {\r\n const curArr = item.split(':');\r\n const curItemMins = Number(curArr[0]) * 60 + Number(curArr[1]);\r\n xData2.push(curItemMins);\r\n }\r\n });\r\n\r\n xDataSource3.forEach((item, index) => {\r\n //js的时间格式\r\n if (typeof item == 'object') {\r\n xData3.push(item.getHours() * 60 + item.getMinutes());\r\n }\r\n //数字\r\n else if (typeof item == 'number') {\r\n xData3.push(item);\r\n }\r\n //文本格式\r\n else {\r\n const curArr = item.split(':');\r\n const curItemMins = Number(curArr[0]) * 60 + Number(curArr[1]);\r\n xData3.push(curItemMins);\r\n }\r\n });\r\n\r\n //x轴数据前后增加一个点,y轴数据前后也增加一个点\r\n if (xDataSource1.length > 0) {\r\n xData1.push(xData1[xData1.length - 1] + 20);\r\n xData1.unshift(xData1[0] - 20);\r\n yDataSource1.push(null);\r\n yDataSource1.unshift(null);\r\n }\r\n\r\n if (lineCount == 2) {\r\n if (xDataSource2.length > 0) {\r\n xData2.push(xData2[xData2.length - 1] + 20);\r\n xData2.unshift(xData2[0] - 20);\r\n yDataSource2.push(null);\r\n yDataSource2.unshift(null);\r\n }\r\n }\r\n if (lineCount == 3) {\r\n if (xDataSource3.length == 0) {\r\n xData2.push(xData2[xData2.length - 1] + 20);\r\n xData2.unshift(xData2[0] - 20);\r\n yDataSource2.push(null);\r\n yDataSource2.unshift(null);\r\n xData3.push(xData3[xData3.length - 1] + 20);\r\n xData3.unshift(xData3[0] - 20);\r\n yDataSource3.push(null);\r\n yDataSource3.unshift(null);\r\n }\r\n }\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName;\r\n\r\n //获取xAxis需要的数据\r\n const getxAxisObj = (type, data) => {\r\n return {\r\n type: 'category',\r\n data: data,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n show: type == 1,\r\n splitLine: {\r\n show: true,\r\n },\r\n };\r\n };\r\n\r\n let xAxisData = [getxAxisObj(1, xData1)];\r\n if (lineCount == 2) {\r\n xAxisData.push(getxAxisObj(2, xData2));\r\n }\r\n if (lineCount == 3) {\r\n xAxisData.push(getxAxisObj(2, xData2));\r\n xAxisData.push(getxAxisObj(3, xData3));\r\n }\r\n\r\n //获取series需要的数据\r\n const getLineObj = (type, data) => {\r\n const name = type == 1 ? '第一组' : type == 2 ? '第二组' : '第三组';\r\n const symbol = type == 1 ? 'rect' : type == 2 ? 'triangle' : 'circle';\r\n const lineType = type == 1 ? 'solid' : type == 2 ? 'dotted' : [10, 5];\r\n const color =\r\n type == 1 && lineData.length >= 1\r\n ? lineData[0].lineColor\r\n : type == 2 && lineData.length >= 2\r\n ? lineData[1].lineColor\r\n : type == 3 && lineData.length >= 3\r\n ? lineData[2].lineColor\r\n : '#000';\r\n\r\n let obj = {\r\n name: name,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: symbol, //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: color,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n type: lineType,\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: color,\r\n },\r\n data: data,\r\n };\r\n\r\n return obj;\r\n };\r\n\r\n //series: [getLineObj(1, yDataSource1), getLineObj(2, yDataSource2), getLineObj(3, yDataSource3)],\r\n let seriesData = [getLineObj(1, yDataSource1)];\r\n if (lineCount == 2) {\r\n if (yDataSource2.length > 0) {\r\n seriesData.push(getLineObj(2, yDataSource2));\r\n }\r\n }\r\n if (lineCount == 3) {\r\n if (yDataSource2.length > 0) {\r\n seriesData.push(getLineObj(2, yDataSource2));\r\n }\r\n if (yDataSource3.length > 0) {\r\n seriesData.push(getLineObj(3, yDataSource3));\r\n }\r\n }\r\n\r\n let legendData = lineCount == 1 ? ['第一组'] : lineCount == 2 ? ['第一组', '第二组'] : ['第一组', '第二组', '第三组'],\r\n legendSelected: any =\r\n lineCount == 1 ? { 第一组: true } : lineCount == 2 ? { 第一组: true, 第二组: true } : { 第一组: true, 第二组: true, 第三组: true };\r\n\r\n //console.log(xData1,xData2,xData3,seriesData)\r\n let yValIsAllNull = false;\r\n let xValIsAllNull = false;\r\n let topmargin = 0;\r\n //为空不展示\r\n if (xDataSource1.length == 0) {\r\n xValIsAllNull = true;\r\n topmargin = 15;\r\n\r\n legendData = ['第二组', '第三组'];\r\n legendSelected = { 第一组: false, 第二组: true, 第三组: true };\r\n\r\n xAxisData = [];\r\n seriesData = [];\r\n\r\n xAxisData.push(getxAxisObj(1, xData2));\r\n xAxisData.push(getxAxisObj(3, xData3));\r\n seriesData.push(getLineObj(2, yDataSource2));\r\n seriesData.push(getLineObj(3, yDataSource3));\r\n\r\n if (xDataSource2.length == 0) {\r\n topmargin = 35;\r\n\r\n legendData = ['第三组'];\r\n legendSelected = { 第一组: false, 第二组: false, 第三组: true };\r\n\r\n xAxisData = [];\r\n seriesData = [];\r\n\r\n xAxisData.push(getxAxisObj(1, xData3));\r\n seriesData.push(getLineObj(3, yDataSource3));\r\n\r\n if (xDataSource3.length == 0) {\r\n topmargin = 0;\r\n\r\n yValIsAllNull = true;\r\n legendData = [];\r\n legendSelected = { 第一组: false, 第二组: false, 第三组: false };\r\n xAxisData = [];\r\n seriesData = [];\r\n xAxisData.push(getxAxisObj(1, []));\r\n seriesData.push(getLineObj(3, []));\r\n }\r\n }\r\n } else if (xDataSource2.length == 0) {\r\n topmargin = 15;\r\n xValIsAllNull = true;\r\n legendData = ['第一组', '第三组'];\r\n legendSelected = { 第一组: true, 第二组: false, 第三组: true };\r\n\r\n xAxisData = [];\r\n seriesData = [];\r\n\r\n xAxisData.push(getxAxisObj(1, xData1));\r\n xAxisData.push(getxAxisObj(3, xData3));\r\n\r\n seriesData.push(getLineObj(1, yDataSource1));\r\n seriesData.push(getLineObj(3, yDataSource3));\r\n\r\n if (xDataSource1.length == 0) {\r\n topmargin = 35;\r\n\r\n legendData = ['第三组'];\r\n legendSelected = { 第一组: false, 第二组: false, 第三组: true };\r\n\r\n xAxisData = [];\r\n seriesData = [];\r\n\r\n xAxisData.push(getxAxisObj(1, xData1));\r\n seriesData.push(getLineObj(3, yDataSource1));\r\n\r\n if (xDataSource3.length == 0) {\r\n topmargin = 0;\r\n\r\n yValIsAllNull = true;\r\n legendData = [];\r\n legendSelected = { 第一组: false, 第二组: false, 第三组: false };\r\n xAxisData = [];\r\n seriesData = [];\r\n xAxisData.push(getxAxisObj(1, []));\r\n seriesData.push(getLineObj(3, []));\r\n }\r\n }\r\n } else if (xDataSource3.length == 0) {\r\n topmargin = 15;\r\n xValIsAllNull = true;\r\n legendData = ['第一组', '第二组'];\r\n legendSelected = { 第一组: true, 第二组: true, 第三组: false };\r\n\r\n xAxisData = [];\r\n seriesData = [];\r\n xAxisData.push(getxAxisObj(1, xData1));\r\n xAxisData.push(getxAxisObj(2, xData2));\r\n seriesData.push(getLineObj(1, yDataSource1));\r\n seriesData.push(getLineObj(2, yDataSource2));\r\n\r\n if (xDataSource1.length == 0) {\r\n topmargin = 35;\r\n legendData = ['第二组'];\r\n legendSelected = { 第一组: false, 第二组: true, 第三组: false };\r\n\r\n xAxisData = [];\r\n seriesData = [];\r\n\r\n xAxisData.push(getxAxisObj(1, xData2));\r\n seriesData.push(getLineObj(2, yDataSource2));\r\n\r\n if (xDataSource2.length == 0) {\r\n topmargin = 0;\r\n yValIsAllNull = true;\r\n legendData = [];\r\n legendSelected = { 第一组: false, 第二组: false, 第三组: false };\r\n xAxisData = [];\r\n seriesData = [];\r\n xAxisData.push(getxAxisObj(1, []));\r\n seriesData.push(getLineObj(2, []));\r\n }\r\n }\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: !xValIsAllNull ? -5 : topmargin,\r\n left: 30,\r\n right: 10,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n left: 'center',\r\n top: 16,\r\n data: legendData,\r\n selected: legendSelected,\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: xAxisData,\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: seriesData,\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 颗粒组成(密度计法)\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart250: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n const xData = xDataArr[0], // [0.0316, 0.0224, 0.0115, 0.0075, 0.0058, 0.0033, 0.0031, 0.0024, 0.001, 0.0008],\r\n yData = yDataArr[0]; // [83.0, 78.8, 53.8, 42.6, 33.7, 27.8, 23.2, 19.2, 13.0, 7.7];\r\n\r\n let seriesData = [];\r\n xData.forEach((item, index) => {\r\n seriesData.push([item, yData[index]]);\r\n });\r\n\r\n let xmin = 0.001,\r\n xmax = 100;\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item == null || item == undefined || item == '/') {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n xmin = null;\r\n xmax = null;\r\n }\r\n if (yData.some((item) => item != null && item != undefined && item != '/')) {\r\n yValIsAllNull = false;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: 20,\r\n right: 15,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'log', //设置x轴为对数坐标轴\r\n logBase: 10, //可以设置对数轴的底数,默认为10\r\n inverse: true,\r\n min: xmin,\r\n max: xmax,\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: seriesData,\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 承载比(CBR)\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart270: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n // const xDataSource1 = xDataArr[0], // [36, 102, 316, 678, 917, 1177, 1396, 1478, 1620, 1651, 1753, 1789, 1855],\r\n // \txDataSource2 = xDataArr[1], // [56, 122, 357, 617, 958, 1223, 1376, 1493, 1631, 1682, 1783, 1824, 1885],\r\n // \txDataSource3 = xDataArr[2], // [66, 168, 443, 729, 994, 1213, 1411, 1529, 1651, 1722, 1783, 1824, 1890],\r\n // \tyDataSource1 = yDataArr[0], // [0.31, 0.51, 0.94, 1.47, 2.0, 2.48, 2.92, 3.41, 3.87, 4.37, 4.86, 5.36, 5.88],\r\n // \tyDataSource2 = yDataArr[1], // [0.26, 0.5, 1.01, 1.52, 2.02, 2.52, 2.98, 3.49, 3.99, 4.49, 4.98, 5.48, 5.98],\r\n // \tyDataSource3 = yDataArr[2]; // [0.32, 0.52, 1.01, 1.5, 1.99, 2.49, 2.98, 3.47, 3.96, 4.46, 4.95, 5.44, 5.93];\r\n\r\n let xDataSource1 = [],\r\n xDataSource2 = [],\r\n xDataSource3 = [],\r\n yDataSource1 = [],\r\n yDataSource2 = [],\r\n yDataSource3 = [];\r\n\r\n //排除原始数据为0的数据\r\n xDataArr[0].forEach((item, index) => {\r\n if (item != 0 && yDataArr[0][index] != 0) {\r\n xDataSource1.push(item);\r\n yDataSource1.push(yDataArr[0][index]);\r\n }\r\n });\r\n xDataArr[1].forEach((item, index) => {\r\n if (item != 0 && yDataArr[1][index] != 0) {\r\n xDataSource2.push(item);\r\n yDataSource2.push(yDataArr[1][index]);\r\n }\r\n });\r\n xDataArr[2].forEach((item, index) => {\r\n if (item != 0 && yDataArr[2][index] != 0) {\r\n xDataSource3.push(item);\r\n yDataSource3.push(yDataArr[2][index]);\r\n }\r\n });\r\n\r\n /**\r\n * 获取series需要的3条线配置\r\n * @param type 线类型(1:筛分曲线、2:上限、3:下限)\r\n * @param data 对应的坐标点数据\r\n */\r\n const getLineObj = (type, xData, yData) => {\r\n const name = `曲线${type}`;\r\n const symbol = type == 1 ? 'rect' : type == 2 ? 'triangle' : 'circle';\r\n const lineType = type == 1 ? 'solid' : type == 2 ? 'dotted' : [10, 5];\r\n const color = type == 1 ? lineData[0].lineColor : type == 2 ? lineData[1].lineColor : lineData[2].lineColor; //ttype == 1 ? '#F56C6C' : type == 2 ? '#409EFF' : '#000';\r\n\r\n const seriesData = [];\r\n xData.forEach((item, index) => {\r\n seriesData.push([item, yData[index]]);\r\n });\r\n\r\n return {\r\n name: name,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: symbol, //符号类型\r\n symbolSize: 5, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: color,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n type: lineType,\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: color,\r\n },\r\n data: seriesData,\r\n };\r\n };\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (\r\n xDataSource1.every((item) => item == '/') &&\r\n xDataSource2.every((item) => item == '/') &&\r\n xDataSource3.every((item) => item == '/') &&\r\n yDataSource1.every((item) => item == '/') &&\r\n yDataSource2.every((item) => item == '/') &&\r\n yDataSource3.every((item) => item == '/')\r\n ) {\r\n yValIsAllNull = true;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 35,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 20,\r\n bottom: 5,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + datas[0].value[1] : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n top: 16,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value', //category\r\n //data: xDataSource1,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n position: 'top', //设置x轴在顶部显示\r\n nameGap: 5, //坐标轴名称与轴线之间的距离\r\n nameLocation: 'end', //设置x轴显示的名称的位置在末端,注意:需要配置grid.right一起使用,不然可能会被遮住\r\n },\r\n yAxis: [\r\n //双y轴,目的是使用第二个y轴来配置字符L显示在y轴下方箭头的位置\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n inverse: true, //y轴坐标轴向下\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [getLineObj(1, xDataSource1, yDataSource1), getLineObj(2, xDataSource2, yDataSource2), getLineObj(3, xDataSource3, yDataSource3)],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 压实度-吸水量,膨胀率,CBR-279、280和281\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart279_280_281: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle, //压实度-吸水量关系曲线 压实度-膨胀率关系曲线 压实度-CBR关系曲线\r\n xName = config.chartXName, //压实度(%) 压实度(%) 压实度(%)\r\n yName = config.chartYName, //吸水量(g) 膨胀率(%) CBR(%)\r\n legendName = '图例1';\r\n\r\n //y轴最大最小数据加减数字\r\n let jjNum = config.chartType == 279 ? 5 : config.chartType == 280 ? 0.1 : 0.15;\r\n\r\n //x和y轴的数据\r\n let xData = xDataArr[0], // [90.3, 95.6, 99.5],\r\n yData = yDataArr[0], // [245, 206, 163],\r\n xAxisMin = Math.min(...xData),\r\n yAxisMin = Number(EChartsUtilsComm.getRound(Math.min(...yData) - jjNum, 0.001)),\r\n yAxisMax = Number(EChartsUtilsComm.getRound(Math.max(...yData) + jjNum, 0.001));\r\n //yData1 = [245, 206, 163],\r\n //yData2 = [3.49, 2.69, 2.34];\r\n //yData3 = [4, 4.7, 5.7];\r\n //修约:0.001 0.001 0.001\r\n //y最大最小加减数:5 0.1 0.15\r\n\r\n xAxisMin = Number(EChartsUtilsComm.getRound(xAxisMin - xAxisMin * 0.01, 0.001));\r\n\r\n let seriesData = [];\r\n xData.forEach((item, index) => {\r\n seriesData.push([item, yData[index]]);\r\n });\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (yData.every((item) => item == '/')) {\r\n yValIsAllNull = true;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: 20,\r\n right: 15,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value', //设置x轴为对数坐标轴\r\n min: xAxisMin,\r\n max: 100,\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n show: true, //y轴默认是不显示的\r\n },\r\n min: yAxisMin,\r\n max: yAxisMax,\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: seriesData,\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 承载比(CBR)(路强仪)\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart290: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n let xDataSource1 = xDataArr[0], // [36, 102, 316, 678, 917, 1177, 1396, 1478, 1620, 1651, 1753, 1789, 1855],\r\n xDataSource2 = xDataArr[0], // [56, 122, 357, 617, 958, 1223, 1376, 1493, 1631, 1682, 1783, 1824, 1885],\r\n xDataSource3 = xDataArr[0], // [66, 168, 443, 729, 994, 1213, 1411, 1529, 1651, 1722, 1783, 1824, 1890],\r\n yDataSource1 = yDataArr[0], // [0.31, 0.51, 0.94, 1.47, 2.0, 2.48, 2.92, 3.41, 3.87, 4.37, 4.86, 5.36, 5.88],\r\n yDataSource2 = yDataArr[1], // [0.26, 0.5, 1.01, 1.52, 2.02, 2.52, 2.98, 3.49, 3.99, 4.49, 4.98, 5.48, 5.98],\r\n yDataSource3 = yDataArr[2]; // [0.32, 0.52, 1.01, 1.5, 1.99, 2.49, 2.98, 3.47, 3.96, 4.46, 4.95, 5.44, 5.93];\r\n\r\n /**\r\n * 获取series需要的3条线配置\r\n * @param type 线类型(1:筛分曲线、2:上限、3:下限)\r\n * @param data 对应的坐标点数据\r\n */\r\n const getLineObj = (type, data) => {\r\n const name = `曲线${type}`;\r\n const symbol = type == 1 ? 'rect' : type == 2 ? 'triangle' : 'circle';\r\n const lineType = type == 1 ? 'solid' : type == 2 ? 'dotted' : [10, 5];\r\n const color = type == 1 ? lineData[0].lineColor : type == 2 ? lineData[1].lineColor : lineData[2].lineColor; //ttype == 1 ? '#F56C6C' : type == 2 ? '#409EFF' : '#000';\r\n\r\n return {\r\n name: name,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: symbol, //符号类型\r\n symbolSize: 5, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: color,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n type: lineType,\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: color,\r\n },\r\n data: data,\r\n };\r\n };\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (\r\n xDataSource1.every((item) => item == '/') &&\r\n xDataSource2.every((item) => item == '/') &&\r\n xDataSource3.every((item) => item == '/') &&\r\n yDataSource1.every((item) => item == '/') &&\r\n yDataSource2.every((item) => item == '/') &&\r\n yDataSource3.every((item) => item == '/')\r\n ) {\r\n yValIsAllNull = true;\r\n xDataSource1 = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 35,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 5,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n top: 16,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: xDataSource1,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n position: 'top', //设置x轴在顶部显示\r\n nameGap: 5, //坐标轴名称与轴线之间的距离\r\n nameLocation: 'end', //设置x轴显示的名称的位置在末端,注意:需要配置grid.right一起使用,不然可能会被遮住\r\n axisLabel: {\r\n // 使用formatter格式化标签\r\n formatter: function (value) {\r\n if (value == '/') {\r\n return '';\r\n } else {\r\n return value;\r\n }\r\n },\r\n },\r\n },\r\n yAxis: [\r\n //双y轴,目的是使用第二个y轴来配置字符L显示在y轴下方箭头的位置\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n inverse: true, //y轴坐标轴向下\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [getLineObj(1, yDataSource1), getLineObj(2, yDataSource2), getLineObj(3, yDataSource3)],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 土基回弹模量\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart310: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n let xData = xDataArr[0], // [0.02, 0.04, 0.06, 0.08, 0.14, 0.18, 0.22, 0.26, 0.3, 0.34],\r\n yData = yDataArr[0]; // [6, 10, 12, 16, 20, 28, 36, 44, 54, 68];\r\n\r\n let xDataCl = [],\r\n yDataCl = [];\r\n xData.forEach((item, index) => {\r\n if (item != null && item != undefined && item != '/' && (item._code == null || item._code == undefined)) {\r\n xDataCl.push(item);\r\n yDataCl.push(yData[index]);\r\n }\r\n });\r\n xData = xDataCl;\r\n yData = yDataCl;\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (\r\n xData.every((item) => item == '/' || (item._code != null && item._code != undefined)) &&\r\n yData.every((item) => item == '/' || (item._code != null && item._code != undefined))\r\n ) {\r\n yValIsAllNull = true;\r\n xData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 35,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 20,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n top: 16,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: xData,\r\n axisLabel: {\r\n // 使用formatter格式化标签\r\n formatter: function (value) {\r\n if (value == '/') {\r\n return '';\r\n } else {\r\n return value;\r\n }\r\n },\r\n },\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n axisLine: {\r\n //设置x轴箭头效果\r\n symbol: ['none', 'arrow'], //默认是['none', 'none'],可以设置为['arrow', 'none']或['none', 'arrow']等来分别控制起始和结束的箭头\r\n symbolSize: 10, //箭头大小\r\n },\r\n splitLine: { show: true },\r\n position: 'top', //设置x轴在顶部显示\r\n name: 'p', //设置x轴显示的名称\r\n nameGap: 5, //坐标轴名称与轴线之间的距离\r\n nameLocation: 'end', //设置x轴显示的名称的位置在末端,注意:需要配置grid.right一起使用,不然可能会被遮住\r\n },\r\n yAxis: [\r\n //双y轴,目的是使用第二个y轴来配置字符L显示在y轴下方箭头的位置\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n inverse: true, //y轴坐标轴向下\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n symbol: ['arrow', 'none'], //默认是['none', 'none'],可以设置为['arrow', 'none']或['none', 'arrow']等来分别控制起始和结束的箭头\r\n symbolSize: 10, //箭头大小\r\n },\r\n },\r\n {\r\n //配置符号L的显示\r\n name: 'L',\r\n nameRotate: 0,\r\n nameLocation: 'end',\r\n nameGap: 5, //坐标轴名称与轴线之间的距离\r\n position: 'left',\r\n inverse: true, //y轴坐标轴向下\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: yData,\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 布氏粘度计\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart330: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n let title = '', //config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n let xData = xDataArr[0],\r\n yData = yDataArr[0];\r\n\r\n //获取y轴趋势公式对象\r\n const gsS: any = EChartsUtilsComm.calcTrend(xData, yData, xData[0]);\r\n\r\n //黏度为0.15Pa·s、0.19Pa·s、0.25Pa·s、0.31Pa·s时的温度\r\n let wd015 = EChartsUtilsComm.getRound((0.15 - gsS.jj) / gsS.xl, 0),\r\n wd019 = EChartsUtilsComm.getRound((0.19 - gsS.jj) / gsS.xl, 0),\r\n wd025 = EChartsUtilsComm.getRound((0.25 - gsS.jj) / gsS.xl, 0),\r\n wd031 = EChartsUtilsComm.getRound((0.31 - gsS.jj) / gsS.xl, 0);\r\n\r\n if (wd015 == Infinity) {\r\n wd015 = 0;\r\n }\r\n if (wd019 == Infinity) {\r\n wd019 = 0;\r\n }\r\n if (wd025 == Infinity) {\r\n wd025 = 0;\r\n }\r\n if (wd031 == Infinity) {\r\n wd031 = 0;\r\n }\r\n //输出“拌合温度范围 ℃”和“压实成型温度范围 ℃”\r\n let wdBh = `${wd015}~${wd019}`,\r\n wdYs = `${wd025}~${wd031}`;\r\n // console.log('输出温度:', wdBh, wdYs);\r\n\r\n //设置Sheet单元格的值(拌合温度和压实成型温度范围)\r\n if (chartExtJson != null) {\r\n if (wd015 == 0 && wd019 == 0) {\r\n sheet.setValue(chartExtJson.bszdjBh.row, chartExtJson.bszdjBh.col, '/');\r\n } else {\r\n sheet.setValue(chartExtJson.bszdjBh.row, chartExtJson.bszdjBh.col, wdBh);\r\n }\r\n if (wd025 == 0 && wd031 == 0) {\r\n sheet.setValue(chartExtJson.bszdjYs.row, chartExtJson.bszdjYs.col, '/');\r\n } else {\r\n sheet.setValue(chartExtJson.bszdjYs.row, chartExtJson.bszdjYs.col, wdYs);\r\n }\r\n }\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.every((item) => item == '/') && yData.every((item) => item == '/')) {\r\n yValIsAllNull = true;\r\n xData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 18,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n axisLabel: {\r\n // 使用formatter格式化标签\r\n formatter: function (value) {\r\n if (value == '/') {\r\n return '';\r\n } else {\r\n return value;\r\n }\r\n },\r\n },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 25 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: yData,\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 液限碟式仪\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart350: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson),\r\n lineColor = lineData[0].lineColor;\r\n\r\n //击数N(次)、含水率w(%)、y轴第一个趋势数据、y轴第二个趋势数据、25的趋势数据、y轴最小值、y轴最大值\r\n const jsN = [xDataArr[0][0], xDataArr[0][1]], // [18, 30],\r\n hsl = [yDataArr[0][0], yDataArr[0][1]], // [22.1, 11.5],\r\n //通过calcTrend获取y轴第一个趋势数据、y轴第二个趋势数据、25的趋势数据\r\n yVal1 = Number(EChartsUtilsComm.getRound(EChartsUtilsComm.calcTrend(jsN, hsl, jsN[0]).y, 0.1)),\r\n yVal2 = Number(EChartsUtilsComm.getRound(EChartsUtilsComm.calcTrend(jsN, hsl, jsN[1]).y, 0.1)),\r\n yVal25 = Number(EChartsUtilsComm.getRound(EChartsUtilsComm.calcTrend(jsN, hsl, 25).y, 0.1)),\r\n //通过calcTrend获取y轴的趋势数据,然后分别-2和+2\r\n yAxisMin = Math.floor(Number(yVal2)) - 2,\r\n yAxisMax = Math.floor(Number(yVal1)) + 2;\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //检测是否所有数据都为空\r\n let isAllNull = true;\r\n isAllNull = xDataArr[0].filter((item) => item != null && item != undefined && item != '/').length == 0;\r\n if (isAllNull) {\r\n isAllNull = yDataArr[0].filter((item) => item != null && item != undefined && item != '/').length == 0;\r\n }\r\n\r\n //x和y轴的字体大小\r\n const xyFontSize = 8;\r\n\r\n let seriesObjs = [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle',\r\n z: 10, //控制曲线的浮动层级,避免在markLine下方被遮住\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineColor,\r\n },\r\n connectNulls: true, //是否连接空数据\r\n data: [\r\n [0, null],\r\n [2, null],\r\n [3.5, null],\r\n [4.9, null],\r\n [5.9, null],\r\n [6.9, null],\r\n {\r\n //延长线1\r\n value: [10.4, yVal25 - (2.7 * (yVal25 - yVal1)) / 2.1],\r\n symbol: 'none', //隐藏线条上的数据点\r\n },\r\n [11, yVal1], //第一个点\r\n [11.8, null],\r\n [13.1, yVal25], //第二个点\r\n [14.6, yVal2], //第三个点\r\n {\r\n //延长线2\r\n value: [15.2, (2.1 / 1.5) * (yVal2 - yVal25) + yVal25],\r\n symbol: 'none', //隐藏线条上的数据点\r\n },\r\n [16.4, null],\r\n [17.4, null],\r\n [18.9, null],\r\n [19.8, null],\r\n [20.7, null],\r\n [21.6, null],\r\n [22.6, null],\r\n ],\r\n markPoint: {\r\n data: [\r\n {\r\n xAxis: 13.1,\r\n yAxis: yVal25,\r\n symbolOffset: [40, 25],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n //显示25这个坐标点数据\r\n return isAllNull ? '' : '( ' + 25 + ' , ' + data.data.yAxis + ')';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n ],\r\n },\r\n markLine: {\r\n symbol: '', //取消箭头\r\n silent: true, //取消鼠标hover事件\r\n label: {\r\n //标线的文本,模拟x轴显示的内容\r\n position: 'start', //改变label位置\r\n // rotate: 45, //设置文字旋转度数(注意:ECharts官网文档居然没有rotate这个属性的说明)\r\n // backgroundColor:'#fff'\r\n // color:'#f00',//文字颜色\r\n formatter: (data) => {\r\n return data.name;\r\n },\r\n },\r\n lineStyle: { color: '#e0e6f1', type: 'solid' },\r\n data: [\r\n {\r\n name: '5',\r\n xAxis: 0,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n name: '6',\r\n xAxis: 2,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n name: '7',\r\n xAxis: 3.5,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n name: '8',\r\n xAxis: 4.9,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n name: '9',\r\n xAxis: 5.9,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n name: '10',\r\n xAxis: 6.9,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n //延长线1\r\n name: '',\r\n xAxis: 10.4,\r\n lineStyle: {\r\n opacity: 0,\r\n },\r\n },\r\n {\r\n //第一个点\r\n name: '',\r\n xAxis: 11,\r\n },\r\n {\r\n name: '20',\r\n xAxis: 11.8,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n //第二个点\r\n name: '25',\r\n xAxis: 13.1,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n //第三个点\r\n name: '30',\r\n xAxis: 14.6,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n //延长线2\r\n name: '',\r\n xAxis: 15.2,\r\n lineStyle: {\r\n opacity: 0,\r\n },\r\n },\r\n {\r\n name: '40',\r\n xAxis: 16.4,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n name: '50',\r\n xAxis: 17.4,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n name: '',\r\n xAxis: 18.9,\r\n },\r\n {\r\n name: '',\r\n xAxis: 19.8,\r\n },\r\n {\r\n name: '',\r\n xAxis: 20.7,\r\n },\r\n {\r\n name: '',\r\n xAxis: 21.6,\r\n },\r\n {\r\n name: '100',\r\n xAxis: 22.6,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n\r\n //横线\r\n [\r\n {\r\n coord: [0, yVal25],\r\n lineStyle: {\r\n color: '#529b2e',\r\n type: 'solid',\r\n },\r\n },\r\n { coord: [13.1, yVal25] },\r\n ],\r\n //纵线\r\n [\r\n {\r\n coord: [13.1, yAxisMin],\r\n lineStyle: {\r\n color: '#000',\r\n type: 'silid',\r\n },\r\n },\r\n { coord: [13.1, yVal25] },\r\n ],\r\n ],\r\n },\r\n },\r\n ];\r\n if (isAllNull) {\r\n seriesObjs = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: 30,\r\n right: 10,\r\n bottom: 35,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas[0].data.length > 1\r\n ? datas[0].data[1] == null\r\n ? ''\r\n : datas[0].seriesName + '(' + datas[0].data[0] + ')' + ':' + datas[0].data[1]\r\n : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n axisTick: { show: false }, //隐藏刻度线\r\n axisLabel: { show: false }, //隐藏刻度值\r\n //网格线,参考文档:https://echarts.apache.org/zh/option.html#xAxis.splitLine\r\n splitLine: {\r\n show: false, //隐藏分割线\r\n },\r\n min: 0,\r\n max: 23.5,\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !isAllNull ? 30 : 10,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n splitNumber: 4, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n min: !isAllNull ? yAxisMin : null,\r\n max: yAxisMax,\r\n axisLabel: {\r\n show: !isAllNull ? true : false,\r\n fontSize: xyFontSize,\r\n },\r\n axisTick: {\r\n show: !isAllNull ? true : false,\r\n },\r\n },\r\n ],\r\n series: seriesObjs,\r\n };\r\n\r\n return option;\r\n },\r\n};\r\n","import * as echarts from 'echarts';\r\nimport { type CellModel } from '../types/sheet';\r\nimport { type EChartsUtilsConfigModel, type EChartsUtilsChartLinesJsonModel } from '../types/echarts';\r\nimport { EChartsUtilsAll } from './echarts-all';\r\n\r\n/**\r\n * ECharts图表工具类\r\n */\r\nexport const EChartsUtils = {\r\n /**\r\n * 创建图表\r\n * @param GC GC对象\r\n * @param spread 工作簿对象\r\n * @param sheet 工作表对象\r\n * @param config 折现配置\r\n * @param isHideChart 是否隐藏图表\r\n */\r\n create: async (\r\n GC: any,\r\n spread: any,\r\n sheet: any,\r\n config: EChartsUtilsConfigModel,\r\n isHideChart: boolean = false\r\n ): Promise<{\r\n fObj: any;\r\n fObjPosition: {\r\n x: number;\r\n y: number;\r\n w: number;\r\n h: number;\r\n };\r\n ecObj: echarts.ECharts;\r\n }> => {\r\n // 获取扩展配置\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n // 如果isShowCon配置存在,则验证isShowCon对应单元格的值是否和输入的配置chartExtJson.isShowVal相等,不相等的话,就不创建图表\r\n if (chartExtJson != null && chartExtJson.isShowCon != null && chartExtJson.isShowCon != undefined) {\r\n const conVal = sheet.getValue(chartExtJson.isShowCon.row, chartExtJson.isShowCon.col);\r\n\r\n if (conVal != chartExtJson.isShowVal) {\r\n sheet.floatingObjects.remove(config.chartId);\r\n return;\r\n }\r\n }\r\n\r\n // 获取图表单元格之上的所有行的高度总和、所有列的宽度总和、距离左侧的距离和图表所在单元格的高度\r\n let allRowsTotalHeight = 0,\r\n allRowsTotalWidth = 0,\r\n allRowsTotalLeft = 0,\r\n chartCellHeight = 0;\r\n for (let i = 0; i < config.row; i++) {\r\n allRowsTotalHeight += sheet.getRowHeight(i);\r\n }\r\n allRowsTotalHeight += sheet.getRowHeight(0, GC.Spread.Sheets.SheetArea.colHeader);\r\n for (let i = config.col; i < config.col + config.colCount; i++) {\r\n allRowsTotalWidth += sheet.getColumnWidth(i);\r\n }\r\n for (let i = 0; i < config.col; i++) {\r\n allRowsTotalLeft += sheet.getColumnWidth(i);\r\n }\r\n allRowsTotalLeft += sheet.getColumnWidth(0, GC.Spread.Sheets.SheetArea.rowHeader);\r\n for (let i = config.row; i < config.row + config.rowCount; i++) {\r\n chartCellHeight += sheet.getRowHeight(i);\r\n }\r\n\r\n // 设置浮动对象的呈现位置(实际情况根据需要进行调整)\r\n const fObjPosition = {\r\n x: allRowsTotalLeft - 40 + 2,\r\n y: allRowsTotalHeight - 20 + 2,\r\n w: allRowsTotalWidth - 6,\r\n h: chartCellHeight - 6,\r\n };\r\n\r\n // 获取浮动对象\r\n let fcObj = sheet.floatingObjects.get(config.chartId);\r\n\r\n // 浮动对象不存在时\r\n if (fcObj == null || fcObj == undefined) {\r\n // 创建浮动对象\r\n fcObj = new GC.Spread.Sheets.FloatingObjects.FloatingObject(config.chartId, fObjPosition.x, fObjPosition.y, fObjPosition.w, fObjPosition.h);\r\n\r\n // 不允许改变大小、不允许拖动\r\n fcObj.allowResize(false);\r\n fcObj.allowMove(false);\r\n\r\n // 将浮动对象添加到表单\r\n sheet.floatingObjects.add(fcObj);\r\n }\r\n // 浮动对象存在时\r\n else {\r\n fcObj.x(fObjPosition.x);\r\n fcObj.y(fObjPosition.y);\r\n fcObj.width(fObjPosition.w);\r\n fcObj.height(fObjPosition.h);\r\n }\r\n\r\n // 设置浮动对象的内容为divObj(当document.getElementById(config.chartId + '_ec')为null的时候)\r\n if (document.getElementById(config.chartId + '_ec') == null) {\r\n // 创建用于放置ECharts的div容器\r\n const divObj = document.createElement('div');\r\n divObj.setAttribute('style', `background-color:#fff;width:100%;height:100%;`);\r\n divObj.innerHTML = `<div id=\"${config.chartId}_ec\" style=\"width:100%;height:100%;\"></div>`;\r\n\r\n fcObj.content(divObj);\r\n }\r\n\r\n // 定义ECharts对象\r\n let ecObj: echarts.ECharts | null = null;\r\n\r\n // 获取ECharts对象的函数(这里使用到了Promise和setTimeout,原因是:ECharts所在的div可能还没有及时在浮动元素中渲染完成,导致ECharts展示部出来)\r\n const getEcObj = (): any => {\r\n return new Promise((resolve, reject) => {\r\n setTimeout(() => {\r\n // 初始化图表并获取ECharts对象\r\n resolve({ ecObj: EChartsUtils.initChart(spread, sheet, config, isHideChart) });\r\n }, 10);\r\n });\r\n };\r\n ecObj = (await getEcObj()).ecObj;\r\n\r\n return {\r\n fObj: fcObj,\r\n fObjPosition: fObjPosition,\r\n ecObj: ecObj,\r\n };\r\n },\r\n\r\n /**\r\n * 初始化图表\r\n * @param spread 工作簿对象\r\n * @param sheet 工作表对象\r\n * @param config 图表配置\r\n * @param isHideChart 是否隐藏图表\r\n */\r\n initChart: (spread: any, sheet: any, config: EChartsUtilsConfigModel, isHideChart: boolean = false): echarts.ECharts => {\r\n // 获取多条x轴的数组(类似[[1,2,3,4],[1,2,3,4]])\r\n let xDataArr: any = [],\r\n yDataArr: any = [];\r\n\r\n // 获取多条x轴的数组(单元格原始数据,类似[['1.0','2.0','3.0'],['1.0','2.0','3.0']],此数据可能在有些情况下需要使用原始数据,如:原始数据为字符串的1.0,可能需要在x轴显示为1.0这个字符文本)\r\n let xDataArrSource: any = [],\r\n yDataArrSource: any = [];\r\n\r\n /**\r\n * 获取x或y轴单元格的值集合\r\n * @param spread 工作簿对象\r\n * @param sheet 工作表对象\r\n * @param sheetName x轴或y轴数据所在的Sheet名称,如果没有值,则说明是当前操作的Sheet\r\n * @param cells 单元格集合\r\n * @returns 返回x或y轴数据的值集合\r\n */\r\n const getCellVals = (\r\n spread: any,\r\n sheet: any,\r\n sheetName?: string,\r\n cells?: CellModel[]\r\n ): {\r\n dataOneArr: any[];\r\n dataOneSourceArr: any[];\r\n } => {\r\n let retArr: {\r\n dataOneArr: any[];\r\n dataOneSourceArr: any[];\r\n } = {\r\n dataOneArr: [],\r\n dataOneSourceArr: [],\r\n };\r\n\r\n // 获取x或y轴数据所在的Sheet对象(如果sheetName有值,则说明是跨Sheet的)\r\n let curSheet: any = null;\r\n if (sheetName != null && sheetName != undefined && sheetName.length > 0) {\r\n curSheet = spread.getSheetFromName(sheetName);\r\n }\r\n\r\n cells?.forEach((itemCell, indexCell) => {\r\n // 如果单元格的值为数字,就转换为数字,否则在后期参与各个ECharts图表计算的时候会出错\r\n const curCellVal = curSheet != null ? curSheet.getValue(itemCell.row, itemCell.col) : sheet.getValue(itemCell.row, itemCell.col);\r\n retArr.dataOneSourceArr.push(curCellVal);\r\n\r\n // 严格的数字验证(包括科学计数法)\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curCellVal)) {\r\n retArr.dataOneArr.push(Number(curCellVal));\r\n } else {\r\n retArr.dataOneArr.push(curCellVal == null ? 0 : curCellVal);\r\n }\r\n });\r\n\r\n return retArr;\r\n };\r\n\r\n let lineData: EChartsUtilsChartLinesJsonModel[] = JSON.parse(config.chartLinesJson);\r\n lineData.forEach((item, index) => {\r\n let xDataOne: any = [],\r\n yDataOne: any = [];\r\n let xDataOneSource: any = [],\r\n yDataOneSource: any = [];\r\n\r\n const curItemValsX = getCellVals(spread, sheet, item.sheetNameX, item.xCells);\r\n xDataOne = curItemValsX.dataOneArr;\r\n xDataOneSource = curItemValsX.dataOneSourceArr;\r\n const curItemValsY = getCellVals(spread, sheet, item.sheetNameY, item.yCells);\r\n yDataOne = curItemValsY.dataOneArr;\r\n yDataOneSource = curItemValsY.dataOneSourceArr;\r\n\r\n xDataArr.push(xDataOne);\r\n yDataArr.push(yDataOne);\r\n xDataArrSource.push(xDataOneSource);\r\n yDataArrSource.push(yDataOneSource);\r\n });\r\n\r\n // 获取ECharts图表所在div容器\r\n const ecDom = document.getElementById(config.chartId + '_ec') as HTMLElement;\r\n\r\n // 获取ECharts对象\r\n let ecObj = echarts.getInstanceByDom(ecDom);\r\n if (ecObj == null || ecObj == undefined) {\r\n ecObj = echarts.init(ecDom, null, {\r\n renderer: 'canvas',\r\n useDirtyRect: false,\r\n });\r\n }\r\n\r\n let option;\r\n\r\n if (config.chartType == 10) {\r\n option = EChartsUtilsAll.chart10(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 11) {\r\n option = EChartsUtilsAll.chart11(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 12) {\r\n option = EChartsUtilsAll.chart12(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 13) {\r\n option = EChartsUtilsAll.chart13(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 14) {\r\n option = EChartsUtilsAll.chart14(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 15) {\r\n option = EChartsUtilsAll.chart15(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 16) {\r\n option = EChartsUtilsAll.chart16(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 30) {\r\n option = EChartsUtilsAll.chart30(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 50) {\r\n option = EChartsUtilsAll.chart50(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 70) {\r\n option = EChartsUtilsAll.chart70(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 90) {\r\n option = EChartsUtilsAll.chart90(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 110) {\r\n option = EChartsUtilsAll.chart110(config, xDataArr, yDataArr, xDataArrSource, yDataArrSource);\r\n } else if (config.chartType == 130) {\r\n option = EChartsUtilsAll.chart130(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 150) {\r\n option = EChartsUtilsAll.chart150(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 170) {\r\n option = EChartsUtilsAll.chart170(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 190) {\r\n option = EChartsUtilsAll.chart190(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 210) {\r\n option = EChartsUtilsAll.chart210(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 230) {\r\n option = EChartsUtilsAll.chart230(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 250) {\r\n option = EChartsUtilsAll.chart250(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 270) {\r\n option = EChartsUtilsAll.chart270(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 279 || config.chartType == 280 || config.chartType == 281) {\r\n option = EChartsUtilsAll.chart279_280_281(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 290) {\r\n option = EChartsUtilsAll.chart290(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 310) {\r\n option = EChartsUtilsAll.chart310(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 330) {\r\n option = EChartsUtilsAll.chart330(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 350) {\r\n option = EChartsUtilsAll.chart350(config, xDataArr, yDataArr);\r\n }\r\n\r\n if (option && typeof option === 'object') {\r\n //如果是隐藏的图表,则需要禁用ECharts的动画效果\r\n //原因是:如果ECharts使用了动画效果,图表渲染完成可能需要0.5秒,但是在导出ECharts统计图为图片的场景下时,可能在图表还没有渲染完成(动画效果还没结束)前就要获取图像了,此时可能就会造成获取到的图像内容丢失的情况\r\n if (isHideChart) {\r\n option.animation = false;\r\n }\r\n\r\n ecObj.setOption(option);\r\n }\r\n\r\n ecObj.setOption(option);\r\n\r\n return ecObj;\r\n },\r\n\r\n /**\r\n * 获取ECharts对象\r\n * @param chartId 图表ID\r\n * @returns 返回ECharts对象,如果不存在则返回null\r\n */\r\n getEChartsObj: (chartId: string): echarts.ECharts | null => {\r\n // 获取ECharts图表所在div容器\r\n const ecDom = document.getElementById(chartId + '_ec') as HTMLElement;\r\n\r\n // 获取ECharts对象\r\n let ecObj = echarts.getInstanceByDom(ecDom);\r\n if (ecObj == null || ecObj == undefined) {\r\n return null;\r\n }\r\n\r\n return ecObj;\r\n },\r\n};\r\n","// 导入rapid-utils中的函数(注意:需要在tsconfig.json文件中设置moduleResolution为node,否则会提示:找不到模块“rapid-utils”。你的意思是要将 \"moduleResolution\" 选项设置为 \"nodenext\",还是要将别名添加到 \"paths\" 选项中?ts(2792))\r\nimport { orderByJson } from 'rapid-utils';\r\n// 导入单元格实体\r\nimport { CellModel, CellWatermarkModel, CellDateModel } from '../types/sheet';\r\n\r\n/**\r\n * SpreadJS工作表工具函数属性\r\n */\r\nexport const SheetUtils = {\r\n /**\r\n * 获取当前活动工作表选中的单元格集合\r\n * @param spread 工作簿对象\r\n * @returns 返回选中单元格的集合,格式如:[{ row: 0, col: 0, rowCount: 1, colCount: 1 }]\r\n */\r\n getActiveSheetSelectCells: (spread: any): CellModel[] => {\r\n const sheet = spread.getActiveSheet();\r\n\r\n const allCellObjs: CellModel[] = sheet.getSelections();\r\n\r\n return allCellObjs;\r\n },\r\n\r\n /**\r\n * 设置当前活动工作表某个或某些单元格范围为选中状态\r\n * @param spread 工作簿对象\r\n * @param cellObj 设置选中的单元格,格式如:{row:0,col:0,rowCount:1,colCount:1}\r\n */\r\n setActiveSheetSelectCells: (spread: any, cellObj: CellModel) => {\r\n const sheet = spread.getActiveSheet();\r\n\r\n sheet.setSelection(cellObj.row, cellObj.col, cellObj.rowCount, cellObj.colCount);\r\n },\r\n\r\n /**\r\n * 获取某工作表中某范围集合中所有的单元格坐标对象集合\r\n * 该方法适用的场景如:手动选择了很多个单元格范围,在这些范围中可能包含独立的单元格,也可能包含合并的单元格,这时候就需要用到如下方法获取到所有单元格对象\r\n * @param sheet 工作表实例\r\n * @param selectRanges 单元格范围集合,格式如:[{ row: 0, col: 0, rowCount: 2, colCount: 2 }]\r\n * @param isMulColOrder 是否按照多列的顺序排序单元格(true:按照第一列从上到下、第二列从上到下……的顺序获取单元格数据、false:按照第一行从左到右、第二行从左到右……的顺序获取单元格数据)\r\n * @returns 返回数组集合,格式如:[{ row: 0, col: 0, rowCount: 1, colCount: 1 }]\r\n */\r\n getAllCellObjsByRanges: (sheet: any, selectRanges: CellModel[], isMulColOrder: boolean = false): CellModel[] => {\r\n // 得到所有的单元格坐标对象集合,格式如:[{ row: 0, col: 0, rowCount: 1, colCount: 1 }]\r\n let allCellObjs: CellModel[] = [];\r\n\r\n selectRanges.forEach((item, index) => {\r\n // 得到当前item中所有合并的单元格对象集合\r\n const itemSpanCells = sheet.getSpans(item);\r\n itemSpanCells.forEach((itemSpanCell: CellModel) => {\r\n allCellObjs.push({\r\n row: itemSpanCell.row,\r\n col: itemSpanCell.col,\r\n rowCount: itemSpanCell.rowCount,\r\n colCount: itemSpanCell.colCount,\r\n });\r\n });\r\n\r\n if (item.row === undefined || item.col === undefined || item.rowCount === undefined || item.colCount === undefined) {\r\n throw new Error('row、col、rowCount、colCount is required.');\r\n }\r\n\r\n // 遍历item中涉及到的所有单元格\r\n for (let i = item.row; i < +item.row + item.rowCount; i++) {\r\n for (let j = item.col; j < item.col + item.colCount; j++) {\r\n const curSpanCellObj = sheet.getSpan(i, j);\r\n\r\n // 检查当前单元格是否为合并单元格\r\n if (curSpanCellObj == null) {\r\n allCellObjs.push({\r\n row: i,\r\n col: j,\r\n rowCount: 1,\r\n colCount: 1,\r\n });\r\n }\r\n }\r\n }\r\n });\r\n\r\n // 对所有单元格坐标对象集合进行排序\r\n allCellObjs = orderByJson(allCellObjs, !isMulColOrder ? ['row', 'col'] : ['col', 'row'], ['asc', 'asc']);\r\n\r\n return allCellObjs;\r\n },\r\n\r\n /**\r\n * 获取某工作表中所有的单元格坐标对象集合\r\n * @param sheet 工作表实例\r\n * @returns 返回数组集合,格式如:[{ col: 0, colCount: 2, row: 0, rowCount: 1 }]\r\n */\r\n getSheetAllCellObjs: (sheet: any): CellModel[] => {\r\n // 得到当前Sheet单元格范围\r\n const curSheetCellRange = [\r\n {\r\n row: 0,\r\n col: 0,\r\n rowCount: sheet.getRowCount(),\r\n colCount: sheet.getColumnCount(),\r\n },\r\n ];\r\n\r\n // 得到所有的单元格坐标对象集合,格式如:[{ col: 0, colCount: 2, row: 0, rowCount: 1 }]\r\n const allCellObjs = SheetUtils.getAllCellObjsByRanges(sheet, curSheetCellRange);\r\n\r\n return allCellObjs;\r\n },\r\n\r\n /**\r\n * 获取某工作表中选中的所有单元格坐标对象集合\r\n * @param sheet 工作表实例\r\n * @param isMulColOrder 是否按照多列的顺序排序单元格(true:按照第一列从上到下、第二列从上到下……的顺序获取单元格数据、false:按照第一行从左到右、第二行从左到右……的顺序获取单元格数据)\r\n * @returns 返回数组集合,格式如:[{ col: 0, row: 0, \"rowCount\": 1, \"colCount\": 1 }]\r\n */\r\n getSheetSelectCellObjs: (sheet: any, isMulColOrder: boolean = false): CellModel[] => {\r\n // 得到当前Sheet中选择的单元格范围集合\r\n const curSheetCellRange = sheet.getSelections();\r\n\r\n // 得到所有的单元格坐标对象集合,格式如:[{ col: 0, colCount: 2, row: 0, rowCount: 1 }]\r\n const allCellObjs = SheetUtils.getAllCellObjsByRanges(sheet, curSheetCellRange, isMulColOrder);\r\n\r\n return allCellObjs;\r\n },\r\n\r\n /**\r\n * 获取活动工作表中选中的所有单元格坐标对象集合\r\n * @param spread 工作簿实例\r\n * @param isMulColOrder 是否按照多列的顺序排序单元格(true:按照第一列从上到下、第二列从上到下……的顺序获取单元格数据、false:按照第一行从左到右、第二行从左到右……的顺序获取单元格数据)\r\n * @returns 返回数组集合,格式如:[{ col: 0, row: 0, \"rowCount\": 1, \"colCount\": 1 }]\r\n */\r\n getActiveSheetSelectCellObjs: (spread: any, isMulColOrder: boolean = false): CellModel[] => {\r\n // 当前活动的Sheet\r\n const sheet = spread.getActiveSheet();\r\n\r\n return SheetUtils.getSheetSelectCellObjs(sheet, isMulColOrder);\r\n },\r\n\r\n /**\r\n * 获取某工作表选中单元格的值集合\r\n * @param sheet 工作表实例\r\n * @param isMulColOrder 是否按照多列的顺序排序单元格(true:按照第一列从上到下、第二列从上到下……的顺序获取单元格数据、false:按照第一行从左到右、第二行从左到右……的顺序获取单元格数据)\r\n * @param nullUndefinedReplaceVal 如果单元格的值为null或undefined,则将其替换为该值(如果不传入该参数,则不替换)\r\n * @returns 返回选中单元格的值集合\r\n */\r\n getSheetSelectVals: (\r\n sheet: any,\r\n isMulColOrder: boolean = false,\r\n nullUndefinedReplaceVal?: number | string\r\n ): (number | string | null | undefined)[] => {\r\n // 获取活动工作表选中单元格对象集合\r\n const selectCells = SheetUtils.getSheetSelectCellObjs(sheet, isMulColOrder);\r\n\r\n // 获取选中单元格的值集合\r\n let selectCellVals: (number | string | null | undefined)[] = [];\r\n selectCells.forEach((cell) => {\r\n let cellVal = sheet.getValue(cell.row, cell.col);\r\n\r\n // 如果cellVal为null或undefined,并且nullUndefinedReplaceVal不为null或undefined,则将cellVal替换为nullUndefinedReplaceVal\r\n if (nullUndefinedReplaceVal != null && nullUndefinedReplaceVal != undefined && (cellVal === null || cellVal === undefined)) {\r\n cellVal = nullUndefinedReplaceVal;\r\n }\r\n\r\n selectCellVals.push(cellVal);\r\n });\r\n\r\n return selectCellVals;\r\n },\r\n\r\n /**\r\n * 获取活动工作表选中单元格的值集合\r\n * @param spread 工作簿实例\r\n * @param isMulColOrder 是否按照多列的顺序排序单元格(true:按照第一列从上到下、第二列从上到下……的顺序获取单元格数据、false:按照第一行从左到右、第二行从左到右……的顺序获取单元格数据)\r\n * @param nullUndefinedReplaceVal 如果单元格的值为null或undefined,则将其替换为该值(如果不传入该参数,则不替换)\r\n * @returns 返回选中单元格的值集合\r\n */\r\n getActiveSheetSelectVals: (\r\n spread: any,\r\n isMulColOrder: boolean = false,\r\n nullUndefinedReplaceVal?: number | string\r\n ): (number | string | null | undefined)[] => {\r\n // 获取当前活动工作表\r\n const sheet = spread.getActiveSheet();\r\n\r\n return SheetUtils.getSheetSelectVals(sheet, isMulColOrder, nullUndefinedReplaceVal);\r\n },\r\n\r\n /**\r\n * 获取单元格类型名称\r\n * @param GC GC对象\r\n * @param sheet 工作表实例\r\n * @param row 单元格行索引\r\n * @param col 单元格列索引\r\n * @returns 返回单元格类型名称,如:button、radio、checkbox、checkboxList、hyperLink、comboBox、date、dateRange、calc\r\n */\r\n getCellType: (GC: any, sheet: any, row: number, col: number): string | undefined => {\r\n let cellTypeName;\r\n\r\n // 先根据getCellType来获取\r\n const cellType = sheet.getCellType(row, col);\r\n\r\n if (cellType instanceof GC.Spread.Sheets.CellTypes.Button) {\r\n cellTypeName = 'button';\r\n } else if (cellType instanceof GC.Spread.Sheets.CellTypes.RadioButtonList) {\r\n cellTypeName = 'radio';\r\n } else if (cellType instanceof GC.Spread.Sheets.CellTypes.CheckBox) {\r\n cellTypeName = 'checkbox';\r\n } else if (cellType instanceof GC.Spread.Sheets.CellTypes.CheckBoxList) {\r\n cellTypeName = 'checkboxList';\r\n } else if (cellType instanceof GC.Spread.Sheets.CellTypes.HyperLink) {\r\n cellTypeName = 'hyperLink';\r\n } else if (cellType instanceof GC.Spread.Sheets.CellTypes.ComboBox) {\r\n cellTypeName = 'comboBox';\r\n }\r\n\r\n // 根据getStyle来获取\r\n if (cellTypeName == undefined || cellTypeName == null) {\r\n const cellStyle = sheet.getStyle(row, col);\r\n\r\n if (cellStyle && cellStyle.cellButtons && cellStyle.cellButtons.length > 0) {\r\n if (cellStyle.cellButtons[0].command == 'openDateTimePicker') {\r\n if (cellStyle.dropDowns && cellStyle.dropDowns.length > 0) {\r\n if (cellStyle.dropDowns[0].option.showDateRange) {\r\n cellTypeName = 'dateRange';\r\n } else {\r\n cellTypeName = 'date';\r\n }\r\n }\r\n } else if (cellStyle.cellButtons[0].command == 'openCalculator') {\r\n cellTypeName = 'calc';\r\n }\r\n }\r\n }\r\n\r\n return cellTypeName;\r\n },\r\n\r\n /**\r\n * 设置工作簿中所有工作表的缩放比例\r\n * @param spread 工作簿实例\r\n * @param scale 缩放比例,默认为:1(100%)\r\n */\r\n setSheetZoom: (spread: any, scale: number) => {\r\n // 暂停绘制\r\n spread.suspendPaint();\r\n\r\n const sheetCount = spread.getSheetCount();\r\n for (let i = 0; i < sheetCount; i++) {\r\n const sheet = spread.getSheet(i);\r\n\r\n sheet.zoom(scale);\r\n }\r\n\r\n // 恢复绘制\r\n spread.resumePaint();\r\n },\r\n\r\n /**\r\n * 设置当前活动工作表中选中的单元格背景颜色\r\n * @param spread 工作簿实例\r\n * @param color 背景颜色\r\n */\r\n setActiveSheetSelectBgColor: (spread: any, color: string) => {\r\n const sheet = spread.getActiveSheet();\r\n\r\n // 暂停绘制\r\n sheet.suspendPaint();\r\n\r\n //#region 方式1:通过getRange进行批量设置,推荐使用该方法来实现\r\n\r\n // 获取选择的多个单元格范围集合\r\n const selections = SheetUtils.getActiveSheetSelectCells(spread);\r\n\r\n // 循环每个选中的单元格范围\r\n selections.forEach((sel: CellModel) => {\r\n // 批量设置每个选中的单元格范围的背景颜色\r\n sheet.getRange(sel.row, sel.col, sel.rowCount, sel.colCount).backColor(color);\r\n });\r\n\r\n //#endregion\r\n\r\n //#region 方式2:通过getCell获取单元格样式对每个单元格进行设置,此方式效率相对较低,不推荐\r\n\r\n // // 当前活动的工作表中所有选择的单元格\r\n // const selectCells = SheetUtils.getActiveSheetSelectCellObjs(spread);\r\n\r\n // selectCells.forEach(item => {\r\n // // 获取单元格对象\r\n // const cellObj = sheet.getCell(item.row, item.col);\r\n\r\n // // 获取单元格样式\r\n // let cellStyle = sheet.getStyle(item.row, item.col);\r\n // if (!cellStyle) {\r\n // // 不存在样式则new一个\r\n // cellStyle = new GC.Spread.Sheets.Style();\r\n // }\r\n\r\n // // 设置单元格背景颜色\r\n // cellStyle.backColor = color;\r\n\r\n // // 重新设置单元格样式\r\n // cellObj.setStyle(cellStyle);\r\n // });\r\n\r\n //#endregion\r\n\r\n // 恢复绘制\r\n sheet.resumePaint();\r\n },\r\n\r\n /**\r\n * 设置某工作表中指定单元格背景颜色\r\n * @param sheet 工作表实例\r\n * @param cells 单元格集合\r\n * @param color 背景颜色\r\n */\r\n setSheetBgColor: (sheet: any, cells: CellModel[], color: string) => {\r\n // 暂停绘制\r\n sheet.suspendPaint();\r\n\r\n // 循环每个选中的单元格范围\r\n cells.forEach((sel: CellModel) => {\r\n // 批量设置每个选中的单元格范围的背景颜色\r\n sheet.getRange(sel.row, sel.col, sel.rowCount, sel.colCount).backColor(color);\r\n });\r\n\r\n // 恢复绘制\r\n sheet.resumePaint();\r\n },\r\n\r\n /**\r\n * 设置工作簿中所有工作表是否显示分页线\r\n * @param spread 工作簿实例\r\n * @param isShow 是否显示分页线(true:显示、false:不显示)\r\n */\r\n setSheetShowPrintPageLine: (spread: any, isShow: boolean) => {\r\n // 暂停绘制\r\n spread.suspendPaint();\r\n\r\n const sheetCount = spread.getSheetCount();\r\n for (let i = 0; i < sheetCount; i++) {\r\n const sheet = spread.getSheet(i);\r\n\r\n // 获取当前工作表是否显示分页线\r\n // var isVisible = sheet.isPrintLineVisible();\r\n\r\n sheet.isPrintLineVisible(isShow);\r\n }\r\n\r\n // 恢复绘制\r\n spread.resumePaint();\r\n },\r\n\r\n /**\r\n * 忽略工作工作表元格中指定字符串不显示,如:#DIV/0!、#VALUE!等\r\n * @param GC GC对象\r\n */\r\n ignoreSheetShowStrs: (GC: any) => {\r\n // 忽略的字符串集合\r\n const ignoreStrs: string[] = ['#DIV/0!', '#VALUE!', '#NAME?', '#N/A', '#NULL!', '#NUM!', '#REF!'];\r\n\r\n // paint对象\r\n const ignorePaint = GC.Spread.Sheets.CellTypes.Text.prototype.paint;\r\n\r\n // 重写paint函数\r\n GC.Spread.Sheets.CellTypes.Text.prototype.paint = function (ctx: any, value: any, x: any, y: any, w: any, h: any, style: any, options: any) {\r\n // 如果在忽略的字符串集合中有匹配的结果,则将其显示为空字符串\r\n if (ignoreStrs.some((item) => item == value)) {\r\n ignorePaint.call(this, ctx, '/', x, y, w, h, style, options);\r\n } else {\r\n ignorePaint.apply(this, arguments);\r\n }\r\n\r\n // // 或使用如下代码\r\n // if (ignoreStrs.some((item) => item == value)) {\r\n // \tvalue = '';\r\n // }\r\n // ignorePaint.apply(this, [ctx, value, x, y, w, h, style, options]);\r\n };\r\n },\r\n\r\n /**\r\n * 设置工作表显示辅助线(底部和右侧的辅助线)\r\n * @param sheet 工作表实例\r\n * @param width 宽度(像素)\r\n * @param height 高度(像素)\r\n * @param lineWidth 辅助线宽度(默认为:1像素)\r\n * @param colorStr 辅助线颜色(默认为:#409eff)\r\n * @param isHb 是否为横表(默认为:false)\r\n */\r\n setSheetAuxiliaryLine: (\r\n GC: any,\r\n sheet: any,\r\n width: number,\r\n height: number,\r\n lineWidth: number = 1,\r\n colorStr: string = '#409eff',\r\n isHb: boolean = false\r\n ) => {\r\n // 创建底部和右侧的浮动对象\r\n let floatBottom = new GC.Spread.Sheets.FloatingObjects.FloatingObject(`floatLineBottom${isHb ? 'Hb' : ''}`, 0, height, width, lineWidth),\r\n floatRight = new GC.Spread.Sheets.FloatingObjects.FloatingObject(`floatLineRight${isHb ? 'Hb' : ''}`, width, 0, lineWidth, height);\r\n\r\n // 创建底部和右侧的div对象\r\n let divBottom = document.createElement('div'),\r\n divRight = document.createElement('div');\r\n\r\n // 设置底部div对象样式\r\n divBottom.style.width = `${width}px`;\r\n divBottom.style.height = '1px';\r\n divBottom.style.borderBottom = `${lineWidth}px dashed ${colorStr}`;\r\n\r\n // 设置右侧div对象样式\r\n divRight.style.width = '1px';\r\n divRight.style.height = `${height}px`;\r\n divRight.style.borderLeft = `${lineWidth}px dashed ${colorStr}`;\r\n\r\n // floatBottom.fixedPosition(true);\r\n // floatRight.fixedPosition(true);\r\n\r\n // 设置底部和右侧浮动对象不允许改变大小、不允许拖动和设置浮动对象的内容\r\n floatBottom.allowResize(false);\r\n floatBottom.allowMove(false);\r\n floatBottom.content(divBottom);\r\n floatRight.allowResize(false);\r\n floatRight.allowMove(false);\r\n floatRight.content(divRight);\r\n\r\n // 将浮动元素添加到工作表中\r\n sheet.floatingObjects.add(floatBottom);\r\n sheet.floatingObjects.add(floatRight);\r\n },\r\n\r\n /**\r\n * 设置当前活动工作表的水印和数据绑定是否显示\r\n * @param spread 工作簿实例\r\n * @param cells 数据绑定单元格配置集合([{ row: number; col: number; title: string; pathPrev: string; pathField: string }])\r\n * @param isShow 是否显示\r\n */\r\n setActiveSheetWatermark: (spread: any, cells: CellWatermarkModel[], isShow: boolean) => {\r\n if (cells == null || cells == undefined) {\r\n return;\r\n }\r\n\r\n const sheet = spread.getActiveSheet();\r\n\r\n // 暂停绘制\r\n sheet.suspendPaint();\r\n\r\n cells.forEach((cell: CellWatermarkModel) => {\r\n // 设置或移除水印标签\r\n sheet.getCell(cell.row, cell.col).watermark(isShow ? `{${cell.title}}` : undefined);\r\n\r\n // 设置或移除绑定路径\r\n sheet.setBindingPath(cell.row, cell.col, isShow ? `${cell.pathPrev}.${cell.pathField}` : undefined);\r\n });\r\n\r\n // 恢复绘制\r\n sheet.resumePaint();\r\n },\r\n\r\n /**\r\n\t * 设置某工作表中单元格为日期选择控件\r\n\t * @param GC GC对象\r\n\t * @param sheet 工作表实例\r\n\t * @param cells 单元格集合,格式如:[{\r\n\t\t\tdateFormat: 'yyyy-MM-dd',\r\n\t\t\trow: 0,\r\n\t\t\tcol: 0\r\n\t\t}]\r\n\t * @param isAutoSize 是否自适应单元格大小(默认为:true)\r\n\t */\r\n setSheetCellDate: (GC: any, sheet: any, cells: CellDateModel[], isAutoSize: boolean = true) => {\r\n cells.forEach((item, index) => {\r\n // 先获取单元格样式,否则设置控件后样式会丢失\r\n let cellStyle = sheet.getStyle(item.row, item.col);\r\n if (!cellStyle) {\r\n cellStyle = new GC.Spread.Sheets.Style();\r\n }\r\n\r\n cellStyle.cellButtons = [\r\n {\r\n imageType: GC.Spread.Sheets.ButtonImageType.dropdown,\r\n command: 'openDateTimePicker',\r\n // 按钮宽度\r\n // width: 10,\r\n },\r\n ];\r\n cellStyle.dropDowns = [\r\n {\r\n type: GC.Spread.Sheets.DropDownType.dateTimePicker,\r\n option: {\r\n showTime: false,\r\n showDateRange: false,\r\n },\r\n },\r\n ];\r\n cellStyle.formatter = item.dateFormat;\r\n\r\n // 是否缩小以适应\r\n cellStyle.shrinkToFit = isAutoSize;\r\n\r\n // 设置单元格样式\r\n sheet.setStyle(item.row, item.col, cellStyle);\r\n });\r\n },\r\n};\r\n","// 导出Excel文件所需的第三方包\r\nimport { saveAs } from \"file-saver\";\r\n\r\n/**\r\n * SpreadJS工作簿工具函数属性\r\n */\r\nexport const WorkbookUtils = {\r\n /**\r\n * 打印所有工作表\r\n * @param GC GC对象\r\n * @param spread 工作簿实例\r\n */\r\n print: (GC: any, spread: any) => {\r\n // 得到Sheet个数\r\n const sheetCount = spread.getSheetCount();\r\n\r\n for (let i = 0; i < sheetCount; i++) {\r\n const sheet = spread.getSheet(i);\r\n\r\n // 获取每个工作表的打印信息\r\n let printInfo = sheet.printInfo();\r\n\r\n // 隐藏行和列的头部信息\r\n printInfo.showRowHeader(GC.Spread.Sheets.Print.PrintVisibilityType.hide);\r\n printInfo.showColumnHeader(\r\n GC.Spread.Sheets.Print.PrintVisibilityType.hide\r\n );\r\n\r\n // // 显示和隐藏打印区域的辅助线\r\n // spread.getSheet(0).isPrintLineVisible(true);\r\n // spread.getSheet(0).isPrintLineVisible(!true);\r\n\r\n // 设置打印区域,这里是固定的,在业务应用中需要根据实际情况修改打印区域\r\n printInfo.rowStart(0);\r\n printInfo.rowEnd(sheet.getRowCount()); //printInfo.rowEnd(41);\r\n printInfo.columnStart(0);\r\n printInfo.columnEnd(76);\r\n\r\n // 设置SpreadJS自身的边距为合适的距离\r\n printInfo.margin({\r\n /**\r\n * 设置默认边距\r\n * 单位是:以百分之一英寸为单位\r\n * 也就是,如果我们需要设置左边距为25mm,需要将25mm先转换为英寸,然后再用这个英寸*100就是要设置的边距\r\n * 即:(25mm转换为英寸的结果)*100\r\n *\r\n * 参考文档:\r\n * https://demo.grapecity.com.cn/spreadjs/help/api/classes/GC.Spread.Sheets.Print.PrintInfo#margin\r\n * https://www.67tool.com/converter/length\r\n */\r\n // 纵表\r\n top: 0.5905511999999999 * 100,\r\n bottom: 0.5905511999999999 * 100,\r\n left: 0.9842520000000001 * 100,\r\n right: 0.5905511999999999 * 100,\r\n\r\n // // 横表\r\n // top: 0.9842520000000001 * 100,\r\n // bottom: 0.5905511999999999 * 100,\r\n // left: 0.5905511999999999 * 100,\r\n // right: 0.5905511999999999 * 100,\r\n\r\n // top: 0,\r\n // bottom: 0,\r\n // left: 0,\r\n // right: 0,\r\n header: 0,\r\n footer: 0,\r\n });\r\n\r\n // 设置打印的纸张\r\n printInfo.paperSize(\r\n new GC.Spread.Sheets.Print.PaperSize(\r\n GC.Spread.Sheets.Print.PaperKind.a4\r\n )\r\n );\r\n\r\n sheet.printInfo(printInfo);\r\n }\r\n\r\n // 调用打印方法\r\n spread.print();\r\n },\r\n\r\n /**\r\n * 导出为Excel文件\r\n * 如支持导出自定义公式的值等功能\r\n * @param GC Spread的GC对象\r\n * @param spread 原始Spread对象\r\n * @param fileName 导出的文件名称,不传则为第一个工作表的名称\r\n */\r\n exportToExcel: (GC: any, spread: any, fileName: string = \"\") => {\r\n // 导出模板为JSON对象,此处设置了参数includeBindingSource,改参数代表包含数据绑定的值\r\n const json = spread.toJSON({ includeBindingSource: true });\r\n\r\n // 需要移除的自定义公式名称集合(该变量的作用是,在导出Excel前,将工作簿中所有的自定义公式移除掉,其他内置的公式保留)\r\n const removeCustomFormulas = [\r\n \"YJMAX\",\r\n \"YJMIN\",\r\n \"YJMID\",\r\n \"YJGETNUM\",\r\n \"YJGETS\",\r\n \"YJGETCV\",\r\n \"YJINTERPOLATIONMETHOD\",\r\n \"YJINTERPOLATIONMETHOD_Y\",\r\n ];\r\n\r\n // 临时工作簿\r\n const tempSpread = new GC.Spread.Sheets.Workbook();\r\n tempSpread.fromJSON(json);\r\n\r\n // 暂停绘制\r\n tempSpread.suspendPaint();\r\n\r\n // 获取Sheet数量\r\n const sheetCount = tempSpread.getSheetCount();\r\n\r\n for (let iSheet = 0; iSheet < sheetCount; iSheet++) {\r\n // 当前工作表\r\n const sheet = tempSpread.getSheet(iSheet);\r\n\r\n // 暂停公式的计算,提高性能\r\n sheet.suspendCalcService();\r\n\r\n for (var i = 0; i < sheet.getRowCount(); i++) {\r\n for (var j = 0; j < sheet.getColumnCount(); j++) {\r\n // 获取单元格的公式\r\n const cellFormula = sheet.getFormula(i, j);\r\n\r\n // 如果cellFormula不为null或undefined,则说明该单元格引用了公式\r\n if (\r\n cellFormula != null &&\r\n cellFormula != undefined &&\r\n removeCustomFormulas.some((item) => cellFormula.indexOf(item) > -1)\r\n ) {\r\n // 获取单元格的值\r\n const cellVal = sheet.getValue(i, j);\r\n\r\n // 移除单元格引用的公式\r\n sheet.getCell(i, j).formula(undefined);\r\n\r\n // 设置单元格的值\r\n sheet.setValue(i, j, cellVal);\r\n }\r\n }\r\n }\r\n\r\n // 恢复计算\r\n sheet.resumeCalcService(false);\r\n }\r\n\r\n // 恢复绘制\r\n tempSpread.resumePaint();\r\n\r\n if (fileName == \"\") {\r\n fileName = tempSpread.getSheet(0).name();\r\n }\r\n\r\n let options = {\r\n fileType: GC.Spread.Sheets.FileType.excel,\r\n includeBindingSource: true,\r\n includeStyles: true,\r\n includeFormulas: true,\r\n saveAsView: false,\r\n rowHeadersAsFrozenColumns: false,\r\n columnHeadersAsFrozenRows: false,\r\n includeAutoMergedCells: false,\r\n includeCalcModelCache: false,\r\n includeUnusedNames: true,\r\n includeEmptyRegionCells: true,\r\n };\r\n\r\n tempSpread.export(\r\n (blob: any) => {\r\n saveAs(blob, `${fileName}.xlsx`);\r\n },\r\n () => {},\r\n options\r\n );\r\n\r\n // 销毁临时工作簿\r\n tempSpread.destroy();\r\n },\r\n};\r\n"],"names":["CommonUtils","getColLetterName","colIndex","letter","remainder","String","fromCharCode","Math","floor","toUpperCase","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","apply","SuppressedError","EChartsUtilsComm","getRound","roundingVal","accuracy","valIsNegative","abs","inputValStr","toString","indexOf","intVal","parseInt","split","decimalStr","parseFloat","coefficient","retNum","inputVal","decimalStrFirst","substring","length","calcRoundingRet","Number","toFixed","accuracyStr","retNumStr","zeroStr","index","xsPart","calcTrend","x","y","xVal","n","sumX","sumY","sumXY","sumXX","i","slope","intercept","gs","xl","jj","filterNullEmptyErrArray","dataSource","filter","item","undefined","_error","EChartsUtilsAll","chart10","config","xDataArr","yDataArr","sheet","lineJson","JSON","parse","chartLinesJson","chartExtJson","xDataSource","yDataSource","dxsJs","xData","yData","forEach","test","push","xMin","min","xMax","max","yMin","yMax","xAxisMax","xAxisMin","yAxisMax","yAxisMin","seriesData","points","A","N","matrix","row","j","math","pow","vandermondeMatrix","AT","transpose","ATA","multiply","ATb","coefficients","lusolve","valueOf","err","funequation","arrX","arrY","temp","maxIndex","findIndex","xName","chartXName","yName","chartYName","includes","symbol","peakvalue","coordX","lqhhlKs","setValue","col","lqhhlJs","lqhhlSc1","lineData","pointData","coord","lineStyle","color","type","xAxis","yAxis","symbolOffset","label","show","formatter","data","itemStyle","yValIsAllNull","every","ele","grid","top","left","right","bottom","containLabel","tooltip","trigger","datas","ticket","seriesName","title","text","textStyle","fontSize","fontWeight","legend","selected","legendName","selectedMode","axisTick","alignWithLabel","splitLine","name","nameGap","nameRotate","nameLocation","axisLine","series","smooth","symbolSize","lineColor","markPoint","markLine","width","chart11","ceil","upperLimit","lowerLimit","lqhhlSx","curVal","getValue","lqhhlXx","ifHaveIntersectionPoint","y1","y2","y3","y4","getIntersectionPoint","upperIntersectionPoint","lowerIntersectionPoint","upperIntersectionPointTrend","lowerIntersectionPointTrend","index1","validX1","validX2","chart12","avg","avgXIndex","chart13","chart14","chart15","chart16","lines","lqhhlHz","yAxisData","map","isNaN","lqhhlSc2","axisLabel","chart30","jsIsJz","isTwoLine","xDataSource1","xDataSource2","yDataSource1","yDataSource2","chartTitle","lineFunc","isShowMarkPoint","isShowMarkLine","isTwoLineData","cellValJzZjhsl","cellValJzZdgmd","trunc","jsZjhslJz","jsZdgmdJz","outJdZjhsl","outJdZdgmd","outValZjhsl","outValZdgmd","jsZjhslJd","jsZdgmdJd","jsZjhsl","jsZdgmd","coordY","markPointObj","markLineObj","seriesDataObj","maxPointData","lineObj2","maxPointDataX","maxPointDataY","lineObj1","chart50","xDataSourceOld","yDataSourceOld","yDataSourceSxOld","yDataSourceXxOld","allData","ySx","yXx","sort","a","b","yDataSourceSx","yDataSourceXx","sxValNullCount","xDataSx","xDataXx","markLineData","val045","getLineObj","lineType","obj","z","connectNulls","silent","position","nullCount","some","xObj","splitNumber","chart70","ztzl","cllx","logx","logy","curZtzl","jxhslZtzl","curCllx","jxhslCllx","item1","log","item2","abk","ack","dropName","getYOnLine","point1","point2","point3X","logX1","logY1","logX2","logY","exp","zero_ab","zero_ac","HpCoordinates","wl","hp","scHp","scWl","scWp","point_hp","Dy","Dylog","hp0_xab","hp0_xac","hp0_xcenter","Dxlog","adk","wly","wlx","wpy","wpx","wp","hpy2","hpylog2","hp0_xab2","hp0_xac2","hp0_xcenter2","outJdHp","outJdWl","outJdWp","jxhslScHpJd","jxhslScWlJd","jxhslScWpJd","jxhslScHp","jxhslScWl","jxhslScWp","interval","param","minMargin","chart90","xDataCl","yDataSourceCl","markPointData","gsS","jxhslSnShScfc","yDataCopy","curYData","eval","replace","option","opacity","val","chart110","xDataArrSource","yDataArrSource","curXName","chart130","logBase","inverse","chart150","chart170","chart190","_code","chart210","arr","uniqueData","self","t","getXline","chart230","lineCount","xDataSource3","yDataSource3","xData1","xData2","xData3","getHours","getMinutes","curArr","curItemMins","unshift","getxAxisObj","xAxisData","legendData","legendSelected","xValIsAllNull","topmargin","chart250","xmin","xmax","chart270","chart279_280_281","jjNum","chartType","chart290","chart310","yDataCl","chart330","wd015","wd019","wd025","wd031","Infinity","wdBh","wdYs","bszdjBh","bszdjYs","chart350","jsN","hsl","yVal1","yVal2","yVal25","isAllNull","seriesObjs","EChartsUtils","create","GC_1","spread_1","sheet_1","config_1","args_1","GC","spread","isHideChart","isShowCon","isShowVal","floatingObjects","remove","chartId","allRowsTotalHeight","allRowsTotalWidth","allRowsTotalLeft","chartCellHeight","getRowHeight","Spread","Sheets","SheetArea","colHeader","colCount","getColumnWidth","rowHeader","rowCount","fObjPosition","w","h","fcObj","get","FloatingObjects","FloatingObject","allowResize","allowMove","add","height","document","getElementById","divObj","createElement","setAttribute","innerHTML","content","ecObj","setTimeout","initChart","fObj","getCellVals","sheetName","cells","retArr","dataOneArr","dataOneSourceArr","curSheet","getSheetFromName","itemCell","indexCell","curCellVal","xDataOne","yDataOne","xDataOneSource","yDataOneSource","curItemValsX","sheetNameX","xCells","curItemValsY","sheetNameY","yCells","ecDom","echarts","getInstanceByDom","init","renderer","useDirtyRect","animation","setOption","getEChartsObj","SheetUtils","getActiveSheetSelectCells","getActiveSheet","getSelections","setActiveSheetSelectCells","cellObj","setSelection","getAllCellObjsByRanges","selectRanges","isMulColOrder","allCellObjs","getSpans","itemSpanCell","Error","getSpan","orderByJson","getSheetAllCellObjs","curSheetCellRange","getRowCount","getColumnCount","getSheetSelectCellObjs","getActiveSheetSelectCellObjs","getSheetSelectVals","nullUndefinedReplaceVal","selectCells","selectCellVals","cell","cellVal","getActiveSheetSelectVals","getCellType","cellTypeName","cellType","CellTypes","Button","RadioButtonList","CheckBox","CheckBoxList","HyperLink","ComboBox","cellStyle","getStyle","cellButtons","command","dropDowns","showDateRange","setSheetZoom","scale","suspendPaint","sheetCount","getSheetCount","getSheet","zoom","resumePaint","setActiveSheetSelectBgColor","sel","getRange","backColor","setSheetBgColor","setSheetShowPrintPageLine","isShow","isPrintLineVisible","ignoreSheetShowStrs","ignoreStrs","ignorePaint","Text","prototype","paint","ctx","style","options","call","this","arguments","setSheetAuxiliaryLine","lineWidth","colorStr","isHb","floatBottom","floatRight","divBottom","divRight","borderBottom","borderLeft","setActiveSheetWatermark","getCell","watermark","setBindingPath","pathPrev","pathField","setSheetCellDate","isAutoSize","Style","imageType","ButtonImageType","dropdown","DropDownType","dateTimePicker","showTime","dateFormat","shrinkToFit","setStyle","WorkbookUtils","print","printInfo","showRowHeader","Print","PrintVisibilityType","hide","showColumnHeader","rowStart","rowEnd","columnStart","columnEnd","margin","header","footer","paperSize","PaperSize","PaperKind","a4","exportToExcel","fileName","json","toJSON","includeBindingSource","removeCustomFormulas","tempSpread","Workbook","fromJSON","iSheet","suspendCalcService","cellFormula","getFormula","formula","resumeCalcService","fileType","FileType","excel","includeStyles","includeFormulas","saveAsView","rowHeadersAsFrozenColumns","columnHeadersAsFrozenRows","includeAutoMergedCells","includeCalcModelCache","includeUnusedNames","includeEmptyRegionCells","export","blob","saveAs","destroy"],"mappings":"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","x_google_ignoreList":[1]}
1
+ {"version":3,"file":"index.cjs.min.js","sources":["../src/utils/common.ts","../node_modules/.pnpm/@rollup+plugin-typescript@1_ccba8aa16c5fc04bbd7ba036697931a3/node_modules/tslib/tslib.es6.js","../src/utils/echarts-all.ts","../src/utils/echarts.ts","../src/utils/sheet.ts","../src/utils/wookbook.ts"],"sourcesContent":["/**\r\n * 公用工具函数属性\r\n */\r\nexport const CommonUtils = {\r\n /**\r\n * 获取列的英文字母\r\n * @param colIndex 列的索引\r\n * @returns 返回英文字母\r\n */\r\n getColLetterName: (colIndex: number): string => {\r\n colIndex += 1;\r\n\r\n let letter = \"\";\r\n while (colIndex > 0) {\r\n const remainder = (colIndex - 1) % 26;\r\n letter = String.fromCharCode(remainder + 65) + letter;\r\n colIndex = Math.floor((colIndex - 1) / 26);\r\n }\r\n\r\n return letter.toUpperCase();\r\n },\r\n};\r\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","import * as math from 'mathjs';\r\nimport { type EChartsUtilsConfigModel } from '../types/echarts';\r\n\r\n/**\r\n * 公用方法,如:修约计算等\r\n */\r\nconst EChartsUtilsComm = {\r\n /**\r\n * 计算常规修约\r\n * @param roundingVal 修约值\r\n * @param accuracy 修约精度\r\n * @return 返回修约结果\r\n */\r\n getRound: (roundingVal, accuracy) => {\r\n // 验证修约的值是否为负数,为负数的话,取绝对值进行修约\r\n const valIsNegative = roundingVal < 0;\r\n if (valIsNegative) {\r\n roundingVal = Math.abs(roundingVal);\r\n }\r\n\r\n // 修约精度为0的时候\r\n if (accuracy == 0) {\r\n // 得到字符串形式\r\n let inputValStr = roundingVal.toString();\r\n\r\n // 判断是否有小数点,没有则直接返回换算后的修约值\r\n if (inputValStr.indexOf('.') == -1) {\r\n return valIsNegative ? -roundingVal : roundingVal;\r\n }\r\n\r\n // 获取整数数字部分和小数部分字符串\r\n let intVal = parseInt(inputValStr.split('.')[0]);\r\n let decimalStr = inputValStr.split('.')[1];\r\n\r\n // 小数部分大于或等于0.5的话,就给整数部分加1后返回,否则返回整数部分\r\n if (parseFloat(`0.${decimalStr}`) >= 0.5) {\r\n return valIsNegative ? -(intVal + 1) : intVal + 1;\r\n } else {\r\n return valIsNegative ? -intVal : intVal;\r\n }\r\n }\r\n\r\n // 系数\r\n let coefficient = 1 / accuracy;\r\n\r\n // 换算后的修约值(=修约值*系数)\r\n // 注意:此处使用到了toFixed,目的是可能会存在精度的问题\r\n let roundingValCal = Number((roundingVal * coefficient).toFixed(8));\r\n\r\n /**\r\n * 计算修约结果函数\r\n * @param inputVal 换算后的修约值\r\n * @returns 返回修约结果\r\n */\r\n const calcRoundingRet = (inputVal: number): number => {\r\n // 得到字符串形式\r\n let inputValStr = inputVal.toString();\r\n\r\n // 判断是否有小数点,没有则直接返回换算后的修约值\r\n if (inputValStr.indexOf('.') == -1) {\r\n return inputVal;\r\n }\r\n\r\n // 获取整数数字部分和小数部分字符串\r\n let intVal = parseInt(inputValStr.split('.')[0]);\r\n let decimalStr = inputValStr.split('.')[1];\r\n\r\n // 获取小数部分的第一位数字\r\n let decimalStrFirst = parseInt(decimalStr.substring(0, 1));\r\n\r\n // 大于等于6的时候,入\r\n if (decimalStrFirst >= 6) {\r\n return intVal + 1;\r\n }\r\n // 小于等于4的时候,舍\r\n else if (decimalStrFirst <= 4) {\r\n return intVal;\r\n }\r\n\r\n // 小数部分为5,并且只有一位小数的时候,前面的整数部分如果是奇数则入,反之则舍\r\n else if (decimalStrFirst == 5 && decimalStr.length == 1) {\r\n return intVal % 2 != 0 ? intVal + 1 : intVal;\r\n }\r\n\r\n // 小数部分为5,并且小数位数大于一位的时候,则入\r\n else if (decimalStrFirst == 5 && decimalStr.length > 1) {\r\n return intVal + 1;\r\n }\r\n\r\n return inputVal;\r\n };\r\n\r\n // 返回最终修约结果(=修约结果/系数)\r\n const retNum = calcRoundingRet(roundingValCal) / coefficient;\r\n\r\n //获取修约精度中的小数位数\r\n let accuracyStr = accuracy + '';\r\n\r\n // 如果修约精度中没有小数,则直接返回\r\n if (accuracyStr.indexOf('.') == -1) {\r\n return valIsNegative ? -retNum : retNum;\r\n } else {\r\n const retNumStr = retNum + '';\r\n\r\n // 补位的0的字符串\r\n let zeroStr = '';\r\n\r\n // 结果为整数的时候,需要补充小数点后面的小数位数为0,如:34→34.0\r\n if (retNumStr.indexOf('.') == -1) {\r\n let zeroStr = '';\r\n for (let index = 0; index < accuracyStr.split('.')[1].length; index++) {\r\n zeroStr += '0';\r\n }\r\n\r\n return (valIsNegative ? '-' : '') + `${retNum}.${zeroStr}`;\r\n }\r\n // 结果为小数的时候,需要补充修约精度的位数,如:0.3修约精度为0.01,则最终应该返回0.30\r\n else {\r\n const xsPart = retNumStr.split('.')[1];\r\n\r\n if (accuracyStr.split('.')[1].length > xsPart.length) {\r\n for (let index = 0; index < accuracyStr.split('.')[1].length - xsPart.length; index++) {\r\n zeroStr += '0';\r\n }\r\n }\r\n\r\n return (valIsNegative ? '-' : '') + `${retNum}${zeroStr}`;\r\n }\r\n }\r\n },\r\n /**\r\n * 实现Excel中TREND(返回线性回归拟合线的一组纵坐标值[y值])公式的计算\r\n * @param x x轴数据集合\r\n * @param y y轴数据集合\r\n * @param xVal x轴的值\r\n * @returns\r\n */\r\n calcTrend: (x: Array<number>, y: Array<number>, xVal: number) => {\r\n let n = x.length;\r\n let sumX = 0,\r\n sumY = 0,\r\n sumXY = 0,\r\n sumXX = 0;\r\n for (let i = 0; i < n; i++) {\r\n sumX += x[i];\r\n sumY += y[i];\r\n sumXY += x[i] * y[i];\r\n sumXX += x[i] * x[i];\r\n }\r\n let slope = (n * sumXY - sumX * sumY) / (n * sumXX - sumX * sumX);\r\n let intercept = (sumY - slope * sumX) / n;\r\n\r\n let predictedY = slope * xVal + intercept;\r\n\r\n if (slope + '' == 'NaN') {\r\n return { y: '', gs: '', xl: '', jj: '' };\r\n }\r\n\r\n //返回y轴趋势数据,以及公式\r\n return { y: predictedY, gs: `${slope}*x+${intercept}`, xl: slope, jj: intercept };\r\n },\r\n /**\r\n * 过滤掉数组中的null、空字符串或/符号等,并返回新的数组\r\n * @param dataSource 原始数组\r\n */\r\n filterNullEmptyErrArray: (dataSource: Array<any>) => {\r\n let retArr = dataSource.filter((item) => item != null && item != undefined && (item._error == null || item._error == undefined) && item != '/');\r\n\r\n return retArr;\r\n },\r\n};\r\n\r\n/**\r\n * 所有统计图表的ECharts配置\r\n */\r\nexport const EChartsUtilsAll = {\r\n /**\r\n * 沥青混合料-目标配合比设计-毛体积密度\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart10: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineJson = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n let xDataSource = xDataArr[0],\r\n yDataSource = yDataArr[0];\r\n\r\n // 原始数据\r\n let dxsJs = chartExtJson != null ? chartExtJson.dxsJs : 5,\r\n xData: any[] = [],\r\n yData: any[] = [];\r\n\r\n // 处理原始数据为空的值,不然参与mathjs计算会报错\r\n xDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n xData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n xData.push(item);\r\n }\r\n }\r\n });\r\n yDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n yData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n yData.push(item);\r\n }\r\n }\r\n });\r\n\r\n // y轴没有任何数据的时候,不参与绘制图表\r\n if (yData.length == 0) {\r\n return;\r\n }\r\n\r\n // 检查x轴的数据有多少个0,大于1个的时候,就不绘制图形\r\n let zeroCount = 0;\r\n xData.forEach((item) => {\r\n if (item == 0) {\r\n zeroCount++;\r\n }\r\n });\r\n // if (zeroCount > 1) {\r\n // \treturn;\r\n // }\r\n\r\n if (dxsJs >= yData.length) {\r\n dxsJs = yData.length - 1;\r\n }\r\n\r\n let xMin = Math.min(...xData),\r\n xMax = Math.max(...xData),\r\n yMin = Math.min(...yData),\r\n yMax = Math.max(...yData),\r\n /*xAxisMax = 5.5,\r\n xAxisMin = 3.5,\r\n yAxisMax = 2.35,\r\n yAxisMin = 2.25,\r\n */\r\n xAxisMax = xMax,\r\n xAxisMin = xMin,\r\n yAxisMax = Number(EChartsUtilsComm.getRound(yMax + 0.05, 0.01)),\r\n yAxisMin = Number(EChartsUtilsComm.getRound(yMin - 0.05, 0.01)),\r\n seriesData = [],\r\n upperLimit = null, // 上限\r\n lowerLimit = null,\r\n showLine = true; // 是否显示辅助线\r\n\r\n let points: any = [];\r\n xData.forEach((item, index) => {\r\n points.push([item, yData[index]]);\r\n });\r\n\r\n // 构造范德蒙德矩阵的函数\r\n function vandermondeMatrix(x, N) {\r\n const matrix = [];\r\n for (let i = 0; i < x.length; i++) {\r\n const row = [];\r\n for (let j = 0; j <= N; j++) {\r\n // 注意这里从0到N,包含N\r\n row.push(math.pow(x[i], j));\r\n }\r\n matrix.push(row);\r\n }\r\n return math.matrix(matrix);\r\n }\r\n\r\n // 构造原始的范德蒙德矩阵\r\n const vandermonde_matrix = vandermondeMatrix(xData, dxsJs); // 注意这里N=4,因为我们从0开始计数\r\n\r\n // 使用最小二乘法求解\r\n const A = vandermonde_matrix;\r\n const AT = math.transpose(A);\r\n const ATA = math.multiply(AT, A);\r\n const ATb = math.multiply(AT, math.matrix(yData));\r\n\r\n // 解线性方程组\r\n // const result = math.lusolve(ATA, ATb);\r\n // const coefficients = result.valueOf();\r\n\r\n let result: any = null,\r\n coefficients: any = [];\r\n try {\r\n result = math.lusolve(ATA, ATb);\r\n coefficients = result.valueOf();\r\n } catch (err) {\r\n for (let index = 0; index < xData.length; index++) {\r\n coefficients.push([0]);\r\n }\r\n console.log('无法解决该线性系统');\r\n }\r\n\r\n function funequation(x) {\r\n let y = 0;\r\n coefficients.forEach((item, index) => {\r\n //fx^0\r\n //fx^0+ax^1\r\n //fx^0+ax^1+bx^2\r\n //fx^0+ax^1+bx^2+cx^3\r\n //fx^0+x^1+x^2+x^3+x^4\r\n y += item * x ** index;\r\n });\r\n return y;\r\n }\r\n // console.log('计算公式:', coefficients);\r\n\r\n function lagrangeInterpolation(points, x) {\r\n let result = 0;\r\n for (let i = 0; i < points.length; i++) {\r\n let term = points[i][1];\r\n let xi = points[i][0];\r\n for (let j = 0; j < points.length; j++) {\r\n if (j !== i) {\r\n let xj = points[j][0];\r\n term *= (x - xj) / (xi - xj);\r\n }\r\n }\r\n result += term;\r\n }\r\n return result;\r\n }\r\n let arrX = [];\r\n let arrY = [];\r\n for (let i = xMin; i <= xMax; i += 0.01) {\r\n let temp = Number(EChartsUtilsComm.getRound(i, 0.01));\r\n //arrY.push(lagrangeInterpolation(points, temp));\r\n arrY.push(funequation(temp));\r\n arrX.push(temp);\r\n }\r\n let max = Math.max(...arrY);\r\n\r\n // 找到最大值的索引\r\n let maxIndex = arrY.findIndex((value) => value === max);\r\n\r\n // console.log('最大点数据:', arrX[maxIndex], max);\r\n\r\n let title = '', // config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n arrX.forEach((item, index) => {\r\n if (xData.includes(item)) {\r\n seriesData.push({ value: [item, arrY[index]] });\r\n } else {\r\n seriesData.push({\r\n value: [item, arrY[index]],\r\n symbol: 'none',\r\n });\r\n }\r\n });\r\n // 计算峰值\r\n const peakvalue = [arrX[maxIndex], Number(EChartsUtilsComm.getRound(max, 0.001))],\r\n coordX = [peakvalue[0], yAxisMin];\r\n\r\n // console.log('x范围:', xMin, xMax);\r\n // 输出开始和结束范围\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlKs != null && chartExtJson.lqhhlKs != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlKs.row, chartExtJson.lqhhlKs.col, xMin);\r\n sheet.setValue(chartExtJson.lqhhlJs.row, chartExtJson.lqhhlJs.col, xMax);\r\n }\r\n if (chartExtJson.lqhhlSc1 != null && chartExtJson.lqhhlSc1 != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlSc1.row, chartExtJson.lqhhlSc1.col, arrX[maxIndex]);\r\n }\r\n }\r\n\r\n let lineData = [];\r\n let pointData = [];\r\n if (showLine) {\r\n lineData = [\r\n [\r\n {\r\n coord: coordX,\r\n lineStyle: {\r\n color: '#333', // X轴\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: peakvalue,\r\n },\r\n ],\r\n ];\r\n pointData = [\r\n {\r\n xAxis: peakvalue[0],\r\n yAxis: peakvalue[1],\r\n symbolOffset: [0, 15],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n if (Number(data.data.xAxis) == 0 && Number(data.data.yAxis) == 0) {\r\n return '';\r\n } else {\r\n return '( ' + data.data.xAxis + ',' + data.data.yAxis + ')';\r\n }\r\n //return '( ' + data.data.xAxis + ',' + data.data.yAxis + ')';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n {\r\n xAxis: peakvalue[0],\r\n yAxis: yAxisMin,\r\n symbolOffset: [0, 40],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n return 'a1';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n ];\r\n }\r\n\r\n // 判断数据是否为/\r\n let yValIsAllNull = false;\r\n seriesData.forEach((item) => {\r\n yValIsAllNull = item.value.every((ele) => {\r\n return ele == 0;\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,// 是否显示外边框线\r\n // borderColor: '#f00',// 外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: !yValIsAllNull ? 16 : 20,\r\n containLabel: true,\r\n },\r\n // 提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n //console.log(datas,\" datas\")\r\n return datas && datas.length > 0\r\n ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + Number(EChartsUtilsComm.getRound(datas[0].value[1], 0.001))\r\n : datas[0].data;\r\n },\r\n },\r\n // 顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n // 图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, // 显示\r\n },\r\n selectedMode: 'multiple', // 用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, // 使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 40 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', // '#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n // splitNumber: 10, // 设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n // 设置y轴箭头效果\r\n show: true, // y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, // 平滑的线条\r\n // 设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', // 符号类型\r\n symbolSize: 6, // 符号大小 lineJson.lineColor\r\n // 线条的颜色\r\n lineStyle: {\r\n color: lineJson[0].lineColor,\r\n // 线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n // 线条上数据点的颜色\r\n itemStyle: {\r\n color: lineJson[0].lineColor,\r\n },\r\n data: seriesData,\r\n markPoint: {\r\n data: pointData,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'], // 去掉箭头\r\n itemStyle: {\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n width: 2,\r\n },\r\n },\r\n data: lineData,\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 沥青混合料-目标配合比设计-稳定度\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart11: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineJson = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n let xDataSource = xDataArr[0],\r\n yDataSource = yDataArr[0];\r\n\r\n // 原始数据\r\n let dxsJs = chartExtJson != null ? chartExtJson.dxsJs : 5,\r\n xData = [],\r\n yData = [];\r\n\r\n // 处理原始数据为空的值,不然参与mathjs计算会报错\r\n xDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n xData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n xData.push(item);\r\n }\r\n }\r\n });\r\n yDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n yData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n yData.push(item);\r\n }\r\n }\r\n });\r\n\r\n // y轴没有任何数据的时候,不参与绘制图表\r\n if (yData.length == 0) {\r\n return;\r\n }\r\n\r\n // 检查x轴的数据有多少个0,大于1个的时候,就不绘制图形\r\n let zeroCount = 0;\r\n xData.forEach((item) => {\r\n if (item == 0) {\r\n zeroCount++;\r\n }\r\n });\r\n // if (zeroCount > 1) {\r\n // \treturn;\r\n // }\r\n\r\n if (dxsJs >= yData.length) {\r\n dxsJs = yData.length - 1;\r\n }\r\n\r\n let xMin = Math.min(...xData),\r\n xMax = Math.max(...xData),\r\n yMin = Math.min(...yData),\r\n yMax = Math.max(...yData),\r\n xAxisMax = xMax,\r\n xAxisMin = xMin,\r\n yAxisMax = Math.ceil(yMax + 2),\r\n yAxisMin = Math.floor(yMin - 2),\r\n seriesData = [],\r\n upperLimit = null, // 上限\r\n lowerLimit = 7.5, // 下限\r\n showLine = true; // 是否显示辅助线\r\n\r\n // 获取单元格中的上限和下限\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSx != null && chartExtJson.lqhhlSx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlSx.row, chartExtJson.lqhhlSx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n upperLimit = curVal;\r\n }\r\n }\r\n if (chartExtJson.lqhhlXx != null && chartExtJson.lqhhlXx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlXx.row, chartExtJson.lqhhlXx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n lowerLimit = curVal;\r\n }\r\n }\r\n }\r\n\r\n if (upperLimit != null && upperLimit > yAxisMax) {\r\n yAxisMax = upperLimit + 2;\r\n }\r\n if (lowerLimit != null && lowerLimit > yAxisMax) {\r\n yAxisMin = lowerLimit - 2;\r\n }\r\n\r\n let points = [];\r\n xData.forEach((item, index) => {\r\n points.push([item, yData[index]]);\r\n });\r\n\r\n // 构造范德蒙德矩阵的函数\r\n function vandermondeMatrix(x, N) {\r\n const matrix = [];\r\n for (let i = 0; i < x.length; i++) {\r\n const row = [];\r\n for (let j = 0; j <= N; j++) {\r\n // 注意这里从0到N,包含N\r\n row.push(math.pow(x[i], j));\r\n }\r\n matrix.push(row);\r\n }\r\n return math.matrix(matrix);\r\n }\r\n\r\n // 构造原始的范德蒙德矩阵\r\n const vandermonde_matrix = vandermondeMatrix(xData, dxsJs); // 注意这里N=4,因为我们从0开始计数\r\n\r\n // 使用最小二乘法求解\r\n const A = vandermonde_matrix;\r\n const AT = math.transpose(A);\r\n const ATA = math.multiply(AT, A);\r\n const ATb = math.multiply(AT, math.matrix(yData));\r\n\r\n // 解线性方程组\r\n // const result = math.lusolve(ATA, ATb);\r\n // const coefficients = result.valueOf();\r\n\r\n let result: any = null,\r\n coefficients: any = [];\r\n try {\r\n result = math.lusolve(ATA, ATb);\r\n coefficients = result.valueOf();\r\n } catch (err) {\r\n for (let index = 0; index < xData.length; index++) {\r\n coefficients.push([0]);\r\n }\r\n console.log('无法解决该线性系统');\r\n }\r\n\r\n function funequation(x) {\r\n let y = 0;\r\n coefficients.forEach((item, index) => {\r\n //fx^0\r\n //fx^0+ax^1\r\n //fx^0+ax^1+bx^2\r\n //fx^0+ax^1+bx^2+cx^3\r\n //fx^0+x^1+x^2+x^3+x^4\r\n y += item * x ** index;\r\n });\r\n return y;\r\n }\r\n\r\n // console.log('计算公式:', coefficients);\r\n\r\n function lagrangeInterpolation(points, x) {\r\n let result = 0;\r\n for (let i = 0; i < points.length; i++) {\r\n let term = points[i][1];\r\n let xi = points[i][0];\r\n for (let j = 0; j < points.length; j++) {\r\n if (j !== i) {\r\n let xj = points[j][0];\r\n term *= (x - xj) / (xi - xj);\r\n }\r\n }\r\n result += term;\r\n }\r\n return result;\r\n }\r\n let arrX = [];\r\n let arrY = [];\r\n for (let i = xMin; i <= xMax; i += 0.01) {\r\n let temp = Number(EChartsUtilsComm.getRound(i, 0.01));\r\n // arrY.push(lagrangeInterpolation(points, temp));\r\n arrY.push(funequation(temp));\r\n arrX.push(temp);\r\n }\r\n let max = Math.max(...arrY);\r\n\r\n // 找到最大值的索引\r\n let maxIndex = arrY.findIndex((value) => value === max);\r\n\r\n // console.log('最大点数据:', arrX[maxIndex], max);\r\n\r\n let title = '', // config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n arrX.forEach((item, index) => {\r\n if (xData.includes(item)) {\r\n seriesData.push({ value: [item, arrY[index]] });\r\n } else {\r\n seriesData.push({\r\n value: [item, arrY[index]],\r\n symbol: 'none',\r\n });\r\n }\r\n });\r\n\r\n // 计算两条线段是否有交点\r\n function ifHaveIntersectionPoint(y1, y2, y3, y4) {\r\n if ((y1 >= y3 && y2 <= y4) || (y1 <= y3 && y2 >= y4)) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n // 获取两点和香交线最接近的点\r\n function getIntersectionPoint(y1, y2, y) {\r\n if (Math.abs(y1 - y) > Math.abs(y2 - y)) {\r\n return 0;\r\n }\r\n return -1;\r\n }\r\n let upperIntersectionPoint = [],\r\n lowerIntersectionPoint = [];\r\n let upperIntersectionPointTrend = []; // 上限交点趋势(向上相交(1) 还是向下相交(0))\r\n let lowerIntersectionPointTrend = []; // 下限交点趋势\r\n arrX.forEach((item, index) => {\r\n if (index > 0) {\r\n // 上限交点\r\n if (upperLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], upperLimit, upperLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], upperLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n upperIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n // 向下趋势\r\n upperIntersectionPointTrend.push(0);\r\n } else {\r\n upperIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n // 下限交点\r\n if (lowerLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit, lowerLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n lowerIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n // 向下趋势\r\n lowerIntersectionPointTrend.push(0);\r\n } else {\r\n lowerIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n let validX1 = xMin,\r\n validX2 = xMax;\r\n if (upperIntersectionPoint.length == 0 && lowerIntersectionPoint.length > 0) {\r\n // 上限无交点,下限有交点\r\n if (lowerIntersectionPointTrend[0] == 0) {\r\n // 下限向下相交\r\n validX1 = xMin;\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n // 下限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n if (lowerIntersectionPoint.length == 1) {\r\n // 只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = lowerIntersectionPoint[1][0];\r\n }\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length == 0) {\r\n // 上限有交点,下限无交点\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n // 上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n if (upperIntersectionPoint.length == 1) {\r\n // 只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = upperIntersectionPoint[1][0];\r\n }\r\n } else {\r\n // 上限向上相交\r\n validX1 = xMin;\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length > 0) {\r\n // 上下限都有交点,情况太多,我们只取中间\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n // 上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n // 上限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n }\r\n\r\n // console.log('x范围:', validX1, validX2);\r\n // 输出开始和结束范围\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlKs != null && chartExtJson.lqhhlKs != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlKs.row, chartExtJson.lqhhlKs.col, validX1);\r\n sheet.setValue(chartExtJson.lqhhlJs.row, chartExtJson.lqhhlJs.col, validX2);\r\n }\r\n if (chartExtJson.lqhhlSc1 != null && chartExtJson.lqhhlSc1 != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlSc1.row, chartExtJson.lqhhlSc1.col, arrX[maxIndex]);\r\n }\r\n }\r\n\r\n // 峰值\r\n const peakvalue = [arrX[maxIndex], Number(EChartsUtilsComm.getRound(max, 0.001))];\r\n\r\n let lineData = [];\r\n let pointData = [];\r\n if (showLine) {\r\n lineData = [\r\n [\r\n {\r\n coord: [peakvalue[0], yAxisMin],\r\n lineStyle: {\r\n color: '#333', // X轴\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: peakvalue,\r\n },\r\n ],\r\n ];\r\n pointData = [\r\n {\r\n xAxis: peakvalue[0],\r\n yAxis: peakvalue[1],\r\n symbolOffset: [0, 15],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n if (Number(data.data.xAxis) == 0 && Number(data.data.yAxis) == 0) {\r\n return '';\r\n } else {\r\n return '( ' + data.data.xAxis + ',' + data.data.yAxis + ')';\r\n }\r\n //return '( ' + data.data.xAxis + ',' + data.data.yAxis + ')';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n {\r\n xAxis: peakvalue[0],\r\n yAxis: yAxisMin,\r\n symbolOffset: [0, 40],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n return 'a2';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n ];\r\n }\r\n\r\n if (upperLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, upperLimit],\r\n lineStyle: {\r\n color: '#333', //上限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, upperLimit],\r\n },\r\n ]);\r\n }\r\n\r\n if (lowerLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, lowerLimit],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, lowerLimit],\r\n },\r\n ]);\r\n }\r\n\r\n //判断数据是否为/\r\n let yValIsAllNull = false;\r\n seriesData.forEach((item) => {\r\n yValIsAllNull = item.value.every((ele) => {\r\n return ele == 0;\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: !yValIsAllNull ? 16 : 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n //console.log(datas,\" datas\")\r\n return datas && datas.length > 0\r\n ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + Number(EChartsUtilsComm.getRound(datas[0].value[1], 0.001))\r\n : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineJson[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineJson[0].lineColor,\r\n },\r\n data: seriesData,\r\n markPoint: {\r\n data: pointData,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'], //去掉箭头\r\n itemStyle: {\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n width: 2,\r\n },\r\n },\r\n data: lineData,\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 沥青混合料-目标配合比设计-空隙率\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart12: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineJson = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n let xDataSource = xDataArr[0], // [3.5, 4, 4.5, 5, 5.5],\r\n yDataSource = yDataArr[0]; // [8.8, 5.9, 4.1, 3.3, 2.6];\r\n\r\n //原始数据\r\n let dxsJs = chartExtJson != null ? chartExtJson.dxsJs : 5,\r\n xData = [],\r\n yData = [];\r\n\r\n //处理原始数据为空的值,不然参与mathjs计算会报错\r\n xDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n xData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n xData.push(item);\r\n }\r\n }\r\n });\r\n yDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n yData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n yData.push(item);\r\n }\r\n }\r\n });\r\n\r\n //y轴没有任何数据的时候,不参与绘制图表\r\n if (yData.length == 0) {\r\n return;\r\n }\r\n\r\n //检查x轴的数据有多少个0,大于1个的时候,就不绘制图形\r\n let zeroCount = 0;\r\n xData.forEach((item) => {\r\n if (item == 0) {\r\n zeroCount++;\r\n }\r\n });\r\n // if (zeroCount > 1) {\r\n // \treturn;\r\n // }\r\n\r\n if (dxsJs >= yData.length) {\r\n dxsJs = yData.length - 1;\r\n }\r\n\r\n let xMin = Math.min(...xData),\r\n xMax = Math.max(...xData),\r\n yMin = Math.min(...yData),\r\n yMax = Math.max(...yData),\r\n /*\r\n\t\t\txAxisMax = 5.5,\r\n xAxisMin = 3.5,\r\n yAxisMax = 10,\r\n yAxisMin = 0,\r\n\t\t\t*/\r\n xAxisMax = xMax,\r\n xAxisMin = xMin,\r\n yAxisMax = Math.ceil(yMax + 2),\r\n yAxisMin = Math.floor(yMin - 2),\r\n seriesData = [],\r\n upperLimit = 5, //上限\r\n lowerLimit = 3, //下限\r\n showLine = true; //是否显示辅助线\r\n\r\n //获取单元格中的上限和下限\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSx != null && chartExtJson.lqhhlSx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlSx.row, chartExtJson.lqhhlSx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n upperLimit = curVal;\r\n }\r\n }\r\n if (chartExtJson.lqhhlXx != null && chartExtJson.lqhhlXx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlXx.row, chartExtJson.lqhhlXx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n lowerLimit = curVal;\r\n }\r\n }\r\n }\r\n\r\n if (upperLimit != null && upperLimit > yAxisMax) {\r\n yAxisMax = upperLimit + 2;\r\n }\r\n if (lowerLimit != null && lowerLimit > yAxisMax) {\r\n yAxisMin = lowerLimit - 2;\r\n }\r\n\r\n let points = [];\r\n xData.forEach((item, index) => {\r\n points.push([item, yData[index]]);\r\n });\r\n\r\n // 构造范德蒙德矩阵的函数\r\n function vandermondeMatrix(x, N) {\r\n const matrix = [];\r\n for (let i = 0; i < x.length; i++) {\r\n const row = [];\r\n for (let j = 0; j <= N; j++) {\r\n // 注意这里从0到N,包含N\r\n row.push(math.pow(x[i], j));\r\n }\r\n matrix.push(row);\r\n }\r\n return math.matrix(matrix);\r\n }\r\n\r\n // 构造原始的范德蒙德矩阵\r\n const vandermonde_matrix = vandermondeMatrix(xData, dxsJs); // 注意这里N=4,因为我们从0开始计数\r\n\r\n // 使用最小二乘法求解\r\n const A = vandermonde_matrix;\r\n const AT = math.transpose(A);\r\n const ATA = math.multiply(AT, A);\r\n const ATb = math.multiply(AT, math.matrix(yData));\r\n\r\n // 解线性方程组\r\n // const result = math.lusolve(ATA, ATb);\r\n // const coefficients = result.valueOf();\r\n let result: any = null,\r\n coefficients: any = [];\r\n try {\r\n result = math.lusolve(ATA, ATb);\r\n coefficients = result.valueOf();\r\n } catch (err) {\r\n for (let index = 0; index < xData.length; index++) {\r\n coefficients.push([0]);\r\n }\r\n console.log('无法解决该线性系统');\r\n }\r\n\r\n function funequation(x) {\r\n let y = 0;\r\n coefficients.forEach((item, index) => {\r\n //fx^0\r\n //fx^0+ax^1\r\n //fx^0+ax^1+bx^2\r\n //fx^0+ax^1+bx^2+cx^3\r\n //fx^0+x^1+x^2+x^3+x^4\r\n y += item * x ** index;\r\n });\r\n return y;\r\n }\r\n\r\n // console.log('计算公式:', coefficients);\r\n\r\n function lagrangeInterpolation(points, x) {\r\n let result = 0;\r\n for (let i = 0; i < points.length; i++) {\r\n let term = points[i][1];\r\n let xi = points[i][0];\r\n for (let j = 0; j < points.length; j++) {\r\n if (j !== i) {\r\n let xj = points[j][0];\r\n term *= (x - xj) / (xi - xj);\r\n }\r\n }\r\n result += term;\r\n }\r\n return result;\r\n }\r\n let arrX = [];\r\n let arrY = [];\r\n for (let i = xMin; i <= xMax; i += 0.01) {\r\n let temp = Number(EChartsUtilsComm.getRound(i, 0.01));\r\n //arrY.push(lagrangeInterpolation(points, temp));\r\n arrY.push(funequation(temp));\r\n arrX.push(temp);\r\n }\r\n\r\n let title = '', // config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //计算两条线段是否有交点\r\n function ifHaveIntersectionPoint(y1, y2, y3, y4) {\r\n if ((y1 >= y3 && y2 <= y4) || (y1 <= y3 && y2 >= y4)) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n //获取两点和香交线最接近的点\r\n function getIntersectionPoint(y1, y2, y) {\r\n if (Math.abs(y1 - y) > Math.abs(y2 - y)) {\r\n return 0;\r\n }\r\n return -1;\r\n }\r\n let upperIntersectionPoint = [],\r\n lowerIntersectionPoint = [];\r\n let upperIntersectionPointTrend = []; //上限交点趋势(向上相交(1) 还是向下相交(0))\r\n let lowerIntersectionPointTrend = []; //下限交点趋势\r\n arrX.forEach((item, index) => {\r\n if (xData.includes(item)) {\r\n seriesData.push({ value: [item, arrY[index]] });\r\n } else {\r\n seriesData.push({\r\n value: [item, arrY[index]],\r\n symbol: 'none',\r\n });\r\n }\r\n if (index > 0) {\r\n //上限交点\r\n if (upperLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], upperLimit, upperLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], upperLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n upperIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n upperIntersectionPointTrend.push(0);\r\n } else {\r\n upperIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n //下限交点\r\n if (lowerLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit, lowerLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n lowerIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n lowerIntersectionPointTrend.push(0);\r\n } else {\r\n lowerIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n let validX1 = xMin,\r\n validX2 = xMax;\r\n if (upperIntersectionPoint.length == 0 && lowerIntersectionPoint.length > 0) {\r\n //上限无交点,下限有交点\r\n if (lowerIntersectionPointTrend[0] == 0) {\r\n //下限向下相交\r\n validX1 = xMin;\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //下限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n if (lowerIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = lowerIntersectionPoint[1][0];\r\n }\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length == 0) {\r\n //上限有交点,下限无交点\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n if (upperIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = upperIntersectionPoint[1][0];\r\n }\r\n } else {\r\n //上限向上相交\r\n validX1 = xMin;\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length > 0) {\r\n //上下限都有交点,情况太多,我们只取中间\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //上限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n }\r\n\r\n // console.log('x范围:', validX1, validX2);\r\n //输出开始和结束范围\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlKs != null && chartExtJson.lqhhlKs != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlKs.row, chartExtJson.lqhhlKs.col, validX1);\r\n sheet.setValue(chartExtJson.lqhhlJs.row, chartExtJson.lqhhlJs.col, validX2);\r\n }\r\n }\r\n\r\n let lineData = [];\r\n let pointData = [];\r\n if (showLine) {\r\n if (upperIntersectionPoint.length > 0) {\r\n upperIntersectionPoint.forEach((item, index) => {\r\n lineData.push([\r\n {\r\n coord: [item[0], yAxisMin],\r\n lineStyle: {\r\n color: '#333', //上限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [item[0], upperLimit],\r\n },\r\n ]);\r\n });\r\n }\r\n if (lowerIntersectionPoint.length > 0) {\r\n lowerIntersectionPoint.forEach((item, index) => {\r\n lineData.push([\r\n {\r\n coord: [item[0], yAxisMin],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [item[0], lowerLimit],\r\n },\r\n ]);\r\n });\r\n }\r\n\r\n //上下线交点分别只有一个才求平均值\r\n if (upperIntersectionPoint.length == 1 && lowerIntersectionPoint.length == 1) {\r\n const avg = ((upperIntersectionPoint[0][0] + lowerIntersectionPoint[0][0]) / 2).toFixed(2);\r\n const avgXIndex = arrX.findIndex((n) => n == avg);\r\n // console.log('输出:', avg, avgXIndex);\r\n //输出\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSc1 != null && chartExtJson.lqhhlSc1 != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlSc1.row, chartExtJson.lqhhlSc1.col, avg);\r\n }\r\n }\r\n lineData.push([\r\n {\r\n coord: [avg, yAxisMin],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [avg, arrY[avgXIndex]],\r\n },\r\n ]);\r\n pointData.push({\r\n xAxis: avg,\r\n yAxis: yAxisMin,\r\n symbolOffset: [0, 40],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n return 'a3';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n });\r\n }\r\n }\r\n\r\n if (upperLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, upperLimit],\r\n lineStyle: {\r\n color: '#333', //上限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, upperLimit],\r\n },\r\n ]);\r\n }\r\n\r\n if (lowerLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, lowerLimit],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, lowerLimit],\r\n },\r\n ]);\r\n }\r\n\r\n //判断数据是否为/\r\n let yValIsAllNull = false;\r\n seriesData.forEach((item) => {\r\n yValIsAllNull = item.value.every((ele) => {\r\n return ele == 0;\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: !yValIsAllNull ? 16 : 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n //console.log(datas,\" datas\")\r\n return datas && datas.length > 0\r\n ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + Number(EChartsUtilsComm.getRound(datas[0].value[1], 0.001))\r\n : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineJson[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineJson[0].lineColor,\r\n },\r\n data: seriesData,\r\n markPoint: {\r\n data: pointData,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'], //去掉箭头\r\n itemStyle: {\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n width: 2,\r\n },\r\n },\r\n data: lineData,\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 沥青混合料-目标配合比设计-流值\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart13: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineJson = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n let xDataSource = xDataArr[0], // [3.5, 4, 4.5, 5, 5.5],\r\n yDataSource = yDataArr[0]; // [2.2, 2.5, 2.9, 3.4, 4.2];\r\n\r\n //原始数据\r\n let dxsJs = chartExtJson != null ? chartExtJson.dxsJs : 5,\r\n xData = [],\r\n yData = [];\r\n\r\n //处理原始数据为空的值,不然参与mathjs计算会报错\r\n xDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n xData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n xData.push(item);\r\n }\r\n }\r\n });\r\n yDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n yData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n yData.push(item);\r\n }\r\n }\r\n });\r\n\r\n //y轴没有任何数据的时候,不参与绘制图表\r\n if (yData.length == 0) {\r\n return;\r\n }\r\n\r\n //检查x轴的数据有多少个0,大于1个的时候,就不绘制图形\r\n let zeroCount = 0;\r\n xData.forEach((item) => {\r\n if (item == 0) {\r\n zeroCount++;\r\n }\r\n });\r\n // if (zeroCount > 1) {\r\n // \treturn;\r\n // }\r\n\r\n if (dxsJs >= yData.length) {\r\n dxsJs = yData.length - 1;\r\n }\r\n\r\n let xMin = Math.min(...xData),\r\n xMax = Math.max(...xData),\r\n yMin = Math.min(...yData),\r\n yMax = Math.max(...yData),\r\n /*\r\n xAxisMax = 5.5,\r\n xAxisMin = 3.5,\r\n yAxisMax = 5,\r\n yAxisMin = 1,\r\n\t\t\t*/\r\n xAxisMax = xMax,\r\n xAxisMin = xMin,\r\n yAxisMax = Math.ceil(yMax + 1),\r\n yAxisMin = Math.floor(yMin - 1),\r\n seriesData = [],\r\n upperLimit = null, //上限\r\n lowerLimit = 2, //下限\r\n showLine = true; //是否显示辅助线\r\n\r\n //获取单元格中的上限和下限\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSx != null && chartExtJson.lqhhlSx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlSx.row, chartExtJson.lqhhlSx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n upperLimit = curVal;\r\n }\r\n }\r\n if (chartExtJson.lqhhlXx != null && chartExtJson.lqhhlXx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlXx.row, chartExtJson.lqhhlXx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n lowerLimit = curVal;\r\n }\r\n }\r\n }\r\n\r\n if (upperLimit != null && upperLimit > yAxisMax) {\r\n yAxisMax = upperLimit + 1;\r\n }\r\n if (lowerLimit != null && lowerLimit > yAxisMax) {\r\n yAxisMin = lowerLimit - 1;\r\n }\r\n\r\n let points = [];\r\n xData.forEach((item, index) => {\r\n points.push([item, yData[index]]);\r\n });\r\n\r\n // 构造范德蒙德矩阵的函数\r\n function vandermondeMatrix(x, N) {\r\n const matrix = [];\r\n for (let i = 0; i < x.length; i++) {\r\n const row = [];\r\n for (let j = 0; j <= N; j++) {\r\n // 注意这里从0到N,包含N\r\n row.push(math.pow(x[i], j));\r\n }\r\n matrix.push(row);\r\n }\r\n return math.matrix(matrix);\r\n }\r\n\r\n // 构造原始的范德蒙德矩阵\r\n const vandermonde_matrix = vandermondeMatrix(xData, dxsJs); // 注意这里N=4,因为我们从0开始计数\r\n\r\n // 使用最小二乘法求解\r\n const A = vandermonde_matrix;\r\n const AT = math.transpose(A);\r\n const ATA = math.multiply(AT, A);\r\n const ATb = math.multiply(AT, math.matrix(yData));\r\n\r\n // 解线性方程组\r\n // const result = math.lusolve(ATA, ATb);\r\n // const coefficients = result.valueOf();\r\n\r\n let result: any = null,\r\n coefficients: any = [];\r\n try {\r\n result = math.lusolve(ATA, ATb);\r\n coefficients = result.valueOf();\r\n } catch (err) {\r\n for (let index = 0; index < xData.length; index++) {\r\n coefficients.push([0]);\r\n }\r\n console.log('无法解决该线性系统');\r\n }\r\n\r\n function funequation(x) {\r\n let y = 0;\r\n coefficients.forEach((item, index) => {\r\n //fx^0\r\n //fx^0+ax^1\r\n //fx^0+ax^1+bx^2\r\n //fx^0+ax^1+bx^2+cx^3\r\n //fx^0+x^1+x^2+x^3+x^4\r\n y += item * x ** index;\r\n });\r\n return y;\r\n }\r\n\r\n // console.log('计算公式:', coefficients);\r\n\r\n function lagrangeInterpolation(points, x) {\r\n let result = 0;\r\n for (let i = 0; i < points.length; i++) {\r\n let term = points[i][1];\r\n let xi = points[i][0];\r\n for (let j = 0; j < points.length; j++) {\r\n if (j !== i) {\r\n let xj = points[j][0];\r\n term *= (x - xj) / (xi - xj);\r\n }\r\n }\r\n result += term;\r\n }\r\n return result;\r\n }\r\n let arrX = [];\r\n let arrY = [];\r\n for (let i = xMin; i <= xMax; i += 0.01) {\r\n let temp = Number(EChartsUtilsComm.getRound(i, 0.01));\r\n //arrY.push(lagrangeInterpolation(points, temp));\r\n arrY.push(funequation(temp));\r\n arrX.push(temp);\r\n }\r\n let max = Math.max(...arrY);\r\n\r\n // 找到最大值的索引\r\n let maxIndex = arrY.findIndex((value) => value === max);\r\n\r\n // console.log('最大点数据:', arrX[maxIndex], max);\r\n\r\n let title = '', // config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n arrX.forEach((item, index) => {\r\n if (xData.includes(item)) {\r\n seriesData.push({ value: [item, arrY[index]] });\r\n } else {\r\n seriesData.push({\r\n value: [item, arrY[index]],\r\n symbol: 'none',\r\n });\r\n }\r\n });\r\n\r\n //计算两条线段是否有交点\r\n function ifHaveIntersectionPoint(y1, y2, y3, y4) {\r\n if ((y1 >= y3 && y2 <= y4) || (y1 <= y3 && y2 >= y4)) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n //获取两点和香交线最接近的点\r\n function getIntersectionPoint(y1, y2, y) {\r\n if (Math.abs(y1 - y) > Math.abs(y2 - y)) {\r\n return 0;\r\n }\r\n return -1;\r\n }\r\n let upperIntersectionPoint = [],\r\n lowerIntersectionPoint = [];\r\n let upperIntersectionPointTrend = []; //上限交点趋势(向上相交(1) 还是向下相交(0))\r\n let lowerIntersectionPointTrend = []; //下限交点趋势\r\n arrX.forEach((item, index) => {\r\n if (index > 0) {\r\n //上限交点\r\n if (upperLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], upperLimit, upperLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], upperLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n upperIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n upperIntersectionPointTrend.push(0);\r\n } else {\r\n upperIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n //下限交点\r\n if (lowerLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit, lowerLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n lowerIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n lowerIntersectionPointTrend.push(0);\r\n } else {\r\n lowerIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n let validX1 = xMin,\r\n validX2 = xMax;\r\n if (upperIntersectionPoint.length == 0 && lowerIntersectionPoint.length > 0) {\r\n //上限无交点,下限有交点\r\n if (lowerIntersectionPointTrend[0] == 0) {\r\n //下限向下相交\r\n validX1 = xMin;\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //下限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n if (lowerIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = lowerIntersectionPoint[1][0];\r\n }\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length == 0) {\r\n //上限有交点,下限无交点\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n if (upperIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = upperIntersectionPoint[1][0];\r\n }\r\n } else {\r\n //上限向上相交\r\n validX1 = xMin;\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length > 0) {\r\n //上下限都有交点,情况太多,我们只取中间\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //上限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n }\r\n\r\n // console.log('x范围:', validX1, validX2);\r\n //输出开始和结束范围\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlKs != null && chartExtJson.lqhhlKs != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlKs.row, chartExtJson.lqhhlKs.col, validX1);\r\n sheet.setValue(chartExtJson.lqhhlJs.row, chartExtJson.lqhhlJs.col, validX2);\r\n }\r\n }\r\n\r\n let lineData = [];\r\n let pointData = [];\r\n if (showLine) {\r\n lineData = [];\r\n pointData = [];\r\n }\r\n\r\n if (upperLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, upperLimit],\r\n lineStyle: {\r\n color: '#333', //上限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, upperLimit],\r\n },\r\n ]);\r\n }\r\n\r\n if (lowerLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, lowerLimit],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, lowerLimit],\r\n },\r\n ]);\r\n }\r\n\r\n //判断数据是否为/\r\n let yValIsAllNull = false;\r\n seriesData.forEach((item) => {\r\n yValIsAllNull = item.value.every((ele) => {\r\n return ele == 0;\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: !yValIsAllNull ? 16 : 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n //console.log(datas,\" datas\")\r\n return datas && datas.length > 0\r\n ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + Number(EChartsUtilsComm.getRound(datas[0].value[1], 0.001))\r\n : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 25 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineJson[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineJson[0].lineColor,\r\n },\r\n data: seriesData,\r\n markPoint: {\r\n data: pointData,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'], //去掉箭头\r\n itemStyle: {\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n width: 2,\r\n },\r\n },\r\n data: lineData,\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 沥青混合料-目标配合比设计-矿料间隙率\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart14: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineJson = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n let xDataSource = xDataArr[0], // [3.5, 4, 4.5, 5, 5.5],\r\n yDataSource = yDataArr[0]; // [16.1, 15.2, 14.6, 14.8, 16];\r\n\r\n //原始数据\r\n let dxsJs = chartExtJson != null ? chartExtJson.dxsJs : 5,\r\n xData = [],\r\n yData = [];\r\n\r\n //处理原始数据为空的值,不然参与mathjs计算会报错\r\n xDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n xData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n xData.push(item);\r\n }\r\n }\r\n });\r\n yDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n yData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n yData.push(item);\r\n }\r\n }\r\n });\r\n\r\n //y轴没有任何数据的时候,不参与绘制图表\r\n if (yData.length == 0) {\r\n return;\r\n }\r\n\r\n //检查x轴的数据有多少个0,大于1个的时候,就不绘制图形\r\n let zeroCount = 0;\r\n xData.forEach((item) => {\r\n if (item == 0) {\r\n zeroCount++;\r\n }\r\n });\r\n // if (zeroCount > 1) {\r\n // \treturn;\r\n // }\r\n\r\n if (dxsJs >= yData.length) {\r\n dxsJs = yData.length - 1;\r\n }\r\n\r\n let xMin = Math.min(...xData),\r\n xMax = Math.max(...xData),\r\n yMin = Math.min(...yData),\r\n yMax = Math.max(...yData),\r\n /*\r\n\t\t\txAxisMax = 5.5,\r\n xAxisMin = 3.5,\r\n yAxisMax = 19.0,\r\n yAxisMin = 13.0,\r\n\t\t\t*/\r\n xAxisMax = xMax,\r\n xAxisMin = xMin,\r\n yAxisMax = Math.ceil(yMax + 1),\r\n yAxisMin = Math.floor(yMin - 1),\r\n seriesData = [],\r\n upperLimit = null, //上限\r\n lowerLimit = 13.5, //下限\r\n showLine = true; //是否显示辅助线\r\n\r\n //获取单元格中的上限和下限\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSx != null && chartExtJson.lqhhlSx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlSx.row, chartExtJson.lqhhlSx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n upperLimit = curVal;\r\n }\r\n }\r\n if (chartExtJson.lqhhlXx != null && chartExtJson.lqhhlXx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlXx.row, chartExtJson.lqhhlXx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n lowerLimit = curVal;\r\n }\r\n }\r\n }\r\n\r\n if (upperLimit != null && upperLimit > yAxisMax) {\r\n yAxisMax = upperLimit + 1;\r\n }\r\n if (lowerLimit != null && lowerLimit > yAxisMax) {\r\n yAxisMin = lowerLimit - 1;\r\n }\r\n\r\n let points = [];\r\n xData.forEach((item, index) => {\r\n points.push([item, yData[index]]);\r\n });\r\n\r\n // 构造范德蒙德矩阵的函数\r\n function vandermondeMatrix(x, N) {\r\n const matrix = [];\r\n for (let i = 0; i < x.length; i++) {\r\n const row = [];\r\n for (let j = 0; j <= N; j++) {\r\n // 注意这里从0到N,包含N\r\n row.push(math.pow(x[i], j));\r\n }\r\n matrix.push(row);\r\n }\r\n return math.matrix(matrix);\r\n }\r\n\r\n // 构造原始的范德蒙德矩阵\r\n const vandermonde_matrix = vandermondeMatrix(xData, dxsJs); // 注意这里N=4,因为我们从0开始计数\r\n\r\n // 使用最小二乘法求解\r\n const A = vandermonde_matrix;\r\n const AT = math.transpose(A);\r\n const ATA = math.multiply(AT, A);\r\n const ATb = math.multiply(AT, math.matrix(yData));\r\n\r\n // 解线性方程组\r\n // const result = math.lusolve(ATA, ATb);\r\n // const coefficients = result.valueOf();\r\n\r\n let result: any = null,\r\n coefficients: any = [];\r\n try {\r\n result = math.lusolve(ATA, ATb);\r\n coefficients = result.valueOf();\r\n } catch (err) {\r\n for (let index = 0; index < xData.length; index++) {\r\n coefficients.push([0]);\r\n }\r\n console.log('无法解决该线性系统');\r\n }\r\n\r\n function funequation(x) {\r\n let y = 0;\r\n coefficients.forEach((item, index) => {\r\n //fx^0\r\n //fx^0+ax^1\r\n //fx^0+ax^1+bx^2\r\n //fx^0+ax^1+bx^2+cx^3\r\n //fx^0+x^1+x^2+x^3+x^4\r\n y += item * x ** index;\r\n });\r\n return y;\r\n }\r\n\r\n // console.log('计算公式:', coefficients);\r\n\r\n function lagrangeInterpolation(points, x) {\r\n let result = 0;\r\n for (let i = 0; i < points.length; i++) {\r\n let term = points[i][1];\r\n let xi = points[i][0];\r\n for (let j = 0; j < points.length; j++) {\r\n if (j !== i) {\r\n let xj = points[j][0];\r\n term *= (x - xj) / (xi - xj);\r\n }\r\n }\r\n result += term;\r\n }\r\n return result;\r\n }\r\n let arrX = [];\r\n let arrY = [];\r\n for (let i = xMin; i <= xMax; i += 0.01) {\r\n let temp = Number(EChartsUtilsComm.getRound(i, 0.01));\r\n //arrY.push(lagrangeInterpolation(points, temp));\r\n arrY.push(funequation(temp));\r\n arrX.push(temp);\r\n }\r\n let max = Math.max(...arrY);\r\n\r\n // 找到最大值的索引\r\n let maxIndex = arrY.findIndex((value) => value === max);\r\n\r\n // console.log('最大点数据:', arrX[maxIndex], max);\r\n\r\n let title = '', // config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n arrX.forEach((item, index) => {\r\n if (xData.includes(item)) {\r\n seriesData.push({ value: [item, arrY[index]] });\r\n } else {\r\n seriesData.push({\r\n value: [item, arrY[index]],\r\n symbol: 'none',\r\n });\r\n }\r\n });\r\n\r\n //计算两条线段是否有交点\r\n function ifHaveIntersectionPoint(y1, y2, y3, y4) {\r\n if ((y1 >= y3 && y2 <= y4) || (y1 <= y3 && y2 >= y4)) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n //获取两点和香交线最接近的点\r\n function getIntersectionPoint(y1, y2, y) {\r\n if (Math.abs(y1 - y) > Math.abs(y2 - y)) {\r\n return 0;\r\n }\r\n return -1;\r\n }\r\n let upperIntersectionPoint = [],\r\n lowerIntersectionPoint = [];\r\n let upperIntersectionPointTrend = []; //上限交点趋势(向上相交(1) 还是向下相交(0))\r\n let lowerIntersectionPointTrend = []; //下限交点趋势\r\n arrX.forEach((item, index) => {\r\n if (index > 0) {\r\n //上限交点\r\n if (upperLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], upperLimit, upperLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], upperLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n upperIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n upperIntersectionPointTrend.push(0);\r\n } else {\r\n upperIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n //下限交点\r\n if (lowerLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit, lowerLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n lowerIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n lowerIntersectionPointTrend.push(0);\r\n } else {\r\n lowerIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n }\r\n });\r\n\r\n let validX1 = xMin,\r\n validX2 = xMax;\r\n if (upperIntersectionPoint.length == 0 && lowerIntersectionPoint.length > 0) {\r\n //上限无交点,下限有交点\r\n if (lowerIntersectionPointTrend[0] == 0) {\r\n //下限向下相交\r\n validX1 = xMin;\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //下限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n if (lowerIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = lowerIntersectionPoint[1][0];\r\n }\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length == 0) {\r\n //上限有交点,下限无交点\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n if (upperIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = upperIntersectionPoint[1][0];\r\n }\r\n } else {\r\n //上限向上相交\r\n validX1 = xMin;\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length > 0) {\r\n //上下限都有交点,情况太多,我们只取中间\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //上限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n }\r\n\r\n // console.log('x范围:', validX1, validX2);\r\n //输出开始和结束范围\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlKs != null && chartExtJson.lqhhlKs != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlKs.row, chartExtJson.lqhhlKs.col, validX1);\r\n sheet.setValue(chartExtJson.lqhhlJs.row, chartExtJson.lqhhlJs.col, validX2);\r\n }\r\n }\r\n\r\n let lineData = [];\r\n let pointData = [];\r\n if (showLine) {\r\n lineData = [];\r\n pointData = [];\r\n }\r\n\r\n if (upperLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, upperLimit],\r\n lineStyle: {\r\n color: '#333', //上限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, upperLimit],\r\n },\r\n ]);\r\n }\r\n\r\n if (lowerLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, lowerLimit],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, lowerLimit],\r\n },\r\n ]);\r\n }\r\n\r\n //判断数据是否为/\r\n let yValIsAllNull = false;\r\n seriesData.forEach((item) => {\r\n yValIsAllNull = item.value.every((ele) => {\r\n return ele == 0;\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: !yValIsAllNull ? 16 : 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n //console.log(datas,\" datas\")\r\n return datas && datas.length > 0\r\n ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + Number(EChartsUtilsComm.getRound(datas[0].value[1], 0.001))\r\n : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineJson[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineJson[0].lineColor,\r\n },\r\n data: seriesData,\r\n markPoint: {\r\n data: pointData,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'], //去掉箭头\r\n itemStyle: {\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n width: 2,\r\n },\r\n },\r\n data: lineData,\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 沥青混合料-目标配合比设计-有效沥青饱和度\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart15: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineJson = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n let xDataSource = xDataArr[0], // [3.5, 4, 4.5, 5, 5.5],\r\n yDataSource = yDataArr[0]; // [40.1, 59.8, 66.8, 74.5, 78.2];\r\n\r\n //原始数据\r\n let dxsJs = chartExtJson != null ? chartExtJson.dxsJs : 5,\r\n xData = [],\r\n yData = [];\r\n\r\n //处理原始数据为空的值,不然参与mathjs计算会报错\r\n xDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n xData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n xData.push(item);\r\n }\r\n }\r\n });\r\n yDataSource.forEach((item, index) => {\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item)) {\r\n yData.push(item);\r\n } else {\r\n if (item == '/' || item == undefined || item == null || item == '') {\r\n item = 0;\r\n yData.push(item);\r\n }\r\n }\r\n });\r\n\r\n //y轴没有任何数据的时候,不参与绘制图表\r\n if (yData.length == 0) {\r\n return;\r\n }\r\n\r\n //检查x轴的数据有多少个0,大于1个的时候,就不绘制图形\r\n let zeroCount = 0;\r\n xData.forEach((item) => {\r\n if (item == 0) {\r\n zeroCount++;\r\n }\r\n });\r\n // if (zeroCount > 1) {\r\n // \treturn;\r\n // }\r\n\r\n if (dxsJs >= yData.length) {\r\n dxsJs = yData.length - 1;\r\n }\r\n\r\n let xMin = Math.min(...xData),\r\n xMax = Math.max(...xData),\r\n yMin = Math.min(...yData),\r\n yMax = Math.max(...yData),\r\n /*\r\n\t\t\txAxisMax = 5.5,\r\n xAxisMin = 3.5,\r\n yAxisMax = 80,\r\n yAxisMin = 30,\r\n\t\t\t*/\r\n xAxisMax = xMax,\r\n xAxisMin = xMin,\r\n yAxisMax = Math.ceil(yMax + 10),\r\n yAxisMin = Math.floor(yMin - 10),\r\n seriesData = [],\r\n upperLimit = 75, //上限\r\n lowerLimit = 60, //下限\r\n showLine = true; //是否显示辅助线\r\n\r\n //获取单元格中的上限和下限\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSx != null && chartExtJson.lqhhlSx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlSx.row, chartExtJson.lqhhlSx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n upperLimit = curVal;\r\n }\r\n }\r\n if (chartExtJson.lqhhlXx != null && chartExtJson.lqhhlXx != undefined) {\r\n const curVal = sheet.getValue(chartExtJson.lqhhlXx.row, chartExtJson.lqhhlXx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curVal)) {\r\n lowerLimit = curVal;\r\n }\r\n }\r\n }\r\n\r\n if (upperLimit != null && upperLimit > yAxisMax) {\r\n yAxisMax = upperLimit + 10;\r\n }\r\n if (lowerLimit != null && lowerLimit > yAxisMax) {\r\n yAxisMin = lowerLimit - 10;\r\n }\r\n\r\n let points = [];\r\n xData.forEach((item, index) => {\r\n points.push([item, yData[index]]);\r\n });\r\n\r\n // 构造范德蒙德矩阵的函数\r\n function vandermondeMatrix(x, N) {\r\n const matrix = [];\r\n for (let i = 0; i < x.length; i++) {\r\n const row = [];\r\n for (let j = 0; j <= N; j++) {\r\n // 注意这里从0到N,包含N\r\n row.push(math.pow(x[i], j));\r\n }\r\n matrix.push(row);\r\n }\r\n return math.matrix(matrix);\r\n }\r\n\r\n // 构造原始的范德蒙德矩阵\r\n const vandermonde_matrix = vandermondeMatrix(xData, dxsJs); // 注意这里N=4,因为我们从0开始计数\r\n\r\n // 使用最小二乘法求解\r\n const A = vandermonde_matrix;\r\n const AT = math.transpose(A);\r\n const ATA = math.multiply(AT, A);\r\n const ATb = math.multiply(AT, math.matrix(yData));\r\n\r\n // 解线性方程组\r\n // const result = math.lusolve(ATA, ATb);\r\n // const coefficients = result.valueOf();\r\n\r\n let result: any = null,\r\n coefficients: any = [];\r\n try {\r\n result = math.lusolve(ATA, ATb);\r\n coefficients = result.valueOf();\r\n } catch (err) {\r\n for (let index = 0; index < xData.length; index++) {\r\n coefficients.push([0]);\r\n }\r\n console.log('无法解决该线性系统');\r\n }\r\n\r\n function funequation(x) {\r\n let y = 0;\r\n coefficients.forEach((item, index) => {\r\n //fx^0\r\n //fx^0+ax^1\r\n //fx^0+ax^1+bx^2\r\n //fx^0+ax^1+bx^2+cx^3\r\n //fx^0+x^1+x^2+x^3+x^4\r\n y += item * x ** index;\r\n });\r\n return y;\r\n }\r\n\r\n // console.log('计算公式:', coefficients);\r\n\r\n function lagrangeInterpolation(points, x) {\r\n let result = 0;\r\n for (let i = 0; i < points.length; i++) {\r\n let term = points[i][1];\r\n let xi = points[i][0];\r\n for (let j = 0; j < points.length; j++) {\r\n if (j !== i) {\r\n let xj = points[j][0];\r\n term *= (x - xj) / (xi - xj);\r\n }\r\n }\r\n result += term;\r\n }\r\n return result;\r\n }\r\n let arrX = [];\r\n let arrY = [];\r\n for (let i = xMin; i <= xMax; i += 0.01) {\r\n let temp = Number(EChartsUtilsComm.getRound(i, 0.01));\r\n //arrY.push(lagrangeInterpolation(points, temp));\r\n arrY.push(funequation(temp));\r\n arrX.push(temp);\r\n }\r\n\r\n let title = '', // config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //计算两条线段是否有交点\r\n function ifHaveIntersectionPoint(y1, y2, y3, y4) {\r\n if ((y1 >= y3 && y2 <= y4) || (y1 <= y3 && y2 >= y4)) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n //获取两点和香交线最接近的点\r\n function getIntersectionPoint(y1, y2, y) {\r\n if (Math.abs(y1 - y) > Math.abs(y2 - y)) {\r\n return 0;\r\n }\r\n return -1;\r\n }\r\n let upperIntersectionPoint = [],\r\n lowerIntersectionPoint = [];\r\n let upperIntersectionPointTrend = []; //上限交点趋势(向上相交(1) 还是向下相交(0))\r\n let lowerIntersectionPointTrend = []; //下限交点趋势\r\n arrX.forEach((item, index) => {\r\n if (xData.includes(item)) {\r\n seriesData.push({ value: [item, arrY[index]] });\r\n } else {\r\n seriesData.push({\r\n value: [item, arrY[index]],\r\n symbol: 'none',\r\n });\r\n }\r\n if (index > 0) {\r\n //上限交点\r\n if (upperLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], upperLimit, upperLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], upperLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n upperIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n upperIntersectionPointTrend.push(0);\r\n } else {\r\n upperIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n //下限交点\r\n if (upperLimit != null) {\r\n if (ifHaveIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit, lowerLimit)) {\r\n let index1 = getIntersectionPoint(arrY[index - 1], arrY[index], lowerLimit);\r\n // console.log(arrX[index + index1], arrY[index + index1]);\r\n lowerIntersectionPoint.push([arrX[index + index1], arrY[index + index1]]);\r\n if (arrY[index - 1] > arrY[index]) {\r\n //向下趋势\r\n lowerIntersectionPointTrend.push(0);\r\n } else {\r\n lowerIntersectionPointTrend.push(1);\r\n }\r\n }\r\n }\r\n }\r\n });\r\n let validX1 = xMin,\r\n validX2 = xMax;\r\n if (upperIntersectionPoint.length == 0 && lowerIntersectionPoint.length > 0) {\r\n //上限无交点,下限有交点\r\n if (lowerIntersectionPointTrend[0] == 0) {\r\n //下限向下相交\r\n validX1 = xMin;\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //下限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n if (lowerIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = lowerIntersectionPoint[1][0];\r\n }\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length == 0) {\r\n //上限有交点,下限无交点\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n if (upperIntersectionPoint.length == 1) {\r\n //只有一个交点\r\n validX2 = xMax;\r\n } else {\r\n validX2 = upperIntersectionPoint[1][0];\r\n }\r\n } else {\r\n //上限向上相交\r\n validX1 = xMin;\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n } else if (upperIntersectionPoint.length > 0 && lowerIntersectionPoint.length > 0) {\r\n //上下限都有交点,情况太多,我们只取中间\r\n if (upperIntersectionPointTrend[0] == 0) {\r\n //上限向下相交\r\n validX1 = upperIntersectionPoint[0][0];\r\n validX2 = lowerIntersectionPoint[0][0];\r\n } else {\r\n //上限向上相交\r\n validX1 = lowerIntersectionPoint[0][0];\r\n validX2 = upperIntersectionPoint[0][0];\r\n }\r\n }\r\n\r\n // console.log('x范围:', validX1, validX2);\r\n //输出开始和结束范围\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlKs != null && chartExtJson.lqhhlKs != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlKs.row, chartExtJson.lqhhlKs.col, validX1);\r\n sheet.setValue(chartExtJson.lqhhlJs.row, chartExtJson.lqhhlJs.col, validX2);\r\n }\r\n }\r\n\r\n let lineData = [];\r\n let pointData = [];\r\n if (showLine) {\r\n if (upperIntersectionPoint.length > 0) {\r\n upperIntersectionPoint.forEach((item, index) => {\r\n lineData.push([\r\n {\r\n coord: [item[0], yAxisMin],\r\n lineStyle: {\r\n color: '#333', //上限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [item[0], upperLimit],\r\n },\r\n ]);\r\n });\r\n }\r\n if (lowerIntersectionPoint.length > 0) {\r\n lowerIntersectionPoint.forEach((item, index) => {\r\n lineData.push([\r\n {\r\n coord: [item[0], yAxisMin],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [item[0], lowerLimit],\r\n },\r\n ]);\r\n });\r\n }\r\n //上下线交点分别只有一个才求平均值\r\n if (upperIntersectionPoint.length == 1 && lowerIntersectionPoint.length == 1) {\r\n const avg = ((upperIntersectionPoint[0][0] + lowerIntersectionPoint[0][0]) / 2).toFixed(2);\r\n const avgXIndex = arrX.findIndex((n) => n == avg);\r\n // console.log('输出:', avg, avgXIndex);\r\n //输出\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSc1 != null && chartExtJson.lqhhlSc1 != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlSc1.row, chartExtJson.lqhhlSc1.col, avg);\r\n }\r\n }\r\n lineData.push([\r\n {\r\n coord: [avg, yAxisMin],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [avg, arrY[avgXIndex]],\r\n },\r\n ]);\r\n pointData.push({\r\n xAxis: avg,\r\n yAxis: yAxisMin,\r\n symbolOffset: [0, 40],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n return 'a4';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n });\r\n }\r\n }\r\n\r\n if (upperLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, upperLimit],\r\n lineStyle: {\r\n color: '#333', //上限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, upperLimit],\r\n },\r\n ]);\r\n }\r\n\r\n if (lowerLimit != null) {\r\n lineData.push([\r\n {\r\n coord: [xAxisMin, lowerLimit],\r\n lineStyle: {\r\n color: '#333', //下限\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: [xAxisMax, lowerLimit],\r\n },\r\n ]);\r\n }\r\n\r\n //判断数据是否为/\r\n let yValIsAllNull = false;\r\n seriesData.forEach((item) => {\r\n yValIsAllNull = item.value.every((ele) => {\r\n return ele == 0;\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: !yValIsAllNull ? 16 : 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n //console.log(datas,\" datas\")\r\n return datas && datas.length > 0\r\n ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + Number(EChartsUtilsComm.getRound(datas[0].value[1], 0.001))\r\n : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineJson[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineJson[0].lineColor,\r\n },\r\n data: seriesData,\r\n markPoint: {\r\n data: pointData,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'], //去掉箭头\r\n itemStyle: {\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n width: 2,\r\n },\r\n },\r\n data: lineData,\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 沥青混合料-目标配合比设计-汇总\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart16: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineJson = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n // let lines = [\r\n // \t[3.5, 5.5],\r\n // \t[3.5, 5.5],\r\n // \t[4.21, 5.27],\r\n // \t[3.5, 5.5],\r\n // \t[3.5, 5.5],\r\n // \t[4.01, 5.03],\r\n // ],\r\n\r\n //原始数据\r\n let lines = [\r\n [\r\n sheet.getValue(chartExtJson.lqhhlHz[0].row, chartExtJson.lqhhlHz[0].col),\r\n sheet.getValue(chartExtJson.lqhhlHz[1].row, chartExtJson.lqhhlHz[1].col),\r\n ],\r\n [\r\n sheet.getValue(chartExtJson.lqhhlHz[2].row, chartExtJson.lqhhlHz[2].col),\r\n sheet.getValue(chartExtJson.lqhhlHz[3].row, chartExtJson.lqhhlHz[3].col),\r\n ],\r\n [\r\n sheet.getValue(chartExtJson.lqhhlHz[4].row, chartExtJson.lqhhlHz[4].col),\r\n sheet.getValue(chartExtJson.lqhhlHz[5].row, chartExtJson.lqhhlHz[5].col),\r\n ],\r\n [\r\n sheet.getValue(chartExtJson.lqhhlHz[6].row, chartExtJson.lqhhlHz[6].col),\r\n sheet.getValue(chartExtJson.lqhhlHz[7].row, chartExtJson.lqhhlHz[7].col),\r\n ],\r\n [\r\n sheet.getValue(chartExtJson.lqhhlHz[8].row, chartExtJson.lqhhlHz[8].col),\r\n sheet.getValue(chartExtJson.lqhhlHz[9].row, chartExtJson.lqhhlHz[9].col),\r\n ],\r\n [\r\n sheet.getValue(chartExtJson.lqhhlHz[10].row, chartExtJson.lqhhlHz[10].col),\r\n sheet.getValue(chartExtJson.lqhhlHz[11].row, chartExtJson.lqhhlHz[11].col),\r\n ],\r\n ],\r\n xData = xDataArr[0], // [3.5, 4, 4.5, 5, 5.5],\r\n xAxisMax = 5.5,\r\n xAxisMin = 3.5,\r\n yAxisMin = 0,\r\n yAxisMax = 6,\r\n yData = [0, 1, 2, 3, 4, 5, 6],\r\n yAxisData = ['VFA', 'VMA', '流值', '稳定度', '空隙率', '密度'],\r\n seriesData = [],\r\n showLine = true; //是否显示辅助线\r\n\r\n const title = 'OAC',\r\n xName = '油石比(%)',\r\n yName = 'VFA(%)',\r\n legendName = '图例1';\r\n let lineData = [];\r\n let pointData = [];\r\n let xMin = Math.max(...lines.map((item) => item[0]));\r\n let xMax = Math.min(...lines.map((item) => item[1]));\r\n\r\n lines.forEach((item, index) => {\r\n lineData.push([\r\n {\r\n coord: [item[0], lines.length - index],\r\n lineStyle: {\r\n color: lineJson[0].lineColor,\r\n type: 'solid',\r\n width: 2,\r\n },\r\n },\r\n {\r\n coord: [item[1], lines.length - index],\r\n },\r\n ]);\r\n });\r\n if (showLine && xMin <= xMax) {\r\n //最小\r\n lineData.push([\r\n {\r\n coord: [xMin, 0],\r\n lineStyle: {\r\n color: '#333',\r\n type: 'dashed',\r\n width: 2,\r\n },\r\n },\r\n {\r\n coord: [xMin, 6],\r\n },\r\n ]);\r\n //最大\r\n lineData.push([\r\n {\r\n coord: [xMax, 0],\r\n lineStyle: {\r\n color: '#333',\r\n type: 'dashed',\r\n width: 2,\r\n },\r\n },\r\n {\r\n coord: [xMax, 6],\r\n },\r\n ]);\r\n pointData = [\r\n {\r\n xAxis: xMin,\r\n yAxis: 0,\r\n symbolOffset: [0, 40],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n return 'OACmin';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n {\r\n xAxis: xMax,\r\n yAxis: 0,\r\n symbolOffset: [0, 40],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n return 'OACmax';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n ];\r\n }\r\n\r\n if (xMin <= xMax) {\r\n //平均值\r\n const avg = (xMin + xMax) / 2;\r\n lineData.push([\r\n {\r\n coord: [avg, 0],\r\n lineStyle: {\r\n color: '#333',\r\n type: 'dashed',\r\n width: 2,\r\n },\r\n },\r\n {\r\n coord: [avg, 6],\r\n },\r\n ]);\r\n pointData.push({\r\n xAxis: avg,\r\n yAxis: 0,\r\n symbolOffset: [0, 40],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n return 'OAC2';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n });\r\n }\r\n\r\n if (isNaN(xMin)) {\r\n xMin = 0;\r\n }\r\n if (isNaN(xMax)) {\r\n xMax = 0;\r\n }\r\n // console.log('输出:', xMin, xMax);\r\n //输出\r\n if (chartExtJson != null) {\r\n if (chartExtJson.lqhhlSc1 != null && chartExtJson.lqhhlSc1 != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlSc1.row, chartExtJson.lqhhlSc1.col, xMin);\r\n }\r\n if (chartExtJson.lqhhlSc2 != null && chartExtJson.lqhhlSc2 != undefined) {\r\n sheet.setValue(chartExtJson.lqhhlSc2.row, chartExtJson.lqhhlSc2.col, xMax);\r\n }\r\n }\r\n\r\n //判断数据是否为/\r\n let yValIsAllNull = false;\r\n lines.forEach((item) => {\r\n yValIsAllNull = item.every((ele) => {\r\n return ele == '/';\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: 10,\r\n right: 10,\r\n bottom: !yValIsAllNull ? 16 : 20,\r\n containLabel: true,\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n axisLabel: {\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n if (data == 0) {\r\n return '';\r\n } else {\r\n return yAxisData[data - 1];\r\n }\r\n },\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n // data: seriesData,\r\n markPoint: {\r\n data: pointData,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'], //去掉箭头\r\n data: lineData,\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 击实\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart30: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n //设置是否选择校正jsIsJz的默认值\r\n if (chartExtJson != null && (chartExtJson.jsIsJz == null || chartExtJson.jsIsJz == undefined)) {\r\n chartExtJson.jsIsJz = true;\r\n }\r\n // console.log(config);\r\n\r\n let isTwoLine = xDataArr.length == 2;\r\n\r\n let xDataSource1 = xDataArr[0], // [1.6, 2.4, 3.5, 4.6, 5.3],\r\n xDataSource2 = isTwoLine ? xDataArr[1] : [], // [1.5, 2.4, 3.6, 4.3, 5.4],\r\n yDataSource1 = yDataArr[0], // [2.25, 2.29, 2.34, 2.29, 2.23],\r\n yDataSource2 = isTwoLine ? yDataArr[1] : []; // [2.27, 2.32, 2.36, 2.33, 2.26];\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n const lineFunc = (xDataSource, yDataSource, isShowMarkPoint, isShowMarkLine, isTwoLineData) => {\r\n //原始数据\r\n let dxsJs = chartExtJson != null ? chartExtJson.dxsJs : 5,\r\n xData = [],\r\n yData = [],\r\n seriesData = []; //处理原始数据为空的值,不然参与mathjs计算会报错\r\n\r\n //处理原始数据为空的值,不然参与mathjs计算会报错\r\n xDataSource.forEach((item, index) => {\r\n if (\r\n /^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(item) &&\r\n item != 0 &&\r\n /^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(yDataSource[index]) &&\r\n yDataSource[index] != 0\r\n ) {\r\n xData.push(item);\r\n yData.push(yDataSource[index]);\r\n }\r\n });\r\n\r\n //y轴没有任何数据的时候,不参与绘制图表\r\n if (yData.length == 0) {\r\n return;\r\n }\r\n\r\n if (dxsJs >= yData.length) {\r\n dxsJs = yData.length - 1;\r\n }\r\n\r\n let xMin = Math.min(...xData),\r\n xMax = Math.max(...xData),\r\n yMin = Math.min(...yData),\r\n yMax = Math.max(...yData),\r\n xAxisMax = Math.ceil(xMax + 0.1),\r\n xAxisMin = Math.trunc(xMin - 0.1),\r\n yAxisMax = Number(EChartsUtilsComm.getRound(yMax + 0.02, 0.01)),\r\n yAxisMin = Number(EChartsUtilsComm.getRound(yMin - 0.02, 0.01));\r\n\r\n //如果界面设置了校正最佳含水率和最大干密度,则显示界面中的顶点坐标(此时就不显示辅助线了)\r\n let cellValJzZjhsl, cellValJzZdgmd;\r\n if (chartExtJson != null && chartExtJson.jsIsJz) {\r\n if (chartExtJson.jsZjhslJz != null && chartExtJson.jsZjhslJz != undefined) {\r\n cellValJzZjhsl = sheet.getValue(chartExtJson.jsZjhslJz.row, chartExtJson.jsZjhslJz.col);\r\n }\r\n if (chartExtJson.jsZdgmdJz != null && chartExtJson.jsZdgmdJz != undefined) {\r\n cellValJzZdgmd = sheet.getValue(chartExtJson.jsZdgmdJz.row, chartExtJson.jsZdgmdJz.col);\r\n }\r\n\r\n //如果界面输入的最大干密度大于了y轴最大值,则需要重新设置y轴的最大值\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(cellValJzZdgmd) && cellValJzZdgmd > yAxisMax) {\r\n yAxisMax = Number(EChartsUtilsComm.getRound(cellValJzZdgmd + 0.02, 0.01));\r\n }\r\n }\r\n\r\n let points = [];\r\n xData.forEach((item, index) => {\r\n points.push([item, yData[index]]);\r\n });\r\n\r\n // 构造范德蒙德矩阵的函数\r\n function vandermondeMatrix(x, N) {\r\n const matrix = [];\r\n for (let i = 0; i < x.length; i++) {\r\n const row = [];\r\n for (let j = 0; j <= N; j++) {\r\n // 注意这里从0到N,包含N\r\n row.push(math.pow(x[i], j));\r\n }\r\n matrix.push(row);\r\n }\r\n return math.matrix(matrix);\r\n }\r\n\r\n // 构造原始的范德蒙德矩阵\r\n const vandermonde_matrix = vandermondeMatrix(xData, dxsJs); // 注意这里N=4,因为我们从0开始计数\r\n\r\n // 使用最小二乘法求解\r\n const A = vandermonde_matrix;\r\n const AT = math.transpose(A);\r\n const ATA = math.multiply(AT, A);\r\n\r\n const ATb = math.multiply(AT, math.matrix(yData));\r\n\r\n // 解线性方程组\r\n let result: any = null,\r\n coefficients: any = [];\r\n try {\r\n result = math.lusolve(ATA, ATb);\r\n coefficients = result.valueOf();\r\n } catch (err) {\r\n for (let index = 0; index < xData.length; index++) {\r\n coefficients.push([0]);\r\n }\r\n // console.log('无法解决该线性系统');\r\n }\r\n // const result = math.lusolve(ATA, ATb);\r\n // const coefficients = result.valueOf();\r\n\r\n function funequation(x) {\r\n let y = 0;\r\n coefficients.forEach((item, index) => {\r\n //fx^0\r\n //fx^0+ax^1\r\n //fx^0+ax^1+bx^2\r\n //fx^0+ax^1+bx^2+cx^3\r\n //fx^0+x^1+x^2+x^3+x^4\r\n y += item * x ** index;\r\n });\r\n return y;\r\n }\r\n\r\n // console.log('计算公式:', coefficients);\r\n\r\n function lagrangeInterpolation(points, x) {\r\n let result = 0;\r\n for (let i = 0; i < points.length; i++) {\r\n let term = points[i][1];\r\n let xi = points[i][0];\r\n for (let j = 0; j < points.length; j++) {\r\n if (j !== i) {\r\n let xj = points[j][0];\r\n term *= (x - xj) / (xi - xj);\r\n }\r\n }\r\n result += term;\r\n }\r\n return result;\r\n }\r\n // x=[3.5, 4, 4.5, 5, 5.5,6 ],y= [2.262, 2.321, 2.319, 2.292, 2.285, 2.28]\r\n\r\n let arrX = [];\r\n let arrY = [];\r\n for (let i = xMin; i <= xMax; i += 0.01) {\r\n let temp = Number(EChartsUtilsComm.getRound(i, 0.01));\r\n //重新设置i,防止i丢失精度\r\n i = Number(temp);\r\n //arrY.push(lagrangeInterpolation(points, temp));\r\n arrY.push(funequation(temp));\r\n arrX.push(temp);\r\n }\r\n let max = Math.max(...arrY);\r\n\r\n // 找到最大值的索引\r\n let maxIndex = arrY.findIndex((value) => value === max);\r\n\r\n // console.log('最大点数据:', arrX[maxIndex], max);\r\n // console.log(chartExtJson);\r\n\r\n //默认输出精度\r\n let outJdZjhsl = 0.01,\r\n outJdZdgmd = 0.001;\r\n\r\n //顶点数据\r\n let outValZjhsl = 0,\r\n outValZdgmd = 0;\r\n\r\n //设置Sheet单元格的值(最佳含水率和最大干密度)\r\n if (chartExtJson != null) {\r\n // console.log(4444, chartExtJson.jsZjhsl.row, chartExtJson.jsZjhsl.col, arrX[maxIndex]);\r\n\r\n if (chartExtJson.jsZjhslJd != null && chartExtJson.jsZjhslJd != undefined) {\r\n outJdZjhsl = chartExtJson.jsZjhslJd;\r\n }\r\n if (chartExtJson.jsZdgmdJd != null && chartExtJson.jsZdgmdJd != undefined) {\r\n outJdZdgmd = chartExtJson.jsZdgmdJd;\r\n }\r\n\r\n if (arrX[maxIndex] == 0 && max == 0) {\r\n sheet.setValue(chartExtJson.jsZjhsl.row, chartExtJson.jsZjhsl.col, '/');\r\n sheet.setValue(chartExtJson.jsZdgmd.row, chartExtJson.jsZdgmd.col, '/');\r\n } else {\r\n outValZjhsl = EChartsUtilsComm.getRound(arrX[maxIndex], outJdZjhsl);\r\n outValZdgmd = EChartsUtilsComm.getRound(max, outJdZdgmd);\r\n\r\n sheet.setValue(chartExtJson.jsZjhsl.row, chartExtJson.jsZjhsl.col, outValZjhsl);\r\n sheet.setValue(chartExtJson.jsZdgmd.row, chartExtJson.jsZdgmd.col, outValZdgmd);\r\n }\r\n }\r\n\r\n arrX.forEach((item, index) => {\r\n if (xData.includes(item)) {\r\n seriesData.push({ value: [item, arrY[index]] });\r\n } else {\r\n seriesData.push({\r\n value: [item, arrY[index]],\r\n symbol: 'none',\r\n });\r\n }\r\n });\r\n\r\n //xData.forEach((item, index) => {\r\n //seriesData.push([item, yData[index]]);\r\n //});\r\n\r\n //计算峰值----目前没有公式 值写死的\r\n const peakvalue = [arrX[maxIndex], Number(EChartsUtilsComm.getRound(max, outJdZdgmd))],\r\n coordX = [peakvalue[0], yAxisMin],\r\n coordY = [xAxisMin, peakvalue[1]];\r\n\r\n let markPointObj = {\r\n data: [\r\n {\r\n xAxis: EChartsUtilsComm.getRound(peakvalue[0], outJdZjhsl),\r\n yAxis: EChartsUtilsComm.getRound(peakvalue[1], outJdZdgmd),\r\n symbolOffset: [0, 15],\r\n symbol: 'circle',\r\n symbolSize: 6,\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n // 自定义标签内容\r\n if (Number(data.data.xAxis) == 0 && Number(data.data.yAxis) == 0) {\r\n return '';\r\n } else {\r\n return '( ' + data.data.xAxis + ',' + data.data.yAxis + ')';\r\n }\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n ],\r\n },\r\n markLineObj = {\r\n symbol: ['none', 'none'], //去掉箭头\r\n itemStyle: {\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n width: 2,\r\n },\r\n },\r\n data: [\r\n [\r\n {\r\n coord: coordX,\r\n lineStyle: {\r\n color: '#333', //X轴\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: peakvalue,\r\n },\r\n ],\r\n [\r\n {\r\n coord: coordY,\r\n lineStyle: {\r\n color: '#333', //y轴\r\n type: 'dashed',\r\n },\r\n },\r\n {\r\n coord: peakvalue,\r\n },\r\n ],\r\n ],\r\n };\r\n\r\n //如果界面设置了校正最佳含水率和最大干密度,则显示界面中的顶点坐标(此时就不显示辅助线了)\r\n if (chartExtJson.jsIsJz && /^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(cellValJzZjhsl) && /^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(cellValJzZdgmd)) {\r\n markLineObj = null;\r\n markPointObj.data[0].label = null;\r\n markPointObj.data[0].symbolOffset = null;\r\n markPointObj.data[0].itemStyle.color = '#F56C6C';\r\n markPointObj.data[0].xAxis = cellValJzZjhsl;\r\n markPointObj.data[0].yAxis = cellValJzZdgmd;\r\n markLineObj = null;\r\n }\r\n\r\n let seriesDataObj = {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[isTwoLineData ? 1 : 0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n type: isTwoLineData ? 'dotted' : 'solid',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[isTwoLineData ? 1 : 0].lineColor,\r\n },\r\n data: seriesData,\r\n markPoint: isShowMarkPoint ? markPointObj : null,\r\n markLine: isShowMarkLine ? markLineObj : null,\r\n };\r\n\r\n return {\r\n xAxisMin: xAxisMin,\r\n xAxisMax: xAxisMax,\r\n yAxisMin: yAxisMin,\r\n yAxisMax: yAxisMax,\r\n xData: xData,\r\n seriesDataObj: seriesDataObj,\r\n maxPointData: [arrX[maxIndex], max],\r\n };\r\n };\r\n\r\n let xAxisMin = 0,\r\n xAxisMax = 0,\r\n yAxisMin = 0,\r\n yAxisMax = 0,\r\n xData = [],\r\n seriesData = [],\r\n maxPointDataX = 0,\r\n maxPointDataY = 0;\r\n\r\n let lineObj1 = lineFunc(xDataSource1, yDataSource1, !isTwoLine, !isTwoLine, false),\r\n lineObj2;\r\n if (isTwoLine) {\r\n lineObj2 = lineFunc(xDataSource2, yDataSource2, false, false, true);\r\n }\r\n\r\n //此处的作用是,有可能x和y轴的数据都为空,造成lineObj1为undefined,避免报错\r\n if (lineObj1 == undefined || lineObj1 == null) {\r\n return;\r\n }\r\n\r\n //一条线的时候\r\n if (!isTwoLine) {\r\n xAxisMin = lineObj1.xAxisMin;\r\n xAxisMax = lineObj1.xAxisMax;\r\n yAxisMin = lineObj1.yAxisMin;\r\n yAxisMax = lineObj1.yAxisMax;\r\n xData = lineObj1.xData;\r\n seriesData.push(lineObj1.seriesDataObj);\r\n }\r\n //2条线的时候\r\n else {\r\n if (lineObj2 == undefined || lineObj2 == null) {\r\n return;\r\n }\r\n\r\n xAxisMax = lineObj1.xAxisMax;\r\n if (lineObj2.xAxisMax > xAxisMax) {\r\n xAxisMax = lineObj2.xAxisMax;\r\n }\r\n xAxisMin = lineObj1.xAxisMin;\r\n if (lineObj2.xAxisMin < xAxisMin) {\r\n xAxisMin = lineObj2.xAxisMin;\r\n }\r\n yAxisMax = lineObj1.yAxisMax;\r\n if (lineObj2.yAxisMax > yAxisMax) {\r\n yAxisMax = lineObj2.yAxisMax;\r\n }\r\n yAxisMin = lineObj1.yAxisMin;\r\n if (lineObj2.yAxisMin < yAxisMin) {\r\n yAxisMin = lineObj2.yAxisMin;\r\n }\r\n\r\n lineObj1.xData.forEach((item) => {\r\n xData.push(item);\r\n });\r\n lineObj2.xData.forEach((item) => {\r\n xData.push(item);\r\n });\r\n\r\n seriesData.push(lineObj1.seriesDataObj);\r\n seriesData.push(lineObj2.seriesDataObj);\r\n\r\n maxPointDataX = (lineObj1.maxPointData[0] + lineObj2.maxPointData[0]) / 2;\r\n maxPointDataY = (lineObj1.maxPointData[1] + lineObj2.maxPointData[1]) / 2;\r\n\r\n // console.log(\r\n // \t\"两条线最大点的平均值:\",\r\n // \tmaxPointDataX,\r\n // \tmaxPointDataY\r\n // );\r\n\r\n //默认输出精度\r\n let outJdZjhsl = 0.01,\r\n outJdZdgmd = 0.001;\r\n\r\n //顶点数据\r\n let outValZjhsl = 0,\r\n outValZdgmd = 0;\r\n\r\n //设置Sheet单元格的值(最佳含水率和最大干密度)\r\n if (chartExtJson != null) {\r\n // console.log(4444, chartExtJson.jsZjhsl.row, chartExtJson.jsZjhsl.col, arrX[maxIndex]);\r\n\r\n if (chartExtJson.jsZjhslJd != null && chartExtJson.jsZjhslJd != undefined) {\r\n outJdZjhsl = chartExtJson.jsZjhslJd;\r\n }\r\n if (chartExtJson.jsZdgmdJd != null && chartExtJson.jsZdgmdJd != undefined) {\r\n outJdZdgmd = chartExtJson.jsZdgmdJd;\r\n }\r\n\r\n if (maxPointDataX == 0 && maxPointDataY == 0) {\r\n sheet.setValue(chartExtJson.jsZjhsl.row, chartExtJson.jsZjhsl.col, '/');\r\n sheet.setValue(chartExtJson.jsZdgmd.row, chartExtJson.jsZdgmd.col, '/');\r\n } else {\r\n outValZjhsl = EChartsUtilsComm.getRound(maxPointDataX, outJdZjhsl);\r\n outValZdgmd = EChartsUtilsComm.getRound(maxPointDataY, outJdZdgmd);\r\n\r\n sheet.setValue(chartExtJson.jsZjhsl.row, chartExtJson.jsZjhsl.col, outValZjhsl);\r\n sheet.setValue(chartExtJson.jsZdgmd.row, chartExtJson.jsZdgmd.col, outValZdgmd);\r\n }\r\n }\r\n }\r\n\r\n //判断数据是否为/,‘’,null,undefined\r\n let yValIsAllNull = false;\r\n seriesData.forEach((item) => {\r\n yValIsAllNull = item.data[0].value.every((ele) => {\r\n return ele == 0;\r\n });\r\n });\r\n if (yValIsAllNull) {\r\n xAxisMin = null;\r\n xAxisMax = null;\r\n yAxisMin = null;\r\n yAxisMax = null;\r\n seriesData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n //console.log(datas,\" datas\")\r\n return datas && datas.length > 0\r\n ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + Number(EChartsUtilsComm.getRound(datas[0].value[1], 0.001))\r\n : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n max: xAxisMax,\r\n min: xAxisMin,\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n max: yAxisMax,\r\n min: yAxisMin,\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 40 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: seriesData,\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 筛分\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart50: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = '', //config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName;\r\n\r\n // x轴原始数据、y轴原始数据、y轴原始数据(上限)、y轴原始数据(下限)\r\n const xDataSourceOld = xDataArr[0],\r\n yDataSourceOld = yDataArr[0],\r\n yDataSourceSxOld = yDataArr[1],\r\n yDataSourceXxOld = yDataArr[2];\r\n const allData: any[] = [];\r\n xDataSourceOld.forEach((item, index) => {\r\n allData.push({\r\n x: item,\r\n y: yDataSourceOld[index],\r\n ySx: yDataSourceSxOld[index],\r\n yXx: yDataSourceXxOld[index],\r\n });\r\n });\r\n allData.sort(function (a, b) {\r\n return a.x - b.x;\r\n });\r\n\r\n const xDataSource: any[] = [],\r\n yDataSource: any[] = [],\r\n yDataSourceSx: any[] = [],\r\n yDataSourceXx: any[] = [];\r\n\r\n // 记录上限或下限中值为null的个数\r\n let sxValNullCount = 0;\r\n yDataSourceSxOld.forEach((item, index) => {\r\n if (item == null || item == '/') {\r\n sxValNullCount++;\r\n }\r\n });\r\n\r\n // 如果上限或下限值中的所有值都为null,则只展示筛分曲线的折线\r\n if (sxValNullCount == yDataSourceSxOld.length) {\r\n allData.forEach((item, index) => {\r\n xDataSource.push(item.x);\r\n yDataSource.push(item.y);\r\n yDataSourceSx.push(item.ySx);\r\n yDataSourceXx.push(item.yXx);\r\n });\r\n } else {\r\n // 只获取上限或下限中值不为null的点\r\n allData.forEach((item, index) => {\r\n if (item.ySx != null && item.ySx != '/' && item.yXx != null && item.yXx != '/') {\r\n xDataSource.push(item.x);\r\n yDataSource.push(item.y);\r\n yDataSourceSx.push(item.ySx);\r\n yDataSourceXx.push(item.yXx);\r\n }\r\n });\r\n }\r\n\r\n // x轴需要的数据(x轴原始数据的0.45次方,并修约0.01)、x轴需要的上限数据(x轴原始数据的0.45次方,并修约0.01)、x轴需要的下限数据(x轴原始数据的0.45次方,并修约0.01)、标记线需要的数据\r\n let xData: any[] = [],\r\n xDataSx: any[] = [],\r\n xDataXx: any[] = [],\r\n markLineData: any[] = [];\r\n\r\n // x和y轴的字体大小\r\n const xyFontSize = 10;\r\n\r\n // 组装数据\r\n xDataSource.forEach((item, index) => {\r\n // 得到x轴原始数据的0.45次方值,并修约0.001\r\n const val045 = Number(EChartsUtilsComm.getRound(item ** 0.45, 0.001));\r\n\r\n xData.push([val045, yDataSource[index]]);\r\n markLineData.push({\r\n name: item + '',\r\n xAxis: val045,\r\n label: {\r\n show: xDataSource.length >= 6 && index % 2 != 0 && index < 6 ? false : true, // 控制x轴的名称某些点是否显示,避免重叠的情况\r\n fontSize: xyFontSize,\r\n },\r\n });\r\n\r\n xDataSx.push([val045, yDataSourceSx[index]]);\r\n xDataXx.push([val045, yDataSourceXx[index]]);\r\n });\r\n\r\n /**\r\n * 获取series需要的3条线配置\r\n * @param type 线类型(1:筛分曲线、2:上限、3:下限)\r\n * @param data 对应的坐标点数据\r\n */\r\n const getLineObj = (type, data) => {\r\n const name = type == 1 ? '筛分曲线' : type == 2 ? '上限' : '下限';\r\n const symbol = type == 1 ? 'rect' : type == 2 ? 'triangle' : 'circle';\r\n const lineType = type == 1 ? 'solid' : type == 2 ? 'dotted' : [10, 5];\r\n const color = type == 1 ? lineData[0].lineColor : type == 2 ? lineData[1].lineColor : lineData[2].lineColor; //type == 1 ? '#F56C6C' : type == 2 ? '#409EFF' : '#000';\r\n\r\n let obj = {\r\n name: name,\r\n type: 'line',\r\n smooth: true, // 平滑的线条\r\n // 设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: symbol,\r\n symbolSize: 5,\r\n z: 10, // 控制曲线的浮动层级,避免在markLine下方被遮住\r\n // 线条的颜色\r\n lineStyle: {\r\n color: color,\r\n // 线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n type: lineType,\r\n },\r\n // 线条上数据点的颜色\r\n itemStyle: {\r\n color: color,\r\n },\r\n data: data,\r\n connectNulls: true, // 是否连接空数据\r\n markLine: {\r\n symbol: '', // 取消箭头\r\n silent: true, // 取消鼠标hover事件\r\n label: {\r\n // 标线的文本,模拟x轴显示的内容\r\n position: 'start', // 改变label位置\r\n //rotate: 45, // 设置文字旋转度数(注意:ECharts官网文档居然没有rotate这个属性的说明)\r\n // backgroundColor:'#fff'\r\n // color:'#f00',// 文字颜色\r\n formatter: (data) => {\r\n return data.name;\r\n },\r\n },\r\n lineStyle: { color: '#e0e6f1', type: 'solid' },\r\n data: markLineData,\r\n },\r\n };\r\n\r\n return obj;\r\n };\r\n\r\n // 验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item[1] == null || item[1] == undefined || item[1] == '/') {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n }\r\n if (\r\n yDataSourceSxOld.some((item) => item != null && item != undefined && item != '/') ||\r\n yDataSourceXxOld.some((item) => item != null && item != undefined && item != '/')\r\n ) {\r\n yValIsAllNull = false;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,// 是否显示外边框线\r\n // borderColor: '#f00',// 外边框线颜色\r\n top: 20,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 35,\r\n containLabel: true,\r\n },\r\n // 提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n if (datas && datas[0].data.length > 1) {\r\n let xObj = markLineData.filter((item) => item.xAxis == datas[0].data[0]);\r\n\r\n return datas[0].seriesName + '(' + xObj[0].name + ')' + ':' + datas[0].data[1];\r\n } else {\r\n return datas[0].data;\r\n }\r\n },\r\n },\r\n // 顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 5,\r\n textStyle: {\r\n fontSize: 18,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n // 图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n left: 'center',\r\n data: ['筛分曲线', '上限', '下限'],\r\n selected: {\r\n 筛分曲线: true, // 显示\r\n 上限: true, // 显示\r\n 下限: true, // 显示\r\n },\r\n selectedMode: 'multiple', // 用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n axisTick: { show: false }, // 隐藏刻度线\r\n axisLabel: { show: false }, // 隐藏刻度值\r\n // 网格线,参考文档:https://echarts.apache.org/zh/option.html#xAxis.splitLine\r\n splitLine: {\r\n show: false, // 隐藏分割线\r\n },\r\n min: xData.length > 0 ? (xData[0][0] > 0.2 ? xData[0][0] - 0.2 : 0) : null, //控制x轴的最小值\r\n max: xData.length > 0 ? xData[xData.length - 1][0] + 0.1 : null,\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', // '#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n splitNumber: 10, // 设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLabel: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n ],\r\n series: [getLineObj(1, xData), getLineObj(2, xDataSx), getLineObj(3, xDataXx)],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 界限含水率\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart70: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n //此图形排除了图形数据不正确的情况,如果数据不对,则直接返回{}\r\n if (\r\n xDataArr[0].some((item) => item == null || item == '' || item == undefined) ||\r\n yDataArr[0].some((item) => item == null || item == '' || item == undefined)\r\n ) {\r\n return {};\r\n }\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n let xData = xDataArr[0], // [22.9, 32.4, 36.9],\r\n yData = yDataArr[0], // [2.2, 11.6, 19.8],\r\n ztzl = 100, //锥体质量(g),100或76\r\n cllx = '砂类土', //材料类型,砂类土或细粒土\r\n logx = [], // c,b,a\r\n logy = [];\r\n\r\n //获取锥体质量和材料类型\r\n if (chartExtJson != null) {\r\n let curZtzl = sheet.getValue(chartExtJson.jxhslZtzl.row, chartExtJson.jxhslZtzl.col),\r\n curCllx = sheet.getValue(chartExtJson.jxhslCllx.row, chartExtJson.jxhslCllx.col);\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curZtzl)) {\r\n curZtzl = Number(curZtzl);\r\n if (curZtzl == 100 || curZtzl == 76) {\r\n ztzl = curZtzl;\r\n }\r\n }\r\n if (curCllx == '砂类土' || curCllx == '细粒土') {\r\n cllx = curCllx;\r\n }\r\n }\r\n\r\n // console.log(ztzl, cllx);\r\n\r\n //先求对数\r\n for (const item1 of xData) {\r\n logx.push(Math.log(item1));\r\n }\r\n for (const item2 of yData) {\r\n logy.push(Math.log(item2));\r\n }\r\n //求ab / ac 斜率 公式k=y2-y1 / x2-x1\r\n let abk = (logy[2] - logy[1]) / (logx[2] - logx[1]);\r\n let ack = (logy[2] - logy[0]) / (logx[2] - logx[0]);\r\n\r\n const xMax = Math.max.apply(Math, xData),\r\n xMin = Math.min.apply(Math, xData),\r\n xAxisMax = xMax + 1,\r\n xAxisMin = xMin - 0.3,\r\n yMax = Math.max.apply(Math, yData),\r\n yMin = Math.min.apply(Math, yData),\r\n yAxisMax = yMax + 1,\r\n yAxisMin = yMin - 2,\r\n dropName = ['C', 'B', 'A'],\r\n seriesData = [];\r\n\r\n xData.forEach((item, index) => {\r\n seriesData.push([item, yData[index], dropName[index]]);\r\n });\r\n\r\n //求ab / ac 延长线方法\r\n function getYOnLine(point1, point2, point3X) {\r\n const logX1 = Math.log(point1[0]);\r\n const logY1 = Math.log(point1[1]);\r\n const logX2 = Math.log(point2[0]);\r\n const logY2 = Math.log(point2[1]);\r\n const slope = (logY2 - logY1) / (logX2 - logX1);\r\n const logPoint3X = Math.log(point3X);\r\n const logY = logY1 + slope * (logPoint3X - logX1);\r\n return Math.exp(logY);\r\n }\r\n\r\n let point3X = 20;\r\n let abd3 = getYOnLine([xData[2], yData[2]], [xData[1], yData[1]], point3X);\r\n let zero_ab = [20, abd3];\r\n let acd3 = getYOnLine([xData[2], yData[2]], [xData[0], yData[0]], point3X);\r\n let zero_ac = [20, acd3];\r\n\r\n // console.log(zero_ab, 'zero_ab');\r\n // console.log(zero_ac, 'zero_ac');\r\n\r\n //第一次计算D-y值,代入A点的X坐标\r\n function HpCoordinates(wl) {\r\n let hp;\r\n if (cllx == '砂类土') {\r\n //砂类土\r\n hp = 29.6 - 1.22 * wl + 0.017 * wl * wl - 0.0000744 * wl * wl * wl;\r\n } else {\r\n //细粒土\r\n hp = wl / (0.524 * wl - 7.606);\r\n }\r\n return hp;\r\n }\r\n\r\n let coordX = [];\r\n let coordY = [];\r\n let point_hp = [];\r\n\r\n let Dy = HpCoordinates(xData[2]);\r\n let Dylog = Math.log(Dy);\r\n let hp0_xab = (abk * logx[2] - (logy[2] - Dylog)) / abk;\r\n let hp0_xac = (ack * logx[2] - (logy[2] - Dylog)) / ack;\r\n if (hp0_xab - hp0_xac >= 2) {\r\n //return '超差!';\r\n }\r\n let hp0_xcenter = Math.exp((hp0_xab + hp0_xac) / 2);\r\n let Dxlog = Math.log(hp0_xcenter);\r\n let adk = (logy[2] - Dylog) / (logx[2] - Dxlog); //AD 斜率\r\n\r\n //输出的hp、wl和wp\r\n let scHp, scWl, scWp;\r\n\r\n //判断锥数\r\n if (ztzl == 76) {\r\n //计算wl ad直线上y=17时,对应的x值\r\n let wly = Math.log(17);\r\n let wlx = (adk * logx[2] - (logy[2] - wly)) / adk;\r\n let wl = Math.exp(wlx);\r\n\r\n //计算WP:ad直线上y=2时,对应的x值\r\n let wpy = Math.log(2);\r\n let wpx = (adk * logx[2] - (logy[2] - wpy)) / adk;\r\n let wp = Math.exp(wpx);\r\n\r\n point_hp = [hp0_xcenter, Dy];\r\n coordX = [hp0_xcenter, yAxisMin];\r\n coordY = [xAxisMin, Dy];\r\n seriesData.push([hp0_xcenter, Dy, 'Hp']);\r\n\r\n scHp = Dy;\r\n scWl = wl;\r\n scWp = wp;\r\n // console.log('输出:', wp, wl, Dy);\r\n } else if (ztzl == 100) {\r\n //计算wl的值----先求AD斜率再代入y=20,求X (X即Wl的值)\r\n let wly = Math.log(20);\r\n let wlx = (adk * logx[2] - (logy[2] - wly)) / adk;\r\n let wl = Math.exp(wlx);\r\n\r\n //第二次计算hp值\r\n let hpy2 = HpCoordinates(wl);\r\n let hpylog2 = Math.log(hpy2);\r\n let hp0_xab2 = (abk * logx[2] - (logy[2] - hpylog2)) / abk;\r\n let hp0_xac2 = (ack * logx[2] - (logy[2] - hpylog2)) / ack;\r\n\r\n let hp0_xcenter2 = Math.exp((hp0_xab2 + hp0_xac2) / 2);\r\n let wp = hp0_xcenter2;\r\n\r\n point_hp = [hp0_xcenter2, hpy2];\r\n\r\n coordX = [hp0_xcenter2, yAxisMin];\r\n coordY = [xAxisMin, hpy2];\r\n seriesData.push([hp0_xcenter2, hpy2, 'Hp']);\r\n\r\n scHp = hpy2;\r\n scWl = wl;\r\n scWp = wp;\r\n // console.log('输出:', wp, wl, hpy2);\r\n }\r\n\r\n //判断是否是一个数字\r\n if (isNaN(scHp) || isNaN(scWl) || isNaN(scWp)) {\r\n scHp = 0;\r\n scWl = 0;\r\n scWp = 0;\r\n }\r\n\r\n //设置Sheet单元格的值(输出hp、wl和wp)\r\n if (chartExtJson != null) {\r\n //默认输出精度\r\n let outJdHp = 0.01,\r\n outJdWl = 0.01,\r\n outJdWp = 0.01;\r\n if (chartExtJson.jxhslScHpJd != null && chartExtJson.jxhslScHpJd != undefined) {\r\n outJdHp = chartExtJson.jxhslScHpJd;\r\n }\r\n if (chartExtJson.jxhslScWlJd != null && chartExtJson.jxhslScWlJd != undefined) {\r\n outJdWl = chartExtJson.jxhslScWlJd;\r\n }\r\n if (chartExtJson.jxhslScWpJd != null && chartExtJson.jxhslScWpJd != undefined) {\r\n outJdWp = chartExtJson.jxhslScWpJd;\r\n }\r\n\r\n if (chartExtJson.jxhslScHp != null && chartExtJson.jxhslScHp != undefined) {\r\n if (scHp == 0) {\r\n sheet.setValue(chartExtJson.jxhslScHp.row, chartExtJson.jxhslScHp.col, '/');\r\n } else {\r\n sheet.setValue(chartExtJson.jxhslScHp.row, chartExtJson.jxhslScHp.col, EChartsUtilsComm.getRound(scHp, outJdHp));\r\n }\r\n }\r\n if (chartExtJson.jxhslScWl != null && chartExtJson.jxhslScWl != undefined) {\r\n if (scWl == 0) {\r\n sheet.setValue(chartExtJson.jxhslScWl.row, chartExtJson.jxhslScWl.col, '/');\r\n } else {\r\n sheet.setValue(chartExtJson.jxhslScWl.row, chartExtJson.jxhslScWl.col, EChartsUtilsComm.getRound(scWl, outJdWl));\r\n }\r\n }\r\n if (chartExtJson.jxhslScWp != null && chartExtJson.jxhslScWp != undefined) {\r\n if (scWp == 0) {\r\n sheet.setValue(chartExtJson.jxhslScWp.row, chartExtJson.jxhslScWp.col, '/');\r\n } else {\r\n sheet.setValue(chartExtJson.jxhslScWp.row, chartExtJson.jxhslScWp.col, EChartsUtilsComm.getRound(scWp, outJdWp));\r\n }\r\n }\r\n }\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item[1] == null || item[1] == undefined || item[1] == '/') {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n }\r\n if (\r\n yData.some((item) => item != null && item != undefined && item != '/') ||\r\n yData.some((item) => item != null && item != undefined && item != '/')\r\n ) {\r\n yValIsAllNull = false;\r\n }\r\n let option = {\r\n grid: {\r\n top: 20,\r\n left: !yValIsAllNull ? 50 : 25,\r\n right: 10,\r\n bottom: 35,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + datas[0].value[1] : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'log',\r\n min: xAxisMin,\r\n max: xAxisMax,\r\n interval: 0,\r\n axisTick: {\r\n show: false,\r\n alignWithLabel: true,\r\n },\r\n splitLine: {\r\n show: false,\r\n },\r\n axisLabel: {\r\n show: false,\r\n },\r\n },\r\n yAxis: {\r\n type: 'log',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n min: yAxisMin,\r\n max: yAxisMax,\r\n interval: 0,\r\n axisTick: {\r\n show: false,\r\n alignWithLabel: true,\r\n },\r\n splitLine: {\r\n show: false,\r\n },\r\n axisLabel: {\r\n show: false,\r\n },\r\n },\r\n series: [\r\n {\r\n name: legendName,\r\n data: seriesData,\r\n type: 'scatter',\r\n symbol: 'circle',\r\n smooth: false,\r\n symbolSize: 6,\r\n label: {\r\n show: true,\r\n formatter: function (param) {\r\n return param.data[2];\r\n },\r\n position: 'right',\r\n minMargin: 2,\r\n },\r\n markLine: {\r\n symbol: ['none', 'none'],\r\n silent: true,\r\n label: {\r\n show: true,\r\n position: 'start',\r\n color: '#000000',\r\n },\r\n lineStyle: {\r\n type: 'solid',\r\n color: '#333',\r\n },\r\n data: [\r\n { xAxis: seriesData[0][0] },\r\n { xAxis: seriesData[1][0] },\r\n { xAxis: seriesData[2][0] },\r\n { yAxis: seriesData[0][1] },\r\n { yAxis: seriesData[1][1] },\r\n { yAxis: seriesData[2][1] },\r\n [\r\n {\r\n coord: coordX,\r\n lineStyle: {\r\n color: '#333',\r\n type: 'dashed',\r\n },\r\n },\r\n { coord: point_hp }, //Hp---x\r\n ],\r\n [\r\n {\r\n coord: coordY,\r\n lineStyle: {\r\n color: '#333',\r\n type: 'dashed', //dashed dotted\r\n },\r\n },\r\n { coord: point_hp }, //Hp----y\r\n ],\r\n ],\r\n },\r\n },\r\n {\r\n //a-b连线\r\n type: 'line',\r\n data: [\r\n [xData[2], yData[2]],\r\n [xData[1], yData[1]],\r\n ],\r\n lineStyle: {\r\n color: '#0000FF',\r\n type: 'solid',\r\n width: 1,\r\n },\r\n symbol: 'none',\r\n },\r\n {\r\n //a-b 延长线\r\n type: 'line',\r\n data: [\r\n [xData[1], yData[1]],\r\n [zero_ab[0], zero_ab[1]],\r\n ],\r\n lineStyle: {\r\n color: '#000000',\r\n type: 'dashed',\r\n width: 1,\r\n },\r\n symbol: 'none',\r\n },\r\n {\r\n //a-c连线\r\n type: 'line',\r\n data: [\r\n [xData[2], yData[2]],\r\n [xData[0], yData[0]],\r\n ],\r\n lineStyle: {\r\n color: '#0000FF',\r\n type: 'solid',\r\n width: 1,\r\n },\r\n symbol: 'none',\r\n },\r\n {\r\n //a-c 延长线\r\n type: 'line',\r\n data: [\r\n [xData[0], yData[0]],\r\n [zero_ac[0], zero_ac[1]],\r\n ],\r\n lineStyle: {\r\n color: '#000000',\r\n type: 'dashed',\r\n width: 1,\r\n },\r\n symbol: 'none',\r\n },\r\n {\r\n //a-Hp连线\r\n type: 'line',\r\n data: [[xData[2], yData[2]], point_hp],\r\n lineStyle: {\r\n color: '#0000FF',\r\n type: 'solid',\r\n width: 1,\r\n },\r\n symbol: 'none',\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 水泥、石灰标准曲线\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart90: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n //y轴原始数据\r\n let yDataSource = yDataArr[0]; // [1.2, 5.6, 10.8, 16, 20.8];\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x轴的数据\r\n let xData = xDataArr[0]; // [0, 2, 4, 6, 8];\r\n\r\n //重新处理x轴和y轴的数据,排除x轴后面为0的数据(因为有可能在单元格中,最后一个单元格的值可能没有填,这时候默认传的是0)\r\n let xDataCl = [],\r\n yDataSourceCl = [];\r\n for (let i = 0; i < xData.length; i++) {\r\n if (xData[i] != '/' && (i == 0 || (i > 0 && xData[i] != 0))) {\r\n xDataCl.push(xData[i]);\r\n yDataSourceCl.push(yDataSource[i]);\r\n } else if (i > 0 && xData[i] == 0) {\r\n break;\r\n }\r\n }\r\n xData = xDataCl;\r\n yDataSource = yDataSourceCl;\r\n\r\n //series的data数据、series的markPoint的data数据、series的markLine的data数据\r\n let seriesData = [],\r\n markPointData = [],\r\n markLineData = [...xData];\r\n\r\n //此目的是显示更多的x轴数据\r\n //假设x轴原始数据为[0, 2, 4, 6, 8],在这个数组中没有1、3、5等数据,此时就可以通过下面的方式进行增加\r\n /*\r\n\t\tfor (let i = 0; i < 20; i++) {\r\n\t\t\tif (!markLineData.some((item) => item == i)) {\r\n\t\t\t\tmarkLineData.push(i);\r\n\t\t\t}\r\n\t\t}\r\n\t\t*/\r\n\r\n //获取y轴趋势公式对象\r\n const gsS = EChartsUtilsComm.calcTrend(xData, yDataSource, xData[0]);\r\n\r\n //输出方程表达式\r\n if (chartExtJson != null) {\r\n if (chartExtJson.jxhslSnShScfc != null && chartExtJson.jxhslSnShScfc != undefined) {\r\n // console.log('输出公式:',`Y=${getRound(gsS.xl,0.0001)}X+${getRound(gsS.jj,0.0001)}`)\r\n if (gsS.xl == '' || gsS.jj == '') {\r\n sheet.setValue(chartExtJson.jxhslSnShScfc.row, chartExtJson.jxhslSnShScfc.col, '/');\r\n } else {\r\n sheet.setValue(\r\n chartExtJson.jxhslSnShScfc.row,\r\n chartExtJson.jxhslSnShScfc.col,\r\n `Y=${EChartsUtilsComm.getRound(gsS.xl, 0.0001)}X+${EChartsUtilsComm.getRound(gsS.jj, 0.0001)}`\r\n );\r\n }\r\n }\r\n }\r\n\r\n let yDataCopy = [];\r\n //获取y轴原始数据对应的趋势数据\r\n xData.forEach((item, index) => {\r\n let curYData = Number(EChartsUtilsComm.getRound(eval(gsS.gs.replace('x', item + '')), 0.01));\r\n if (isNaN(curYData)) {\r\n curYData = 0;\r\n }\r\n\r\n seriesData.push([item, curYData]);\r\n yDataCopy.push(curYData);\r\n markPointData.push({\r\n xAxis: item,\r\n yAxis: yDataSource[index],\r\n symbol: 'circle',\r\n symbolSize: 6,\r\n });\r\n\r\n //console.log(curYData, \"curYData\")\r\n });\r\n\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item[1] == 0 || item[1] == null || item[1] == undefined) {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n }\r\n if (yDataCopy.some((item) => item != 0 || item[1] == null || item[1] == undefined)) {\r\n yValIsAllNull = false;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 22,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 35,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].value[0] + ':' + datas[0].value[1] : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n splitLine: { show: false }, // 隐藏分割线\r\n axisLabel: { show: false }, // 隐藏刻度值\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n opacity: 0,\r\n },\r\n data: seriesData,\r\n markPoint: {\r\n data: markPointData,\r\n },\r\n markLine: {\r\n symbol: false, //取消箭头\r\n silent: true, //取消鼠标hover事件\r\n label: {\r\n position: 'start', //改变label位置\r\n formatter: (obj) => obj.value, //格式化显示的x轴标签内容\r\n },\r\n lineStyle: { color: '#ddd', type: 'solid' },\r\n data: markLineData.map((val) => {\r\n return {\r\n xAxis: val,\r\n };\r\n }),\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 延迟时间-强度曲线\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart110: (\r\n config: EChartsUtilsConfigModel,\r\n xDataArr: Array<Array<any>>,\r\n yDataArr: Array<Array<any>>,\r\n xDataArrSource: Array<Array<any>>,\r\n yDataArrSource: Array<Array<any>>\r\n ) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n const xDataSource = xDataArrSource[0]; // ['0.0','1.0','2.0','3.0','4.0','5.0'];\r\n\r\n let xData = [];\r\n xDataSource.forEach((item, index) => {\r\n if (item == '/') {\r\n xData.push(item);\r\n } else {\r\n xData.push(Number(item));\r\n }\r\n });\r\n\r\n //y轴的数据\r\n let yData = yDataArr[0]; // [4.4,4.3,4.3,4.2,4.1,3.7];\r\n let seriesData = [];\r\n xData.forEach((item, index) => {\r\n if (item != '/' && item != undefined && item != null) {\r\n seriesData.push([item, yData[index]]);\r\n }\r\n });\r\n\r\n let yValIsAllNull = false;\r\n if (seriesData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: 25,\r\n right: 15,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'category', //设置x轴为对数坐标轴\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n axisLabel: {\r\n // 使用formatter格式化标签\r\n formatter: function (value) {\r\n let curXName = '';\r\n for (let i = 0; i < xData.length; i++) {\r\n if (xData[i] == value) {\r\n curXName = xDataSource[i];\r\n if (curXName == '/') {\r\n curXName = '';\r\n }\r\n break;\r\n }\r\n }\r\n\r\n return curXName;\r\n },\r\n },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: seriesData,\r\n },\r\n ],\r\n };\r\n return option;\r\n },\r\n /**\r\n * 颗粒组成(筛分法)\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart130: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n // console.log(config);\r\n // console.log(xDataArr);\r\n // console.log(yDataArr);\r\n\r\n //x和y轴的数据\r\n const xData = xDataArr[0], // [60, 40, 20, 10, 5, 2, 1, 0.5, 0.25, 0.075],\r\n yData = yDataArr[0]; // [100.0, 100.0, 88.3, 69.3, 46.7, 27.0, 19.7, 5.6, 0.5, 0.3];\r\n let xMin = 0.01,\r\n xMax = 200;\r\n\r\n let seriesData = [];\r\n xData.forEach((item, index) => {\r\n seriesData.push([item == '筛底' ? 0 : item, yData[index]]);\r\n });\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item[1] == null || item[1] == undefined || item[1] == '/') {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n }\r\n if (yData.some((item) => item != null && item != undefined && item != '/')) {\r\n yValIsAllNull = false;\r\n }\r\n\r\n if (yValIsAllNull) {\r\n xMin = null;\r\n xMax = null;\r\n }\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: 20,\r\n right: 15,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'log', //设置x轴为对数坐标轴\r\n logBase: 10, //可以设置对数轴的底数,默认为10\r\n inverse: true,\r\n min: xMin,\r\n max: xMax,\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: seriesData,\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 回弹模量 (承载板法)\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart150: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n const xData = xDataArr[0], // [25, 50, 100, 150, 200],\r\n yData = yDataArr[0]; // [0.72, 1.07, 1.87, 2.63, 3.48];\r\n\r\n let seriesData = [];\r\n xData.forEach((item, index) => {\r\n seriesData.push([item, yData[index]]);\r\n });\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item[1] == null || item[1] == undefined || item[1] == '/') {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n }\r\n if (yData.some((item) => item != null && item != undefined && item != '/')) {\r\n yValIsAllNull = false;\r\n }\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 55,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 10,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n top: 18,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n splitLine: { show: false }, // 隐藏分割线\r\n axisLabel: { show: false }, // 隐藏刻度值\r\n position: 'top', //设置x轴在顶部显示\r\n },\r\n yAxis: [\r\n //双y轴,目的是使用第二个y轴来配置字符L显示在y轴下方箭头的位置\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n inverse: true, //y轴坐标轴向下\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: seriesData,\r\n markLine: {\r\n symbol: false, //取消箭头\r\n silent: true, //取消鼠标hover事件\r\n label: {\r\n position: 'start', //改变label位置\r\n formatter: (obj) => obj.value, //格式化显示的x轴标签内容\r\n },\r\n lineStyle: { color: '#ddd', type: 'solid' },\r\n data: xData.map((val) => {\r\n return {\r\n xAxis: val,\r\n };\r\n }),\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 土的回弹模量 (强度仪法)\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart170: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n const xData = xDataArr[0], // [25, 50, 100, 150, 200],\r\n yData = yDataArr[0]; // [0.72, 1.07, 1.87, 2.63, 3.48];\r\n\r\n let seriesData = [];\r\n xData.forEach((item, index) => {\r\n seriesData.push([item, yData[index]]);\r\n });\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item[1] == null || item[1] == undefined || item[1] == '/') {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n }\r\n if (yData.some((item) => item != null && item != undefined && item != '/')) {\r\n yValIsAllNull = false;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 55,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 10,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n top: 18,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n splitLine: { show: false }, // 隐藏分割线\r\n axisLabel: { show: false }, // 隐藏刻度值\r\n position: 'top', //设置x轴在顶部显示\r\n },\r\n yAxis: [\r\n //双y轴,目的是使用第二个y轴来配置字符L显示在y轴下方箭头的位置\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n inverse: true, //y轴坐标轴向下\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: seriesData,\r\n markLine: {\r\n symbol: false, //取消箭头\r\n silent: true, //取消鼠标hover事件\r\n label: {\r\n position: 'start', //改变label位置\r\n formatter: (obj) => obj.value, //格式化显示的x轴标签内容\r\n },\r\n lineStyle: { color: '#ddd', type: 'solid' },\r\n data: xData.map((val) => {\r\n return {\r\n xAxis: val,\r\n };\r\n }),\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 28d抗压强度与胶水比关系\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart190: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = '', // config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n let xData = xDataArr[0], // [2.32, 2.5, 2.7],\r\n yData = yDataArr[0]; // [42.5, 47.1, 49.1];\r\n\r\n //处理数据\r\n xData = xData.filter((item) => item != null && item != undefined && item != '/' && (item._code == null || item._code == undefined));\r\n yData = yData.filter((item) => item != null && item != undefined && item != '/' && (item._code == null || item._code == undefined));\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item == null || item == undefined || item == '/') {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n xData = [];\r\n }\r\n if (yData.some((item) => item != null && item != undefined && item != '/')) {\r\n yValIsAllNull = false;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 18,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n axisLabel: {\r\n // 使用formatter格式化标签\r\n formatter: function (value) {\r\n if (value == '/') {\r\n return '';\r\n } else {\r\n return value;\r\n }\r\n },\r\n },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: yData,\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 混凝土拌合物含气量\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart210: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n //x和y轴的原始数据\r\n let xDataSource = xDataArr[0], // [0.093, 0.081, 0.068, 0.063, 0.057, 0.052, 0.049, 0.044, 0.041, 0.038, 0.036],\r\n yDataSource = yDataArr[0]; // [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10];\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //series需要的数据\r\n const seriesData = [];\r\n\r\n for (let i = xDataSource.length - 1; i >= 0; i--) {\r\n const item = xDataSource[i];\r\n\r\n if (item != null && item != undefined && item != '/' && (item._error == null || item._error == undefined)) {\r\n seriesData.push([item, yDataSource[i]]);\r\n }\r\n }\r\n\r\n //x和y轴的字体大小\r\n const xyFontSize = 10;\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xDataSource.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xDataSource.forEach((item) => {\r\n if (item == null || item == undefined || item == '/' || (item._error != null && item._error != undefined)) {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xDataSource.length) {\r\n yValIsAllNull = true;\r\n //xDataSource = [];\r\n }\r\n if (yDataSource.some((item) => item != null && item != undefined && item != '/')) {\r\n yValIsAllNull = false;\r\n }\r\n\r\n const getXline = () => {\r\n let arr = [];\r\n [0, 0.02, 0.04, 0.06, 0.08, 0.1].forEach((val) => {\r\n xDataSource.forEach((item) => {\r\n let obj: any = { xAxis: '' };\r\n\r\n if (item == '/') {\r\n obj.xAxis = '';\r\n arr.push(obj);\r\n } else {\r\n obj.xAxis = val;\r\n arr.push(obj);\r\n }\r\n });\r\n });\r\n\r\n //去重\r\n let uniqueData = arr.filter((item, index, self) => index === self.findIndex((t) => t.xAxis == item.xAxis));\r\n return nullCount == xDataSource.length ? [] : uniqueData;\r\n };\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: !yValIsAllNull && seriesData.length > 0 ? 30 : 25,\r\n right: 10,\r\n bottom: 40,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].value[0] + ':' + datas[0].value[1] : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n splitLine: { show: false }, // 隐藏分割线\r\n axisLabel: { show: false }, // 隐藏刻度值\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull && seriesData.length > 0 ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n axisLabel: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: seriesData,\r\n markLine: {\r\n symbol: false, //取消箭头\r\n silent: true, //取消鼠标hover事件\r\n label: {\r\n position: 'start', //改变label位置\r\n formatter: (obj) => obj.value, //格式化显示的x轴标签内容\r\n fontSize: xyFontSize,\r\n },\r\n lineStyle: { color: '#ddd', type: 'solid' },\r\n data: getXline(),\r\n // data: [0, 0.02, 0.04, 0.06, 0.08, 0.1].map((val) => {\r\n // return {\r\n // xAxis: val,\r\n // }\r\n // }),\r\n },\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 混凝土拌合物凝结时间\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart230: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n /*\r\n\t\t\t此处需要注意的是,如果单元格A3=A1-A2,就需要将A3=TEXT(A1-A2, \"h\"\":\"\"m\")\r\n\r\n\t\t\tExcel中默认时间相减得到的是天为单位,因此此处使用了TEXT函数来格式化相减的时间差格式\r\n\r\n\t\t\t=TEXT(A1-A2, \"h\"\":\"\"m\")\r\n\t\t\t=INT(A1-A2) & \"天\" & TEXT(A1-A2, \"h\"\"小时\"\"m\"\"分\"\"\")\r\n\r\n\t\t*/\r\n\r\n //折线的数量\r\n let lineCount = xDataArr.length;\r\n\r\n //原始数据\r\n let xDataSource1 = [], // ['6:20', '6:50', '7:20', '7:50', '7:56', '8:26', '8:56', '9:26', '9:56', '10:11'],\r\n xDataSource2 = [], // ['6:27', '6:57', '7:32', '8:02', '8:05', '8:35', '9:05', '9:35', '10:05', '10:22'],\r\n xDataSource3 = [], // ['6:10', '6:40', '7:10', '7:40', '8:03', '8:13', '8:42', '9:12', '9:40', '10:12'],\r\n yDataSource1 = [], // [0.8, 1.2, 2.2, 3.4, 3.6, 7.8, 11.8, 16.6, 24.6, 28.2],\r\n yDataSource2 = [], // [0.8, 1.3, 2.4, 3.4, 3.5, 7.7, 12.2, 16.7, 25, 28.2],\r\n yDataSource3 = []; // [0.7, 1, 1.9, 3, 3.3, 3.5, 8.2, 13.8, 20.2, 28.2];\r\n\r\n //折线1\r\n xDataSource1 = EChartsUtilsComm.filterNullEmptyErrArray(xDataArr[0]); // ['6:20', '6:50', '7:20', '7:50', '7:56', '8:26', '8:56', '9:26', '9:56', '10:11'],\r\n yDataSource1 = EChartsUtilsComm.filterNullEmptyErrArray(yDataArr[0]); // [0.8, 1.2, 2.2, 3.4, 3.6, 7.8, 11.8, 16.6, 24.6, 28.2],\r\n\r\n //折线2\r\n if (lineCount == 2) {\r\n xDataSource2 = EChartsUtilsComm.filterNullEmptyErrArray(xDataArr[1]); // ['6:27', '6:57', '7:32', '8:02', '8:05', '8:35', '9:05', '9:35', '10:05', '10:22'],\r\n yDataSource2 = EChartsUtilsComm.filterNullEmptyErrArray(yDataArr[1]); // [0.8, 1.3, 2.4, 3.4, 3.5, 7.7, 12.2, 16.7, 25, 28.2],\r\n }\r\n //折线3\r\n if (lineCount == 3) {\r\n xDataSource2 = EChartsUtilsComm.filterNullEmptyErrArray(xDataArr[1]); // ['6:27', '6:57', '7:32', '8:02', '8:05', '8:35', '9:05', '9:35', '10:05', '10:22'],\r\n yDataSource2 = EChartsUtilsComm.filterNullEmptyErrArray(yDataArr[1]); // [0.8, 1.3, 2.4, 3.4, 3.5, 7.7, 12.2, 16.7, 25, 28.2],\r\n xDataSource3 = EChartsUtilsComm.filterNullEmptyErrArray(xDataArr[2]); // ['6:10', '6:40', '7:10', '7:40', '8:03', '8:13', '8:42', '9:12', '9:40', '10:12'],\r\n yDataSource3 = EChartsUtilsComm.filterNullEmptyErrArray(yDataArr[2]); // [0.7, 1, 1.9, 3, 3.3, 3.5, 8.2, 13.8, 20.2, 28.2];\r\n }\r\n\r\n //3条线的x轴数据\r\n let xData1 = [],\r\n xData2 = [],\r\n xData3 = [];\r\n\r\n //组装数据\r\n\r\n xDataSource1.forEach((item, index) => {\r\n //js的时间格式\r\n if (typeof item == 'object') {\r\n xData1.push(item.getHours() * 60 + item.getMinutes());\r\n }\r\n //数字\r\n else if (typeof item == 'number') {\r\n xData1.push(item);\r\n }\r\n //文本格式\r\n else {\r\n const curArr = item.split(':');\r\n const curItemMins = Number(curArr[0]) * 60 + Number(curArr[1]);\r\n xData1.push(curItemMins);\r\n }\r\n });\r\n\r\n xDataSource2.forEach((item, index) => {\r\n //js的时间格式\r\n if (typeof item == 'object') {\r\n xData2.push(item.getHours() * 60 + item.getMinutes());\r\n }\r\n //数字\r\n else if (typeof item == 'number') {\r\n xData2.push(item);\r\n }\r\n //文本格式\r\n else {\r\n const curArr = item.split(':');\r\n const curItemMins = Number(curArr[0]) * 60 + Number(curArr[1]);\r\n xData2.push(curItemMins);\r\n }\r\n });\r\n\r\n xDataSource3.forEach((item, index) => {\r\n //js的时间格式\r\n if (typeof item == 'object') {\r\n xData3.push(item.getHours() * 60 + item.getMinutes());\r\n }\r\n //数字\r\n else if (typeof item == 'number') {\r\n xData3.push(item);\r\n }\r\n //文本格式\r\n else {\r\n const curArr = item.split(':');\r\n const curItemMins = Number(curArr[0]) * 60 + Number(curArr[1]);\r\n xData3.push(curItemMins);\r\n }\r\n });\r\n\r\n //x轴数据前后增加一个点,y轴数据前后也增加一个点\r\n if (xDataSource1.length > 0) {\r\n xData1.push(xData1[xData1.length - 1] + 20);\r\n xData1.unshift(xData1[0] - 20);\r\n yDataSource1.push(null);\r\n yDataSource1.unshift(null);\r\n }\r\n\r\n if (lineCount == 2) {\r\n if (xDataSource2.length > 0) {\r\n xData2.push(xData2[xData2.length - 1] + 20);\r\n xData2.unshift(xData2[0] - 20);\r\n yDataSource2.push(null);\r\n yDataSource2.unshift(null);\r\n }\r\n }\r\n if (lineCount == 3) {\r\n if (xDataSource3.length == 0) {\r\n xData2.push(xData2[xData2.length - 1] + 20);\r\n xData2.unshift(xData2[0] - 20);\r\n yDataSource2.push(null);\r\n yDataSource2.unshift(null);\r\n xData3.push(xData3[xData3.length - 1] + 20);\r\n xData3.unshift(xData3[0] - 20);\r\n yDataSource3.push(null);\r\n yDataSource3.unshift(null);\r\n }\r\n }\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName;\r\n\r\n //获取xAxis需要的数据\r\n const getxAxisObj = (type, data) => {\r\n return {\r\n type: 'category',\r\n data: data,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n show: type == 1,\r\n splitLine: {\r\n show: true,\r\n },\r\n };\r\n };\r\n\r\n let xAxisData = [getxAxisObj(1, xData1)];\r\n if (lineCount == 2) {\r\n xAxisData.push(getxAxisObj(2, xData2));\r\n }\r\n if (lineCount == 3) {\r\n xAxisData.push(getxAxisObj(2, xData2));\r\n xAxisData.push(getxAxisObj(3, xData3));\r\n }\r\n\r\n //获取series需要的数据\r\n const getLineObj = (type, data) => {\r\n const name = type == 1 ? '第一组' : type == 2 ? '第二组' : '第三组';\r\n const symbol = type == 1 ? 'rect' : type == 2 ? 'triangle' : 'circle';\r\n const lineType = type == 1 ? 'solid' : type == 2 ? 'dotted' : [10, 5];\r\n const color =\r\n type == 1 && lineData.length >= 1\r\n ? lineData[0].lineColor\r\n : type == 2 && lineData.length >= 2\r\n ? lineData[1].lineColor\r\n : type == 3 && lineData.length >= 3\r\n ? lineData[2].lineColor\r\n : '#000';\r\n\r\n let obj = {\r\n name: name,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: symbol, //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: color,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n type: lineType,\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: color,\r\n },\r\n data: data,\r\n };\r\n\r\n return obj;\r\n };\r\n\r\n //series: [getLineObj(1, yDataSource1), getLineObj(2, yDataSource2), getLineObj(3, yDataSource3)],\r\n let seriesData = [getLineObj(1, yDataSource1)];\r\n if (lineCount == 2) {\r\n if (yDataSource2.length > 0) {\r\n seriesData.push(getLineObj(2, yDataSource2));\r\n }\r\n }\r\n if (lineCount == 3) {\r\n if (yDataSource2.length > 0) {\r\n seriesData.push(getLineObj(2, yDataSource2));\r\n }\r\n if (yDataSource3.length > 0) {\r\n seriesData.push(getLineObj(3, yDataSource3));\r\n }\r\n }\r\n\r\n let legendData = lineCount == 1 ? ['第一组'] : lineCount == 2 ? ['第一组', '第二组'] : ['第一组', '第二组', '第三组'],\r\n legendSelected: any =\r\n lineCount == 1 ? { 第一组: true } : lineCount == 2 ? { 第一组: true, 第二组: true } : { 第一组: true, 第二组: true, 第三组: true };\r\n\r\n //console.log(xData1,xData2,xData3,seriesData)\r\n let yValIsAllNull = false;\r\n let xValIsAllNull = false;\r\n let topmargin = 0;\r\n //为空不展示\r\n if (xDataSource1.length == 0) {\r\n xValIsAllNull = true;\r\n topmargin = 15;\r\n\r\n legendData = ['第二组', '第三组'];\r\n legendSelected = { 第一组: false, 第二组: true, 第三组: true };\r\n\r\n xAxisData = [];\r\n seriesData = [];\r\n\r\n xAxisData.push(getxAxisObj(1, xData2));\r\n xAxisData.push(getxAxisObj(3, xData3));\r\n seriesData.push(getLineObj(2, yDataSource2));\r\n seriesData.push(getLineObj(3, yDataSource3));\r\n\r\n if (xDataSource2.length == 0) {\r\n topmargin = 35;\r\n\r\n legendData = ['第三组'];\r\n legendSelected = { 第一组: false, 第二组: false, 第三组: true };\r\n\r\n xAxisData = [];\r\n seriesData = [];\r\n\r\n xAxisData.push(getxAxisObj(1, xData3));\r\n seriesData.push(getLineObj(3, yDataSource3));\r\n\r\n if (xDataSource3.length == 0) {\r\n topmargin = 0;\r\n\r\n yValIsAllNull = true;\r\n legendData = [];\r\n legendSelected = { 第一组: false, 第二组: false, 第三组: false };\r\n xAxisData = [];\r\n seriesData = [];\r\n xAxisData.push(getxAxisObj(1, []));\r\n seriesData.push(getLineObj(3, []));\r\n }\r\n }\r\n } else if (xDataSource2.length == 0) {\r\n topmargin = 15;\r\n xValIsAllNull = true;\r\n legendData = ['第一组', '第三组'];\r\n legendSelected = { 第一组: true, 第二组: false, 第三组: true };\r\n\r\n xAxisData = [];\r\n seriesData = [];\r\n\r\n xAxisData.push(getxAxisObj(1, xData1));\r\n xAxisData.push(getxAxisObj(3, xData3));\r\n\r\n seriesData.push(getLineObj(1, yDataSource1));\r\n seriesData.push(getLineObj(3, yDataSource3));\r\n\r\n if (xDataSource1.length == 0) {\r\n topmargin = 35;\r\n\r\n legendData = ['第三组'];\r\n legendSelected = { 第一组: false, 第二组: false, 第三组: true };\r\n\r\n xAxisData = [];\r\n seriesData = [];\r\n\r\n xAxisData.push(getxAxisObj(1, xData1));\r\n seriesData.push(getLineObj(3, yDataSource1));\r\n\r\n if (xDataSource3.length == 0) {\r\n topmargin = 0;\r\n\r\n yValIsAllNull = true;\r\n legendData = [];\r\n legendSelected = { 第一组: false, 第二组: false, 第三组: false };\r\n xAxisData = [];\r\n seriesData = [];\r\n xAxisData.push(getxAxisObj(1, []));\r\n seriesData.push(getLineObj(3, []));\r\n }\r\n }\r\n } else if (xDataSource3.length == 0) {\r\n topmargin = 15;\r\n xValIsAllNull = true;\r\n legendData = ['第一组', '第二组'];\r\n legendSelected = { 第一组: true, 第二组: true, 第三组: false };\r\n\r\n xAxisData = [];\r\n seriesData = [];\r\n xAxisData.push(getxAxisObj(1, xData1));\r\n xAxisData.push(getxAxisObj(2, xData2));\r\n seriesData.push(getLineObj(1, yDataSource1));\r\n seriesData.push(getLineObj(2, yDataSource2));\r\n\r\n if (xDataSource1.length == 0) {\r\n topmargin = 35;\r\n legendData = ['第二组'];\r\n legendSelected = { 第一组: false, 第二组: true, 第三组: false };\r\n\r\n xAxisData = [];\r\n seriesData = [];\r\n\r\n xAxisData.push(getxAxisObj(1, xData2));\r\n seriesData.push(getLineObj(2, yDataSource2));\r\n\r\n if (xDataSource2.length == 0) {\r\n topmargin = 0;\r\n yValIsAllNull = true;\r\n legendData = [];\r\n legendSelected = { 第一组: false, 第二组: false, 第三组: false };\r\n xAxisData = [];\r\n seriesData = [];\r\n xAxisData.push(getxAxisObj(1, []));\r\n seriesData.push(getLineObj(2, []));\r\n }\r\n }\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: !xValIsAllNull ? -5 : topmargin,\r\n left: 30,\r\n right: 10,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n left: 'center',\r\n top: 16,\r\n data: legendData,\r\n selected: legendSelected,\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: xAxisData,\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: seriesData,\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 颗粒组成(密度计法)\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart250: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n const xData = xDataArr[0], // [0.0316, 0.0224, 0.0115, 0.0075, 0.0058, 0.0033, 0.0031, 0.0024, 0.001, 0.0008],\r\n yData = yDataArr[0]; // [83.0, 78.8, 53.8, 42.6, 33.7, 27.8, 23.2, 19.2, 13.0, 7.7];\r\n\r\n let seriesData = [];\r\n xData.forEach((item, index) => {\r\n seriesData.push([item, yData[index]]);\r\n });\r\n\r\n let xmin = 0.001,\r\n xmax = 100;\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.length == 0) {\r\n yValIsAllNull = true;\r\n }\r\n let nullCount = 0;\r\n xData.forEach((item) => {\r\n if (item == null || item == undefined || item == '/') {\r\n nullCount++;\r\n }\r\n });\r\n if (nullCount == xData.length) {\r\n yValIsAllNull = true;\r\n xmin = null;\r\n xmax = null;\r\n }\r\n if (yData.some((item) => item != null && item != undefined && item != '/')) {\r\n yValIsAllNull = false;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: 20,\r\n right: 15,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'log', //设置x轴为对数坐标轴\r\n logBase: 10, //可以设置对数轴的底数,默认为10\r\n inverse: true,\r\n min: xmin,\r\n max: xmax,\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: seriesData,\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 承载比(CBR)\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart270: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n // const xDataSource1 = xDataArr[0], // [36, 102, 316, 678, 917, 1177, 1396, 1478, 1620, 1651, 1753, 1789, 1855],\r\n // \txDataSource2 = xDataArr[1], // [56, 122, 357, 617, 958, 1223, 1376, 1493, 1631, 1682, 1783, 1824, 1885],\r\n // \txDataSource3 = xDataArr[2], // [66, 168, 443, 729, 994, 1213, 1411, 1529, 1651, 1722, 1783, 1824, 1890],\r\n // \tyDataSource1 = yDataArr[0], // [0.31, 0.51, 0.94, 1.47, 2.0, 2.48, 2.92, 3.41, 3.87, 4.37, 4.86, 5.36, 5.88],\r\n // \tyDataSource2 = yDataArr[1], // [0.26, 0.5, 1.01, 1.52, 2.02, 2.52, 2.98, 3.49, 3.99, 4.49, 4.98, 5.48, 5.98],\r\n // \tyDataSource3 = yDataArr[2]; // [0.32, 0.52, 1.01, 1.5, 1.99, 2.49, 2.98, 3.47, 3.96, 4.46, 4.95, 5.44, 5.93];\r\n\r\n let xDataSource1 = [],\r\n xDataSource2 = [],\r\n xDataSource3 = [],\r\n yDataSource1 = [],\r\n yDataSource2 = [],\r\n yDataSource3 = [];\r\n\r\n //排除原始数据为0的数据\r\n xDataArr[0].forEach((item, index) => {\r\n if (item != 0 && yDataArr[0][index] != 0) {\r\n xDataSource1.push(item);\r\n yDataSource1.push(yDataArr[0][index]);\r\n }\r\n });\r\n xDataArr[1].forEach((item, index) => {\r\n if (item != 0 && yDataArr[1][index] != 0) {\r\n xDataSource2.push(item);\r\n yDataSource2.push(yDataArr[1][index]);\r\n }\r\n });\r\n xDataArr[2].forEach((item, index) => {\r\n if (item != 0 && yDataArr[2][index] != 0) {\r\n xDataSource3.push(item);\r\n yDataSource3.push(yDataArr[2][index]);\r\n }\r\n });\r\n\r\n /**\r\n * 获取series需要的3条线配置\r\n * @param type 线类型(1:筛分曲线、2:上限、3:下限)\r\n * @param data 对应的坐标点数据\r\n */\r\n const getLineObj = (type, xData, yData) => {\r\n const name = `曲线${type}`;\r\n const symbol = type == 1 ? 'rect' : type == 2 ? 'triangle' : 'circle';\r\n const lineType = type == 1 ? 'solid' : type == 2 ? 'dotted' : [10, 5];\r\n const color = type == 1 ? lineData[0].lineColor : type == 2 ? lineData[1].lineColor : lineData[2].lineColor; //ttype == 1 ? '#F56C6C' : type == 2 ? '#409EFF' : '#000';\r\n\r\n const seriesData = [];\r\n xData.forEach((item, index) => {\r\n seriesData.push([item, yData[index]]);\r\n });\r\n\r\n return {\r\n name: name,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: symbol, //符号类型\r\n symbolSize: 5, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: color,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n type: lineType,\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: color,\r\n },\r\n data: seriesData,\r\n };\r\n };\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (\r\n xDataSource1.every((item) => item == '/') &&\r\n xDataSource2.every((item) => item == '/') &&\r\n xDataSource3.every((item) => item == '/') &&\r\n yDataSource1.every((item) => item == '/') &&\r\n yDataSource2.every((item) => item == '/') &&\r\n yDataSource3.every((item) => item == '/')\r\n ) {\r\n yValIsAllNull = true;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 35,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 20,\r\n bottom: 5,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].value[0] + ')' + ':' + datas[0].value[1] : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n top: 16,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value', //category\r\n //data: xDataSource1,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n position: 'top', //设置x轴在顶部显示\r\n nameGap: 5, //坐标轴名称与轴线之间的距离\r\n nameLocation: 'end', //设置x轴显示的名称的位置在末端,注意:需要配置grid.right一起使用,不然可能会被遮住\r\n },\r\n yAxis: [\r\n //双y轴,目的是使用第二个y轴来配置字符L显示在y轴下方箭头的位置\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n inverse: true, //y轴坐标轴向下\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [getLineObj(1, xDataSource1, yDataSource1), getLineObj(2, xDataSource2, yDataSource2), getLineObj(3, xDataSource3, yDataSource3)],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 压实度-吸水量,膨胀率,CBR-279、280和281\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart279_280_281: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle, //压实度-吸水量关系曲线 压实度-膨胀率关系曲线 压实度-CBR关系曲线\r\n xName = config.chartXName, //压实度(%) 压实度(%) 压实度(%)\r\n yName = config.chartYName, //吸水量(g) 膨胀率(%) CBR(%)\r\n legendName = '图例1';\r\n\r\n //y轴最大最小数据加减数字\r\n let jjNum = config.chartType == 279 ? 5 : config.chartType == 280 ? 0.1 : 0.15;\r\n\r\n //x和y轴的数据\r\n let xData = xDataArr[0], // [90.3, 95.6, 99.5],\r\n yData = yDataArr[0], // [245, 206, 163],\r\n xAxisMin = Math.min(...xData),\r\n yAxisMin = Number(EChartsUtilsComm.getRound(Math.min(...yData) - jjNum, 0.001)),\r\n yAxisMax = Number(EChartsUtilsComm.getRound(Math.max(...yData) + jjNum, 0.001));\r\n //yData1 = [245, 206, 163],\r\n //yData2 = [3.49, 2.69, 2.34];\r\n //yData3 = [4, 4.7, 5.7];\r\n //修约:0.001 0.001 0.001\r\n //y最大最小加减数:5 0.1 0.15\r\n\r\n xAxisMin = Number(EChartsUtilsComm.getRound(xAxisMin - xAxisMin * 0.01, 0.001));\r\n\r\n let seriesData = [];\r\n xData.forEach((item, index) => {\r\n seriesData.push([item, yData[index]]);\r\n });\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (yData.every((item) => item == '/')) {\r\n yValIsAllNull = true;\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: 20,\r\n right: 15,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value', //设置x轴为对数坐标轴\r\n min: xAxisMin,\r\n max: 100,\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n show: true, //y轴默认是不显示的\r\n },\r\n min: yAxisMin,\r\n max: yAxisMax,\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: seriesData,\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 承载比(CBR)(路强仪)\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart290: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n let xDataSource1 = xDataArr[0], // [36, 102, 316, 678, 917, 1177, 1396, 1478, 1620, 1651, 1753, 1789, 1855],\r\n xDataSource2 = xDataArr[0], // [56, 122, 357, 617, 958, 1223, 1376, 1493, 1631, 1682, 1783, 1824, 1885],\r\n xDataSource3 = xDataArr[0], // [66, 168, 443, 729, 994, 1213, 1411, 1529, 1651, 1722, 1783, 1824, 1890],\r\n yDataSource1 = yDataArr[0], // [0.31, 0.51, 0.94, 1.47, 2.0, 2.48, 2.92, 3.41, 3.87, 4.37, 4.86, 5.36, 5.88],\r\n yDataSource2 = yDataArr[1], // [0.26, 0.5, 1.01, 1.52, 2.02, 2.52, 2.98, 3.49, 3.99, 4.49, 4.98, 5.48, 5.98],\r\n yDataSource3 = yDataArr[2]; // [0.32, 0.52, 1.01, 1.5, 1.99, 2.49, 2.98, 3.47, 3.96, 4.46, 4.95, 5.44, 5.93];\r\n\r\n /**\r\n * 获取series需要的3条线配置\r\n * @param type 线类型(1:筛分曲线、2:上限、3:下限)\r\n * @param data 对应的坐标点数据\r\n */\r\n const getLineObj = (type, data) => {\r\n const name = `曲线${type}`;\r\n const symbol = type == 1 ? 'rect' : type == 2 ? 'triangle' : 'circle';\r\n const lineType = type == 1 ? 'solid' : type == 2 ? 'dotted' : [10, 5];\r\n const color = type == 1 ? lineData[0].lineColor : type == 2 ? lineData[1].lineColor : lineData[2].lineColor; //ttype == 1 ? '#F56C6C' : type == 2 ? '#409EFF' : '#000';\r\n\r\n return {\r\n name: name,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: symbol, //符号类型\r\n symbolSize: 5, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: color,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n type: lineType,\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: color,\r\n },\r\n data: data,\r\n };\r\n };\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (\r\n xDataSource1.every((item) => item == '/') &&\r\n xDataSource2.every((item) => item == '/') &&\r\n xDataSource3.every((item) => item == '/') &&\r\n yDataSource1.every((item) => item == '/') &&\r\n yDataSource2.every((item) => item == '/') &&\r\n yDataSource3.every((item) => item == '/')\r\n ) {\r\n yValIsAllNull = true;\r\n xDataSource1 = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 35,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 5,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n top: 16,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: xDataSource1,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n splitLine: { show: true },\r\n position: 'top', //设置x轴在顶部显示\r\n nameGap: 5, //坐标轴名称与轴线之间的距离\r\n nameLocation: 'end', //设置x轴显示的名称的位置在末端,注意:需要配置grid.right一起使用,不然可能会被遮住\r\n axisLabel: {\r\n // 使用formatter格式化标签\r\n formatter: function (value) {\r\n if (value == '/') {\r\n return '';\r\n } else {\r\n return value;\r\n }\r\n },\r\n },\r\n },\r\n yAxis: [\r\n //双y轴,目的是使用第二个y轴来配置字符L显示在y轴下方箭头的位置\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n inverse: true, //y轴坐标轴向下\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [getLineObj(1, yDataSource1), getLineObj(2, yDataSource2), getLineObj(3, yDataSource3)],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 土基回弹模量\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart310: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n let xData = xDataArr[0], // [0.02, 0.04, 0.06, 0.08, 0.14, 0.18, 0.22, 0.26, 0.3, 0.34],\r\n yData = yDataArr[0]; // [6, 10, 12, 16, 20, 28, 36, 44, 54, 68];\r\n\r\n let xDataCl = [],\r\n yDataCl = [];\r\n xData.forEach((item, index) => {\r\n if (item != null && item != undefined && item != '/' && (item._code == null || item._code == undefined)) {\r\n xDataCl.push(item);\r\n yDataCl.push(yData[index]);\r\n }\r\n });\r\n xData = xDataCl;\r\n yData = yDataCl;\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (\r\n xData.every((item) => item == '/' || (item._code != null && item._code != undefined)) &&\r\n yData.every((item) => item == '/' || (item._code != null && item._code != undefined))\r\n ) {\r\n yValIsAllNull = true;\r\n xData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 35,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 20,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n top: 16,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: xData,\r\n axisLabel: {\r\n // 使用formatter格式化标签\r\n formatter: function (value) {\r\n if (value == '/') {\r\n return '';\r\n } else {\r\n return value;\r\n }\r\n },\r\n },\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n axisLine: {\r\n //设置x轴箭头效果\r\n symbol: ['none', 'arrow'], //默认是['none', 'none'],可以设置为['arrow', 'none']或['none', 'arrow']等来分别控制起始和结束的箭头\r\n symbolSize: 10, //箭头大小\r\n },\r\n splitLine: { show: true },\r\n position: 'top', //设置x轴在顶部显示\r\n name: 'p', //设置x轴显示的名称\r\n nameGap: 5, //坐标轴名称与轴线之间的距离\r\n nameLocation: 'end', //设置x轴显示的名称的位置在末端,注意:需要配置grid.right一起使用,不然可能会被遮住\r\n },\r\n yAxis: [\r\n //双y轴,目的是使用第二个y轴来配置字符L显示在y轴下方箭头的位置\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 30 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n inverse: true, //y轴坐标轴向下\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n //设置y轴箭头效果\r\n show: true, //y轴默认是不显示的\r\n symbol: ['arrow', 'none'], //默认是['none', 'none'],可以设置为['arrow', 'none']或['none', 'arrow']等来分别控制起始和结束的箭头\r\n symbolSize: 10, //箭头大小\r\n },\r\n },\r\n {\r\n //配置符号L的显示\r\n name: 'L',\r\n nameRotate: 0,\r\n nameLocation: 'end',\r\n nameGap: 5, //坐标轴名称与轴线之间的距离\r\n position: 'left',\r\n inverse: true, //y轴坐标轴向下\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: yData,\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 布氏粘度计\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart330: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>, sheet: any) => {\r\n let lineData = JSON.parse(config.chartLinesJson);\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n let title = '', //config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //x和y轴的数据\r\n let xData = xDataArr[0],\r\n yData = yDataArr[0];\r\n\r\n //获取y轴趋势公式对象\r\n const gsS: any = EChartsUtilsComm.calcTrend(xData, yData, xData[0]);\r\n\r\n //黏度为0.15Pa·s、0.19Pa·s、0.25Pa·s、0.31Pa·s时的温度\r\n let wd015 = EChartsUtilsComm.getRound((0.15 - gsS.jj) / gsS.xl, 0),\r\n wd019 = EChartsUtilsComm.getRound((0.19 - gsS.jj) / gsS.xl, 0),\r\n wd025 = EChartsUtilsComm.getRound((0.25 - gsS.jj) / gsS.xl, 0),\r\n wd031 = EChartsUtilsComm.getRound((0.31 - gsS.jj) / gsS.xl, 0);\r\n\r\n if (wd015 == Infinity) {\r\n wd015 = 0;\r\n }\r\n if (wd019 == Infinity) {\r\n wd019 = 0;\r\n }\r\n if (wd025 == Infinity) {\r\n wd025 = 0;\r\n }\r\n if (wd031 == Infinity) {\r\n wd031 = 0;\r\n }\r\n //输出“拌合温度范围 ℃”和“压实成型温度范围 ℃”\r\n let wdBh = `${wd015}~${wd019}`,\r\n wdYs = `${wd025}~${wd031}`;\r\n // console.log('输出温度:', wdBh, wdYs);\r\n\r\n //设置Sheet单元格的值(拌合温度和压实成型温度范围)\r\n if (chartExtJson != null) {\r\n if (wd015 == 0 && wd019 == 0) {\r\n sheet.setValue(chartExtJson.bszdjBh.row, chartExtJson.bszdjBh.col, '/');\r\n } else {\r\n sheet.setValue(chartExtJson.bszdjBh.row, chartExtJson.bszdjBh.col, wdBh);\r\n }\r\n if (wd025 == 0 && wd031 == 0) {\r\n sheet.setValue(chartExtJson.bszdjYs.row, chartExtJson.bszdjYs.col, '/');\r\n } else {\r\n sheet.setValue(chartExtJson.bszdjYs.row, chartExtJson.bszdjYs.col, wdYs);\r\n }\r\n }\r\n\r\n //验证是否没有任何数据,以便控制显示y轴的名称的距离位置\r\n let yValIsAllNull = false;\r\n if (xData.every((item) => item == '/') && yData.every((item) => item == '/')) {\r\n yValIsAllNull = true;\r\n xData = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 10,\r\n left: !yValIsAllNull ? 30 : 25,\r\n right: 10,\r\n bottom: 20,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas.length > 0 ? datas[0].seriesName + '(' + datas[0].name + ')' + ':' + datas[0].value : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 18,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'category',\r\n data: xData,\r\n axisTick: {\r\n alignWithLabel: true, //使得刻度线和标签对齐\r\n },\r\n axisLabel: {\r\n // 使用formatter格式化标签\r\n formatter: function (value) {\r\n if (value == '/') {\r\n return '';\r\n } else {\r\n return value;\r\n }\r\n },\r\n },\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !yValIsAllNull ? 25 : 5,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n //splitNumber: 10, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n axisLine: {\r\n show: true, //y轴默认是不显示的\r\n },\r\n },\r\n ],\r\n series: [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n smooth: true, //平滑的线条\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle', //符号类型\r\n symbolSize: 6, //符号大小\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineData[0].lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineData[0].lineColor,\r\n },\r\n data: yData,\r\n },\r\n ],\r\n };\r\n\r\n return option;\r\n },\r\n /**\r\n * 液限碟式仪\r\n * @param config 折线配置\r\n * @param xDataArr x轴原始数据(二维数组)\r\n * @param yDataArr y轴原始数据(二维数组)\r\n * @returns 返回ECharts配置项\r\n */\r\n chart350: (config: EChartsUtilsConfigModel, xDataArr: Array<Array<any>>, yDataArr: Array<Array<any>>) => {\r\n let lineData = JSON.parse(config.chartLinesJson),\r\n lineColor = lineData[0].lineColor;\r\n\r\n //击数N(次)、含水率w(%)、y轴第一个趋势数据、y轴第二个趋势数据、25的趋势数据、y轴最小值、y轴最大值\r\n const jsN = [xDataArr[0][0], xDataArr[0][1]], // [18, 30],\r\n hsl = [yDataArr[0][0], yDataArr[0][1]], // [22.1, 11.5],\r\n //通过calcTrend获取y轴第一个趋势数据、y轴第二个趋势数据、25的趋势数据\r\n yVal1 = Number(EChartsUtilsComm.getRound(EChartsUtilsComm.calcTrend(jsN, hsl, jsN[0]).y, 0.1)),\r\n yVal2 = Number(EChartsUtilsComm.getRound(EChartsUtilsComm.calcTrend(jsN, hsl, jsN[1]).y, 0.1)),\r\n yVal25 = Number(EChartsUtilsComm.getRound(EChartsUtilsComm.calcTrend(jsN, hsl, 25).y, 0.1)),\r\n //通过calcTrend获取y轴的趋势数据,然后分别-2和+2\r\n yAxisMin = Math.floor(Number(yVal2)) - 2,\r\n yAxisMax = Math.floor(Number(yVal1)) + 2;\r\n\r\n let title = config.chartTitle,\r\n xName = config.chartXName,\r\n yName = config.chartYName,\r\n legendName = '图例1';\r\n\r\n //检测是否所有数据都为空\r\n let isAllNull = true;\r\n isAllNull = xDataArr[0].filter((item) => item != null && item != undefined && item != '/').length == 0;\r\n if (isAllNull) {\r\n isAllNull = yDataArr[0].filter((item) => item != null && item != undefined && item != '/').length == 0;\r\n }\r\n\r\n //x和y轴的字体大小\r\n const xyFontSize = 8;\r\n\r\n let seriesObjs = [\r\n {\r\n name: legendName,\r\n type: 'line',\r\n //设置数据点形状(实心),参考文档:https://echarts.apache.org/zh/option.html#series-line.symbol\r\n symbol: 'circle',\r\n z: 10, //控制曲线的浮动层级,避免在markLine下方被遮住\r\n //线条的颜色\r\n lineStyle: {\r\n color: lineColor,\r\n //线条类型(solid:实线、dashed:粗虚线、dotted:细虚线)\r\n // type: 'dotted',\r\n },\r\n //线条上数据点的颜色\r\n itemStyle: {\r\n color: lineColor,\r\n },\r\n connectNulls: true, //是否连接空数据\r\n data: [\r\n [0, null],\r\n [2, null],\r\n [3.5, null],\r\n [4.9, null],\r\n [5.9, null],\r\n [6.9, null],\r\n {\r\n //延长线1\r\n value: [10.4, yVal25 - (2.7 * (yVal25 - yVal1)) / 2.1],\r\n symbol: 'none', //隐藏线条上的数据点\r\n },\r\n [11, yVal1], //第一个点\r\n [11.8, null],\r\n [13.1, yVal25], //第二个点\r\n [14.6, yVal2], //第三个点\r\n {\r\n //延长线2\r\n value: [15.2, (2.1 / 1.5) * (yVal2 - yVal25) + yVal25],\r\n symbol: 'none', //隐藏线条上的数据点\r\n },\r\n [16.4, null],\r\n [17.4, null],\r\n [18.9, null],\r\n [19.8, null],\r\n [20.7, null],\r\n [21.6, null],\r\n [22.6, null],\r\n ],\r\n markPoint: {\r\n data: [\r\n {\r\n xAxis: 13.1,\r\n yAxis: yVal25,\r\n symbolOffset: [40, 25],\r\n label: {\r\n show: true,\r\n color: '#000',\r\n formatter: function (data) {\r\n //显示25这个坐标点数据\r\n return isAllNull ? '' : '( ' + 25 + ' , ' + data.data.yAxis + ')';\r\n },\r\n },\r\n itemStyle: { color: 'transparent' },\r\n },\r\n ],\r\n },\r\n markLine: {\r\n symbol: '', //取消箭头\r\n silent: true, //取消鼠标hover事件\r\n label: {\r\n //标线的文本,模拟x轴显示的内容\r\n position: 'start', //改变label位置\r\n // rotate: 45, //设置文字旋转度数(注意:ECharts官网文档居然没有rotate这个属性的说明)\r\n // backgroundColor:'#fff'\r\n // color:'#f00',//文字颜色\r\n formatter: (data) => {\r\n return data.name;\r\n },\r\n },\r\n lineStyle: { color: '#e0e6f1', type: 'solid' },\r\n data: [\r\n {\r\n name: '5',\r\n xAxis: 0,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n name: '6',\r\n xAxis: 2,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n name: '7',\r\n xAxis: 3.5,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n name: '8',\r\n xAxis: 4.9,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n name: '9',\r\n xAxis: 5.9,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n name: '10',\r\n xAxis: 6.9,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n //延长线1\r\n name: '',\r\n xAxis: 10.4,\r\n lineStyle: {\r\n opacity: 0,\r\n },\r\n },\r\n {\r\n //第一个点\r\n name: '',\r\n xAxis: 11,\r\n },\r\n {\r\n name: '20',\r\n xAxis: 11.8,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n //第二个点\r\n name: '25',\r\n xAxis: 13.1,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n //第三个点\r\n name: '30',\r\n xAxis: 14.6,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n //延长线2\r\n name: '',\r\n xAxis: 15.2,\r\n lineStyle: {\r\n opacity: 0,\r\n },\r\n },\r\n {\r\n name: '40',\r\n xAxis: 16.4,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n name: '50',\r\n xAxis: 17.4,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n {\r\n name: '',\r\n xAxis: 18.9,\r\n },\r\n {\r\n name: '',\r\n xAxis: 19.8,\r\n },\r\n {\r\n name: '',\r\n xAxis: 20.7,\r\n },\r\n {\r\n name: '',\r\n xAxis: 21.6,\r\n },\r\n {\r\n name: '100',\r\n xAxis: 22.6,\r\n label: {\r\n fontSize: xyFontSize,\r\n },\r\n },\r\n\r\n //横线\r\n [\r\n {\r\n coord: [0, yVal25],\r\n lineStyle: {\r\n color: '#529b2e',\r\n type: 'solid',\r\n },\r\n },\r\n { coord: [13.1, yVal25] },\r\n ],\r\n //纵线\r\n [\r\n {\r\n coord: [13.1, yAxisMin],\r\n lineStyle: {\r\n color: '#000',\r\n type: 'silid',\r\n },\r\n },\r\n { coord: [13.1, yVal25] },\r\n ],\r\n ],\r\n },\r\n },\r\n ];\r\n if (isAllNull) {\r\n seriesObjs = [];\r\n }\r\n\r\n let option = {\r\n grid: {\r\n // show: true,//是否显示外边框线\r\n // borderColor: '#f00',//外边框线颜色\r\n top: 25,\r\n left: 30,\r\n right: 10,\r\n bottom: 35,\r\n containLabel: true,\r\n },\r\n //提示框组件,参考文档:https://echarts.apache.org/zh/option.html#tooltip\r\n tooltip: {\r\n trigger: 'axis',\r\n formatter: function (datas, ticket) {\r\n return datas && datas[0].data.length > 1\r\n ? datas[0].data[1] == null\r\n ? ''\r\n : datas[0].seriesName + '(' + datas[0].data[0] + ')' + ':' + datas[0].data[1]\r\n : datas[0].data;\r\n },\r\n },\r\n //顶部的标题,参考文档:https://echarts.apache.org/zh/option.html#title\r\n title: [\r\n {\r\n show: true,\r\n text: title,\r\n left: 'center',\r\n top: 0,\r\n textStyle: {\r\n fontSize: 14,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n {\r\n show: true,\r\n text: xName,\r\n left: 'center',\r\n bottom: 0,\r\n textStyle: {\r\n fontSize: 12,\r\n fontWeight: 'normal',\r\n },\r\n },\r\n ],\r\n //图例,参考文档:https://echarts.apache.org/zh/option.html#legend\r\n legend: {\r\n show: false,\r\n left: 'right',\r\n data: [legendName],\r\n selected: {\r\n legendName: true, //显示\r\n },\r\n selectedMode: 'multiple', //用于控制图例的选择模式(single:单选、multiple:多选、false:禁止选择)\r\n },\r\n xAxis: {\r\n type: 'value',\r\n axisTick: { show: false }, //隐藏刻度线\r\n axisLabel: { show: false }, //隐藏刻度值\r\n //网格线,参考文档:https://echarts.apache.org/zh/option.html#xAxis.splitLine\r\n splitLine: {\r\n show: false, //隐藏分割线\r\n },\r\n min: 0,\r\n max: 23.5,\r\n },\r\n yAxis: [\r\n {\r\n type: 'value',\r\n name: yName,\r\n nameGap: !isAllNull ? 30 : 10,\r\n nameRotate: 90,\r\n nameLocation: 'middle',\r\n splitLine: {\r\n show: true,\r\n lineStyle: {\r\n color: '#e0e6f1', //'#e0e6f1',\r\n type: 'solid',\r\n },\r\n },\r\n splitNumber: 4, //设置y轴分隔的段数,如0~100之间默认情况可能会按照0、20、40、60……的间隔显示,设置相应的数字后就会根据实际情况显示的更细,如0、10、20、30……\r\n min: !isAllNull ? yAxisMin : null,\r\n max: yAxisMax,\r\n axisLabel: {\r\n show: !isAllNull ? true : false,\r\n fontSize: xyFontSize,\r\n },\r\n axisTick: {\r\n show: !isAllNull ? true : false,\r\n },\r\n },\r\n ],\r\n series: seriesObjs,\r\n };\r\n\r\n return option;\r\n },\r\n};\r\n","import * as echarts from 'echarts';\r\nimport { type CellModel } from '../types/sheet';\r\nimport { type EChartsUtilsConfigModel, type EChartsUtilsChartLinesJsonModel } from '../types/echarts';\r\nimport { EChartsUtilsAll } from './echarts-all';\r\n\r\n/**\r\n * ECharts图表工具类\r\n */\r\nexport const EChartsUtils = {\r\n /**\r\n * 创建图表\r\n * @param GC GC对象\r\n * @param spread 工作簿对象\r\n * @param sheet 工作表对象\r\n * @param config 折现配置\r\n * @param isHideChart 是否隐藏图表\r\n */\r\n create: async (\r\n GC: any,\r\n spread: any,\r\n sheet: any,\r\n config: EChartsUtilsConfigModel,\r\n isHideChart: boolean = false\r\n ): Promise<{\r\n fObj: any;\r\n fObjPosition: {\r\n x: number;\r\n y: number;\r\n w: number;\r\n h: number;\r\n };\r\n ecObj: echarts.ECharts;\r\n }> => {\r\n // 获取扩展配置\r\n const chartExtJson = config.chartExtJson == null || config.chartExtJson == undefined ? null : JSON.parse(config.chartExtJson);\r\n\r\n // 如果isShowCon配置存在,则验证isShowCon对应单元格的值是否和输入的配置chartExtJson.isShowVal相等,不相等的话,就不创建图表\r\n if (chartExtJson != null && chartExtJson.isShowCon != null && chartExtJson.isShowCon != undefined) {\r\n const conVal = sheet.getValue(chartExtJson.isShowCon.row, chartExtJson.isShowCon.col);\r\n\r\n if (conVal != chartExtJson.isShowVal) {\r\n sheet.floatingObjects.remove(config.chartId);\r\n return;\r\n }\r\n }\r\n\r\n // 获取图表单元格之上的所有行的高度总和、所有列的宽度总和、距离左侧的距离和图表所在单元格的高度\r\n let allRowsTotalHeight = 0,\r\n allRowsTotalWidth = 0,\r\n allRowsTotalLeft = 0,\r\n chartCellHeight = 0;\r\n for (let i = 0; i < config.row; i++) {\r\n allRowsTotalHeight += sheet.getRowHeight(i);\r\n }\r\n allRowsTotalHeight += sheet.getRowHeight(0, GC.Spread.Sheets.SheetArea.colHeader);\r\n for (let i = config.col; i < config.col + config.colCount; i++) {\r\n allRowsTotalWidth += sheet.getColumnWidth(i);\r\n }\r\n for (let i = 0; i < config.col; i++) {\r\n allRowsTotalLeft += sheet.getColumnWidth(i);\r\n }\r\n allRowsTotalLeft += sheet.getColumnWidth(0, GC.Spread.Sheets.SheetArea.rowHeader);\r\n for (let i = config.row; i < config.row + config.rowCount; i++) {\r\n chartCellHeight += sheet.getRowHeight(i);\r\n }\r\n\r\n // 设置浮动对象的呈现位置(实际情况根据需要进行调整)\r\n const fObjPosition = {\r\n x: allRowsTotalLeft - 40 + 2,\r\n y: allRowsTotalHeight - 20 + 2,\r\n w: allRowsTotalWidth - 6,\r\n h: chartCellHeight - 6,\r\n };\r\n\r\n // 获取浮动对象\r\n let fcObj = sheet.floatingObjects.get(config.chartId);\r\n\r\n // 浮动对象不存在时\r\n if (fcObj == null || fcObj == undefined) {\r\n // 创建浮动对象\r\n fcObj = new GC.Spread.Sheets.FloatingObjects.FloatingObject(config.chartId, fObjPosition.x, fObjPosition.y, fObjPosition.w, fObjPosition.h);\r\n\r\n // 不允许改变大小、不允许拖动\r\n fcObj.allowResize(false);\r\n fcObj.allowMove(false);\r\n\r\n // 将浮动对象添加到表单\r\n sheet.floatingObjects.add(fcObj);\r\n }\r\n // 浮动对象存在时\r\n else {\r\n fcObj.x(fObjPosition.x);\r\n fcObj.y(fObjPosition.y);\r\n fcObj.width(fObjPosition.w);\r\n fcObj.height(fObjPosition.h);\r\n }\r\n\r\n // 设置浮动对象的内容为divObj(当document.getElementById(config.chartId + '_ec')为null的时候)\r\n if (document.getElementById(config.chartId + '_ec') == null) {\r\n // 创建用于放置ECharts的div容器\r\n const divObj = document.createElement('div');\r\n divObj.setAttribute('style', `background-color:#fff;width:100%;height:100%;`);\r\n divObj.innerHTML = `<div id=\"${config.chartId}_ec\" style=\"width:100%;height:100%;\"></div>`;\r\n\r\n fcObj.content(divObj);\r\n }\r\n\r\n // 定义ECharts对象\r\n let ecObj: echarts.ECharts | null = null;\r\n\r\n // 获取ECharts对象的函数(这里使用到了Promise和setTimeout,原因是:ECharts所在的div可能还没有及时在浮动元素中渲染完成,导致ECharts展示部出来)\r\n const getEcObj = (): any => {\r\n return new Promise((resolve, reject) => {\r\n setTimeout(() => {\r\n // 初始化图表并获取ECharts对象\r\n resolve({ ecObj: EChartsUtils.initChart(spread, sheet, config, isHideChart) });\r\n }, 10);\r\n });\r\n };\r\n ecObj = (await getEcObj()).ecObj;\r\n\r\n return {\r\n fObj: fcObj,\r\n fObjPosition: fObjPosition,\r\n ecObj: ecObj,\r\n };\r\n },\r\n\r\n /**\r\n * 初始化图表\r\n * @param spread 工作簿对象\r\n * @param sheet 工作表对象\r\n * @param config 图表配置\r\n * @param isHideChart 是否隐藏图表\r\n */\r\n initChart: (spread: any, sheet: any, config: EChartsUtilsConfigModel, isHideChart: boolean = false): echarts.ECharts => {\r\n // 此时可能ECharts所在的div还没有渲染(如浮动元素还没有在可视区域的时候是不会创建的)\r\n if (document.getElementById(config.chartId + '_ec') == null) {\r\n return null;\r\n }\r\n\r\n // 获取多条x轴的数组(类似[[1,2,3,4],[1,2,3,4]])\r\n let xDataArr: any = [],\r\n yDataArr: any = [];\r\n\r\n // 获取多条x轴的数组(单元格原始数据,类似[['1.0','2.0','3.0'],['1.0','2.0','3.0']],此数据可能在有些情况下需要使用原始数据,如:原始数据为字符串的1.0,可能需要在x轴显示为1.0这个字符文本)\r\n let xDataArrSource: any = [],\r\n yDataArrSource: any = [];\r\n\r\n /**\r\n * 获取x或y轴单元格的值集合\r\n * @param spread 工作簿对象\r\n * @param sheet 工作表对象\r\n * @param sheetName x轴或y轴数据所在的Sheet名称,如果没有值,则说明是当前操作的Sheet\r\n * @param cells 单元格集合\r\n * @returns 返回x或y轴数据的值集合\r\n */\r\n const getCellVals = (\r\n spread: any,\r\n sheet: any,\r\n sheetName?: string,\r\n cells?: CellModel[]\r\n ): {\r\n dataOneArr: any[];\r\n dataOneSourceArr: any[];\r\n } => {\r\n let retArr: {\r\n dataOneArr: any[];\r\n dataOneSourceArr: any[];\r\n } = {\r\n dataOneArr: [],\r\n dataOneSourceArr: [],\r\n };\r\n\r\n // 获取x或y轴数据所在的Sheet对象(如果sheetName有值,则说明是跨Sheet的)\r\n let curSheet: any = null;\r\n if (sheetName != null && sheetName != undefined && sheetName.length > 0) {\r\n curSheet = spread.getSheetFromName(sheetName);\r\n }\r\n\r\n cells?.forEach((itemCell, indexCell) => {\r\n // 如果单元格的值为数字,就转换为数字,否则在后期参与各个ECharts图表计算的时候会出错\r\n const curCellVal = curSheet != null ? curSheet.getValue(itemCell.row, itemCell.col) : sheet.getValue(itemCell.row, itemCell.col);\r\n retArr.dataOneSourceArr.push(curCellVal);\r\n\r\n // 严格的数字验证(包括科学计数法)\r\n if (/^-?\\d+(\\.\\d+)?([eE][+-]?\\d+)?$/.test(curCellVal)) {\r\n retArr.dataOneArr.push(Number(curCellVal));\r\n } else {\r\n retArr.dataOneArr.push(curCellVal == null ? 0 : curCellVal);\r\n }\r\n });\r\n\r\n return retArr;\r\n };\r\n\r\n let lineData: EChartsUtilsChartLinesJsonModel[] = JSON.parse(config.chartLinesJson);\r\n lineData.forEach((item, index) => {\r\n let xDataOne: any = [],\r\n yDataOne: any = [];\r\n let xDataOneSource: any = [],\r\n yDataOneSource: any = [];\r\n\r\n const curItemValsX = getCellVals(spread, sheet, item.sheetNameX, item.xCells);\r\n xDataOne = curItemValsX.dataOneArr;\r\n xDataOneSource = curItemValsX.dataOneSourceArr;\r\n const curItemValsY = getCellVals(spread, sheet, item.sheetNameY, item.yCells);\r\n yDataOne = curItemValsY.dataOneArr;\r\n yDataOneSource = curItemValsY.dataOneSourceArr;\r\n\r\n xDataArr.push(xDataOne);\r\n yDataArr.push(yDataOne);\r\n xDataArrSource.push(xDataOneSource);\r\n yDataArrSource.push(yDataOneSource);\r\n });\r\n\r\n // 获取ECharts图表所在div容器\r\n const ecDom = document.getElementById(config.chartId + '_ec') as HTMLElement;\r\n\r\n // 获取ECharts对象\r\n let ecObj = echarts.getInstanceByDom(ecDom);\r\n if (ecObj == null || ecObj == undefined) {\r\n ecObj = echarts.init(ecDom, null, {\r\n renderer: 'canvas',\r\n useDirtyRect: false,\r\n });\r\n }\r\n\r\n let option;\r\n\r\n if (config.chartType == 10) {\r\n option = EChartsUtilsAll.chart10(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 11) {\r\n option = EChartsUtilsAll.chart11(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 12) {\r\n option = EChartsUtilsAll.chart12(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 13) {\r\n option = EChartsUtilsAll.chart13(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 14) {\r\n option = EChartsUtilsAll.chart14(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 15) {\r\n option = EChartsUtilsAll.chart15(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 16) {\r\n option = EChartsUtilsAll.chart16(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 30) {\r\n option = EChartsUtilsAll.chart30(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 50) {\r\n option = EChartsUtilsAll.chart50(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 70) {\r\n option = EChartsUtilsAll.chart70(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 90) {\r\n option = EChartsUtilsAll.chart90(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 110) {\r\n option = EChartsUtilsAll.chart110(config, xDataArr, yDataArr, xDataArrSource, yDataArrSource);\r\n } else if (config.chartType == 130) {\r\n option = EChartsUtilsAll.chart130(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 150) {\r\n option = EChartsUtilsAll.chart150(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 170) {\r\n option = EChartsUtilsAll.chart170(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 190) {\r\n option = EChartsUtilsAll.chart190(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 210) {\r\n option = EChartsUtilsAll.chart210(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 230) {\r\n option = EChartsUtilsAll.chart230(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 250) {\r\n option = EChartsUtilsAll.chart250(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 270) {\r\n option = EChartsUtilsAll.chart270(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 279 || config.chartType == 280 || config.chartType == 281) {\r\n option = EChartsUtilsAll.chart279_280_281(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 290) {\r\n option = EChartsUtilsAll.chart290(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 310) {\r\n option = EChartsUtilsAll.chart310(config, xDataArr, yDataArr);\r\n } else if (config.chartType == 330) {\r\n option = EChartsUtilsAll.chart330(config, xDataArr, yDataArr, sheet);\r\n } else if (config.chartType == 350) {\r\n option = EChartsUtilsAll.chart350(config, xDataArr, yDataArr);\r\n }\r\n\r\n if (option && typeof option === 'object') {\r\n //如果是隐藏的图表,则需要禁用ECharts的动画效果\r\n //原因是:如果ECharts使用了动画效果,图表渲染完成可能需要0.5秒,但是在导出ECharts统计图为图片的场景下时,可能在图表还没有渲染完成(动画效果还没结束)前就要获取图像了,此时可能就会造成获取到的图像内容丢失的情况\r\n if (isHideChart) {\r\n option.animation = false;\r\n }\r\n\r\n ecObj.setOption(option);\r\n }\r\n\r\n ecObj.setOption(option);\r\n\r\n return ecObj;\r\n },\r\n\r\n /**\r\n * 获取ECharts对象\r\n * @param chartId 图表ID\r\n * @returns 返回ECharts对象,如果不存在则返回null\r\n */\r\n getEChartsObj: (chartId: string): echarts.ECharts | null => {\r\n // 获取ECharts图表所在div容器\r\n const ecDom = document.getElementById(chartId + '_ec') as HTMLElement;\r\n\r\n // 获取ECharts对象\r\n let ecObj = echarts.getInstanceByDom(ecDom);\r\n if (ecObj == null || ecObj == undefined) {\r\n return null;\r\n }\r\n\r\n return ecObj;\r\n },\r\n};\r\n","// 导入rapid-utils中的函数(注意:需要在tsconfig.json文件中设置moduleResolution为node,否则会提示:找不到模块“rapid-utils”。你的意思是要将 \"moduleResolution\" 选项设置为 \"nodenext\",还是要将别名添加到 \"paths\" 选项中?ts(2792))\r\nimport { orderByJson } from 'rapid-utils';\r\n// 导入单元格实体\r\nimport { CellModel, CellWatermarkModel, CellDateModel } from '../types/sheet';\r\n\r\n/**\r\n * SpreadJS工作表工具函数属性\r\n */\r\nexport const SheetUtils = {\r\n /**\r\n * 获取当前活动工作表选中的单元格集合\r\n * @param spread 工作簿对象\r\n * @returns 返回选中单元格的集合,格式如:[{ row: 0, col: 0, rowCount: 1, colCount: 1 }]\r\n */\r\n getActiveSheetSelectCells: (spread: any): CellModel[] => {\r\n const sheet = spread.getActiveSheet();\r\n\r\n const allCellObjs: CellModel[] = sheet.getSelections();\r\n\r\n return allCellObjs;\r\n },\r\n\r\n /**\r\n * 设置当前活动工作表某个或某些单元格范围为选中状态\r\n * @param spread 工作簿对象\r\n * @param cellObj 设置选中的单元格,格式如:{row:0,col:0,rowCount:1,colCount:1}\r\n */\r\n setActiveSheetSelectCells: (spread: any, cellObj: CellModel) => {\r\n const sheet = spread.getActiveSheet();\r\n\r\n sheet.setSelection(cellObj.row, cellObj.col, cellObj.rowCount, cellObj.colCount);\r\n },\r\n\r\n /**\r\n * 获取某工作表中某范围集合中所有的单元格坐标对象集合\r\n * 该方法适用的场景如:手动选择了很多个单元格范围,在这些范围中可能包含独立的单元格,也可能包含合并的单元格,这时候就需要用到如下方法获取到所有单元格对象\r\n * @param sheet 工作表实例\r\n * @param selectRanges 单元格范围集合,格式如:[{ row: 0, col: 0, rowCount: 2, colCount: 2 }]\r\n * @param isMulColOrder 是否按照多列的顺序排序单元格(true:按照第一列从上到下、第二列从上到下……的顺序获取单元格数据、false:按照第一行从左到右、第二行从左到右……的顺序获取单元格数据)\r\n * @returns 返回数组集合,格式如:[{ row: 0, col: 0, rowCount: 1, colCount: 1 }]\r\n */\r\n getAllCellObjsByRanges: (sheet: any, selectRanges: CellModel[], isMulColOrder: boolean = false): CellModel[] => {\r\n // 得到所有的单元格坐标对象集合,格式如:[{ row: 0, col: 0, rowCount: 1, colCount: 1 }]\r\n let allCellObjs: CellModel[] = [];\r\n\r\n selectRanges.forEach((item, index) => {\r\n // 得到当前item中所有合并的单元格对象集合\r\n const itemSpanCells = sheet.getSpans(item);\r\n itemSpanCells.forEach((itemSpanCell: CellModel) => {\r\n allCellObjs.push({\r\n row: itemSpanCell.row,\r\n col: itemSpanCell.col,\r\n rowCount: itemSpanCell.rowCount,\r\n colCount: itemSpanCell.colCount,\r\n });\r\n });\r\n\r\n if (item.row === undefined || item.col === undefined || item.rowCount === undefined || item.colCount === undefined) {\r\n throw new Error('row、col、rowCount、colCount is required.');\r\n }\r\n\r\n // 遍历item中涉及到的所有单元格\r\n for (let i = item.row; i < +item.row + item.rowCount; i++) {\r\n for (let j = item.col; j < item.col + item.colCount; j++) {\r\n const curSpanCellObj = sheet.getSpan(i, j);\r\n\r\n // 检查当前单元格是否为合并单元格\r\n if (curSpanCellObj == null) {\r\n allCellObjs.push({\r\n row: i,\r\n col: j,\r\n rowCount: 1,\r\n colCount: 1,\r\n });\r\n }\r\n }\r\n }\r\n });\r\n\r\n // 对所有单元格坐标对象集合进行排序\r\n allCellObjs = orderByJson(allCellObjs, !isMulColOrder ? ['row', 'col'] : ['col', 'row'], ['asc', 'asc']);\r\n\r\n return allCellObjs;\r\n },\r\n\r\n /**\r\n * 获取某工作表中所有的单元格坐标对象集合\r\n * @param sheet 工作表实例\r\n * @returns 返回数组集合,格式如:[{ col: 0, colCount: 2, row: 0, rowCount: 1 }]\r\n */\r\n getSheetAllCellObjs: (sheet: any): CellModel[] => {\r\n // 得到当前Sheet单元格范围\r\n const curSheetCellRange = [\r\n {\r\n row: 0,\r\n col: 0,\r\n rowCount: sheet.getRowCount(),\r\n colCount: sheet.getColumnCount(),\r\n },\r\n ];\r\n\r\n // 得到所有的单元格坐标对象集合,格式如:[{ col: 0, colCount: 2, row: 0, rowCount: 1 }]\r\n const allCellObjs = SheetUtils.getAllCellObjsByRanges(sheet, curSheetCellRange);\r\n\r\n return allCellObjs;\r\n },\r\n\r\n /**\r\n * 获取某工作表中选中的所有单元格坐标对象集合\r\n * @param sheet 工作表实例\r\n * @param isMulColOrder 是否按照多列的顺序排序单元格(true:按照第一列从上到下、第二列从上到下……的顺序获取单元格数据、false:按照第一行从左到右、第二行从左到右……的顺序获取单元格数据)\r\n * @returns 返回数组集合,格式如:[{ col: 0, row: 0, \"rowCount\": 1, \"colCount\": 1 }]\r\n */\r\n getSheetSelectCellObjs: (sheet: any, isMulColOrder: boolean = false): CellModel[] => {\r\n // 得到当前Sheet中选择的单元格范围集合\r\n const curSheetCellRange = sheet.getSelections();\r\n\r\n // 得到所有的单元格坐标对象集合,格式如:[{ col: 0, colCount: 2, row: 0, rowCount: 1 }]\r\n const allCellObjs = SheetUtils.getAllCellObjsByRanges(sheet, curSheetCellRange, isMulColOrder);\r\n\r\n return allCellObjs;\r\n },\r\n\r\n /**\r\n * 获取活动工作表中选中的所有单元格坐标对象集合\r\n * @param spread 工作簿实例\r\n * @param isMulColOrder 是否按照多列的顺序排序单元格(true:按照第一列从上到下、第二列从上到下……的顺序获取单元格数据、false:按照第一行从左到右、第二行从左到右……的顺序获取单元格数据)\r\n * @returns 返回数组集合,格式如:[{ col: 0, row: 0, \"rowCount\": 1, \"colCount\": 1 }]\r\n */\r\n getActiveSheetSelectCellObjs: (spread: any, isMulColOrder: boolean = false): CellModel[] => {\r\n // 当前活动的Sheet\r\n const sheet = spread.getActiveSheet();\r\n\r\n return SheetUtils.getSheetSelectCellObjs(sheet, isMulColOrder);\r\n },\r\n\r\n /**\r\n * 获取某工作表选中单元格的值集合\r\n * @param sheet 工作表实例\r\n * @param isMulColOrder 是否按照多列的顺序排序单元格(true:按照第一列从上到下、第二列从上到下……的顺序获取单元格数据、false:按照第一行从左到右、第二行从左到右……的顺序获取单元格数据)\r\n * @param nullUndefinedReplaceVal 如果单元格的值为null或undefined,则将其替换为该值(如果不传入该参数,则不替换)\r\n * @returns 返回选中单元格的值集合\r\n */\r\n getSheetSelectVals: (\r\n sheet: any,\r\n isMulColOrder: boolean = false,\r\n nullUndefinedReplaceVal?: number | string\r\n ): (number | string | null | undefined)[] => {\r\n // 获取活动工作表选中单元格对象集合\r\n const selectCells = SheetUtils.getSheetSelectCellObjs(sheet, isMulColOrder);\r\n\r\n // 获取选中单元格的值集合\r\n let selectCellVals: (number | string | null | undefined)[] = [];\r\n selectCells.forEach((cell) => {\r\n let cellVal = sheet.getValue(cell.row, cell.col);\r\n\r\n // 如果cellVal为null或undefined,并且nullUndefinedReplaceVal不为null或undefined,则将cellVal替换为nullUndefinedReplaceVal\r\n if (nullUndefinedReplaceVal != null && nullUndefinedReplaceVal != undefined && (cellVal === null || cellVal === undefined)) {\r\n cellVal = nullUndefinedReplaceVal;\r\n }\r\n\r\n selectCellVals.push(cellVal);\r\n });\r\n\r\n return selectCellVals;\r\n },\r\n\r\n /**\r\n * 获取活动工作表选中单元格的值集合\r\n * @param spread 工作簿实例\r\n * @param isMulColOrder 是否按照多列的顺序排序单元格(true:按照第一列从上到下、第二列从上到下……的顺序获取单元格数据、false:按照第一行从左到右、第二行从左到右……的顺序获取单元格数据)\r\n * @param nullUndefinedReplaceVal 如果单元格的值为null或undefined,则将其替换为该值(如果不传入该参数,则不替换)\r\n * @returns 返回选中单元格的值集合\r\n */\r\n getActiveSheetSelectVals: (\r\n spread: any,\r\n isMulColOrder: boolean = false,\r\n nullUndefinedReplaceVal?: number | string\r\n ): (number | string | null | undefined)[] => {\r\n // 获取当前活动工作表\r\n const sheet = spread.getActiveSheet();\r\n\r\n return SheetUtils.getSheetSelectVals(sheet, isMulColOrder, nullUndefinedReplaceVal);\r\n },\r\n\r\n /**\r\n * 获取单元格类型名称\r\n * @param GC GC对象\r\n * @param sheet 工作表实例\r\n * @param row 单元格行索引\r\n * @param col 单元格列索引\r\n * @returns 返回单元格类型名称,如:button、radio、checkbox、checkboxList、hyperLink、comboBox、date、dateRange、calc\r\n */\r\n getCellType: (GC: any, sheet: any, row: number, col: number): string | undefined => {\r\n let cellTypeName;\r\n\r\n // 先根据getCellType来获取\r\n const cellType = sheet.getCellType(row, col);\r\n\r\n if (cellType instanceof GC.Spread.Sheets.CellTypes.Button) {\r\n cellTypeName = 'button';\r\n } else if (cellType instanceof GC.Spread.Sheets.CellTypes.RadioButtonList) {\r\n cellTypeName = 'radio';\r\n } else if (cellType instanceof GC.Spread.Sheets.CellTypes.CheckBox) {\r\n cellTypeName = 'checkbox';\r\n } else if (cellType instanceof GC.Spread.Sheets.CellTypes.CheckBoxList) {\r\n cellTypeName = 'checkboxList';\r\n } else if (cellType instanceof GC.Spread.Sheets.CellTypes.HyperLink) {\r\n cellTypeName = 'hyperLink';\r\n } else if (cellType instanceof GC.Spread.Sheets.CellTypes.ComboBox) {\r\n cellTypeName = 'comboBox';\r\n }\r\n\r\n // 根据getStyle来获取\r\n if (cellTypeName == undefined || cellTypeName == null) {\r\n const cellStyle = sheet.getStyle(row, col);\r\n\r\n if (cellStyle && cellStyle.cellButtons && cellStyle.cellButtons.length > 0) {\r\n if (cellStyle.cellButtons[0].command == 'openDateTimePicker') {\r\n if (cellStyle.dropDowns && cellStyle.dropDowns.length > 0) {\r\n if (cellStyle.dropDowns[0].option.showDateRange) {\r\n cellTypeName = 'dateRange';\r\n } else {\r\n cellTypeName = 'date';\r\n }\r\n }\r\n } else if (cellStyle.cellButtons[0].command == 'openCalculator') {\r\n cellTypeName = 'calc';\r\n }\r\n }\r\n }\r\n\r\n return cellTypeName;\r\n },\r\n\r\n /**\r\n * 设置工作簿中所有工作表的缩放比例\r\n * @param spread 工作簿实例\r\n * @param scale 缩放比例,默认为:1(100%)\r\n */\r\n setSheetZoom: (spread: any, scale: number) => {\r\n // 暂停绘制\r\n spread.suspendPaint();\r\n\r\n const sheetCount = spread.getSheetCount();\r\n for (let i = 0; i < sheetCount; i++) {\r\n const sheet = spread.getSheet(i);\r\n\r\n sheet.zoom(scale);\r\n }\r\n\r\n // 恢复绘制\r\n spread.resumePaint();\r\n },\r\n\r\n /**\r\n * 设置当前活动工作表中选中的单元格背景颜色\r\n * @param spread 工作簿实例\r\n * @param color 背景颜色\r\n */\r\n setActiveSheetSelectBgColor: (spread: any, color: string) => {\r\n const sheet = spread.getActiveSheet();\r\n\r\n // 暂停绘制\r\n sheet.suspendPaint();\r\n\r\n //#region 方式1:通过getRange进行批量设置,推荐使用该方法来实现\r\n\r\n // 获取选择的多个单元格范围集合\r\n const selections = SheetUtils.getActiveSheetSelectCells(spread);\r\n\r\n // 循环每个选中的单元格范围\r\n selections.forEach((sel: CellModel) => {\r\n // 批量设置每个选中的单元格范围的背景颜色\r\n sheet.getRange(sel.row, sel.col, sel.rowCount, sel.colCount).backColor(color);\r\n });\r\n\r\n //#endregion\r\n\r\n //#region 方式2:通过getCell获取单元格样式对每个单元格进行设置,此方式效率相对较低,不推荐\r\n\r\n // // 当前活动的工作表中所有选择的单元格\r\n // const selectCells = SheetUtils.getActiveSheetSelectCellObjs(spread);\r\n\r\n // selectCells.forEach(item => {\r\n // // 获取单元格对象\r\n // const cellObj = sheet.getCell(item.row, item.col);\r\n\r\n // // 获取单元格样式\r\n // let cellStyle = sheet.getStyle(item.row, item.col);\r\n // if (!cellStyle) {\r\n // // 不存在样式则new一个\r\n // cellStyle = new GC.Spread.Sheets.Style();\r\n // }\r\n\r\n // // 设置单元格背景颜色\r\n // cellStyle.backColor = color;\r\n\r\n // // 重新设置单元格样式\r\n // cellObj.setStyle(cellStyle);\r\n // });\r\n\r\n //#endregion\r\n\r\n // 恢复绘制\r\n sheet.resumePaint();\r\n },\r\n\r\n /**\r\n * 设置某工作表中指定单元格背景颜色\r\n * @param sheet 工作表实例\r\n * @param cells 单元格集合\r\n * @param color 背景颜色\r\n */\r\n setSheetBgColor: (sheet: any, cells: CellModel[], color: string) => {\r\n // 暂停绘制\r\n sheet.suspendPaint();\r\n\r\n // 循环每个选中的单元格范围\r\n cells.forEach((sel: CellModel) => {\r\n // 批量设置每个选中的单元格范围的背景颜色\r\n sheet.getRange(sel.row, sel.col, sel.rowCount, sel.colCount).backColor(color);\r\n });\r\n\r\n // 恢复绘制\r\n sheet.resumePaint();\r\n },\r\n\r\n /**\r\n * 设置工作簿中所有工作表是否显示分页线\r\n * @param spread 工作簿实例\r\n * @param isShow 是否显示分页线(true:显示、false:不显示)\r\n */\r\n setSheetShowPrintPageLine: (spread: any, isShow: boolean) => {\r\n // 暂停绘制\r\n spread.suspendPaint();\r\n\r\n const sheetCount = spread.getSheetCount();\r\n for (let i = 0; i < sheetCount; i++) {\r\n const sheet = spread.getSheet(i);\r\n\r\n // 获取当前工作表是否显示分页线\r\n // var isVisible = sheet.isPrintLineVisible();\r\n\r\n sheet.isPrintLineVisible(isShow);\r\n }\r\n\r\n // 恢复绘制\r\n spread.resumePaint();\r\n },\r\n\r\n /**\r\n * 忽略工作工作表元格中指定字符串不显示,如:#DIV/0!、#VALUE!等\r\n * @param GC GC对象\r\n */\r\n ignoreSheetShowStrs: (GC: any) => {\r\n // 忽略的字符串集合\r\n const ignoreStrs: string[] = ['#DIV/0!', '#VALUE!', '#NAME?', '#N/A', '#NULL!', '#NUM!', '#REF!'];\r\n\r\n // paint对象\r\n const ignorePaint = GC.Spread.Sheets.CellTypes.Text.prototype.paint;\r\n\r\n // 重写paint函数\r\n GC.Spread.Sheets.CellTypes.Text.prototype.paint = function (ctx: any, value: any, x: any, y: any, w: any, h: any, style: any, options: any) {\r\n // 如果在忽略的字符串集合中有匹配的结果,则将其显示为空字符串\r\n if (ignoreStrs.some((item) => item == value)) {\r\n ignorePaint.call(this, ctx, '/', x, y, w, h, style, options);\r\n } else {\r\n ignorePaint.apply(this, arguments);\r\n }\r\n\r\n // // 或使用如下代码\r\n // if (ignoreStrs.some((item) => item == value)) {\r\n // \tvalue = '';\r\n // }\r\n // ignorePaint.apply(this, [ctx, value, x, y, w, h, style, options]);\r\n };\r\n },\r\n\r\n /**\r\n * 设置工作表显示辅助线(底部和右侧的辅助线)\r\n * @param sheet 工作表实例\r\n * @param width 宽度(像素)\r\n * @param height 高度(像素)\r\n * @param lineWidth 辅助线宽度(默认为:1像素)\r\n * @param colorStr 辅助线颜色(默认为:#409eff)\r\n * @param isHb 是否为横表(默认为:false)\r\n */\r\n setSheetAuxiliaryLine: (\r\n GC: any,\r\n sheet: any,\r\n width: number,\r\n height: number,\r\n lineWidth: number = 1,\r\n colorStr: string = '#409eff',\r\n isHb: boolean = false\r\n ) => {\r\n // 创建底部和右侧的浮动对象\r\n let floatBottom = new GC.Spread.Sheets.FloatingObjects.FloatingObject(`floatLineBottom${isHb ? 'Hb' : ''}`, 0, height, width, lineWidth),\r\n floatRight = new GC.Spread.Sheets.FloatingObjects.FloatingObject(`floatLineRight${isHb ? 'Hb' : ''}`, width, 0, lineWidth, height);\r\n\r\n // 创建底部和右侧的div对象\r\n let divBottom = document.createElement('div'),\r\n divRight = document.createElement('div');\r\n\r\n // 设置底部div对象样式\r\n divBottom.style.width = `${width}px`;\r\n divBottom.style.height = '1px';\r\n divBottom.style.borderBottom = `${lineWidth}px dashed ${colorStr}`;\r\n\r\n // 设置右侧div对象样式\r\n divRight.style.width = '1px';\r\n divRight.style.height = `${height}px`;\r\n divRight.style.borderLeft = `${lineWidth}px dashed ${colorStr}`;\r\n\r\n // floatBottom.fixedPosition(true);\r\n // floatRight.fixedPosition(true);\r\n\r\n // 设置底部和右侧浮动对象不允许改变大小、不允许拖动和设置浮动对象的内容\r\n floatBottom.allowResize(false);\r\n floatBottom.allowMove(false);\r\n floatBottom.content(divBottom);\r\n floatRight.allowResize(false);\r\n floatRight.allowMove(false);\r\n floatRight.content(divRight);\r\n\r\n // 将浮动元素添加到工作表中\r\n sheet.floatingObjects.add(floatBottom);\r\n sheet.floatingObjects.add(floatRight);\r\n },\r\n\r\n /**\r\n * 设置当前活动工作表的水印和数据绑定是否显示\r\n * @param spread 工作簿实例\r\n * @param cells 数据绑定单元格配置集合([{ row: number; col: number; title: string; pathPrev: string; pathField: string }])\r\n * @param isShow 是否显示\r\n */\r\n setActiveSheetWatermark: (spread: any, cells: CellWatermarkModel[], isShow: boolean) => {\r\n if (cells == null || cells == undefined) {\r\n return;\r\n }\r\n\r\n const sheet = spread.getActiveSheet();\r\n\r\n // 暂停绘制\r\n sheet.suspendPaint();\r\n\r\n cells.forEach((cell: CellWatermarkModel) => {\r\n // 设置或移除水印标签\r\n sheet.getCell(cell.row, cell.col).watermark(isShow ? `{${cell.title}}` : undefined);\r\n\r\n // 设置或移除绑定路径\r\n sheet.setBindingPath(cell.row, cell.col, isShow ? `${cell.pathPrev}.${cell.pathField}` : undefined);\r\n });\r\n\r\n // 恢复绘制\r\n sheet.resumePaint();\r\n },\r\n\r\n /**\r\n\t * 设置某工作表中单元格为日期选择控件\r\n\t * @param GC GC对象\r\n\t * @param sheet 工作表实例\r\n\t * @param cells 单元格集合,格式如:[{\r\n\t\t\tdateFormat: 'yyyy-MM-dd',\r\n\t\t\trow: 0,\r\n\t\t\tcol: 0\r\n\t\t}]\r\n\t * @param isAutoSize 是否自适应单元格大小(默认为:true)\r\n\t */\r\n setSheetCellDate: (GC: any, sheet: any, cells: CellDateModel[], isAutoSize: boolean = true) => {\r\n cells.forEach((item, index) => {\r\n // 先获取单元格样式,否则设置控件后样式会丢失\r\n let cellStyle = sheet.getStyle(item.row, item.col);\r\n if (!cellStyle) {\r\n cellStyle = new GC.Spread.Sheets.Style();\r\n }\r\n\r\n cellStyle.cellButtons = [\r\n {\r\n imageType: GC.Spread.Sheets.ButtonImageType.dropdown,\r\n command: 'openDateTimePicker',\r\n // 按钮宽度\r\n // width: 10,\r\n },\r\n ];\r\n cellStyle.dropDowns = [\r\n {\r\n type: GC.Spread.Sheets.DropDownType.dateTimePicker,\r\n option: {\r\n showTime: false,\r\n showDateRange: false,\r\n },\r\n },\r\n ];\r\n cellStyle.formatter = item.dateFormat;\r\n\r\n // 是否缩小以适应\r\n cellStyle.shrinkToFit = isAutoSize;\r\n\r\n // 设置单元格样式\r\n sheet.setStyle(item.row, item.col, cellStyle);\r\n });\r\n },\r\n};\r\n","// 导出Excel文件所需的第三方包\r\nimport { saveAs } from 'file-saver';\r\n\r\n/**\r\n * SpreadJS工作簿工具函数属性\r\n */\r\nexport const WorkbookUtils = {\r\n /**\r\n * 加载在线sjs文件\r\n * @param spread 工作簿对象\r\n * @param fileUrl 在线sjs文件地址\r\n * @param succFunc 文件打开成功后的回调函数,返回的第一个参数为spread工作簿对象\r\n * @param errorFunc 文件打开失败后的回调函数,返回的第一个参数为错误信息\r\n */\r\n loadSjsFile: async (spread: any, fileUrl: string, succFunc?: (spreadObj) => void, errorFunc?: (error) => void) => {\r\n // 获取文件响应结果\r\n const response = await fetch(fileUrl, { method: 'GET' });\r\n\r\n // 获取成功\r\n if (response.ok) {\r\n // 文件的字节流对象\r\n const blob = await response.blob();\r\n // 将Blob转换为File或Blob对象\r\n const file = new File([blob], 'template.sjs', { type: 'application/octet-stream' });\r\n const sjsBlob = new Blob([blob], { type: 'application/zip' });\r\n\r\n // SpreadJS打开文件\r\n spread.open(\r\n sjsBlob,\r\n () => {\r\n if (typeof succFunc === 'function') {\r\n succFunc(spread);\r\n }\r\n },\r\n (e: any) => {\r\n if (typeof errorFunc === 'function') {\r\n errorFunc(e);\r\n }\r\n }\r\n );\r\n }\r\n },\r\n\r\n /**\r\n * 打印所有工作表\r\n * @param GC GC对象\r\n * @param spread 工作簿实例\r\n */\r\n print: (GC: any, spread: any) => {\r\n // 得到Sheet个数\r\n const sheetCount = spread.getSheetCount();\r\n\r\n for (let i = 0; i < sheetCount; i++) {\r\n const sheet = spread.getSheet(i);\r\n\r\n // 获取每个工作表的打印信息\r\n let printInfo = sheet.printInfo();\r\n\r\n // 隐藏行和列的头部信息\r\n printInfo.showRowHeader(GC.Spread.Sheets.Print.PrintVisibilityType.hide);\r\n printInfo.showColumnHeader(GC.Spread.Sheets.Print.PrintVisibilityType.hide);\r\n\r\n // // 显示和隐藏打印区域的辅助线\r\n // spread.getSheet(0).isPrintLineVisible(true);\r\n // spread.getSheet(0).isPrintLineVisible(!true);\r\n\r\n // 设置打印区域,这里是固定的,在业务应用中需要根据实际情况修改打印区域\r\n printInfo.rowStart(0);\r\n printInfo.rowEnd(sheet.getRowCount()); //printInfo.rowEnd(41);\r\n printInfo.columnStart(0);\r\n printInfo.columnEnd(76);\r\n\r\n // 设置SpreadJS自身的边距为合适的距离\r\n printInfo.margin({\r\n /**\r\n * 设置默认边距\r\n * 单位是:以百分之一英寸为单位\r\n * 也就是,如果我们需要设置左边距为25mm,需要将25mm先转换为英寸,然后再用这个英寸*100就是要设置的边距\r\n * 即:(25mm转换为英寸的结果)*100\r\n *\r\n * 参考文档:\r\n * https://demo.grapecity.com.cn/spreadjs/help/api/classes/GC.Spread.Sheets.Print.PrintInfo#margin\r\n * https://www.67tool.com/converter/length\r\n */\r\n // 纵表\r\n top: 0.5905511999999999 * 100,\r\n bottom: 0.5905511999999999 * 100,\r\n left: 0.9842520000000001 * 100,\r\n right: 0.5905511999999999 * 100,\r\n\r\n // // 横表\r\n // top: 0.9842520000000001 * 100,\r\n // bottom: 0.5905511999999999 * 100,\r\n // left: 0.5905511999999999 * 100,\r\n // right: 0.5905511999999999 * 100,\r\n\r\n // top: 0,\r\n // bottom: 0,\r\n // left: 0,\r\n // right: 0,\r\n header: 0,\r\n footer: 0,\r\n });\r\n\r\n // 设置打印的纸张\r\n printInfo.paperSize(new GC.Spread.Sheets.Print.PaperSize(GC.Spread.Sheets.Print.PaperKind.a4));\r\n\r\n sheet.printInfo(printInfo);\r\n }\r\n\r\n // 调用打印方法\r\n spread.print();\r\n },\r\n\r\n /**\r\n * 导出为Excel文件\r\n * 如支持导出自定义公式的值等功能\r\n * @param GC Spread的GC对象\r\n * @param spread 原始Spread对象\r\n * @param fileName 导出的文件名称,不传则为第一个工作表的名称\r\n */\r\n exportToExcel: (GC: any, spread: any, fileName: string = '') => {\r\n // 导出模板为JSON对象,此处设置了参数includeBindingSource,改参数代表包含数据绑定的值\r\n const json = spread.toJSON({ includeBindingSource: true });\r\n\r\n // 需要移除的自定义公式名称集合(该变量的作用是,在导出Excel前,将工作簿中所有的自定义公式移除掉,其他内置的公式保留)\r\n const removeCustomFormulas = ['YJMAX', 'YJMIN', 'YJMID', 'YJGETNUM', 'YJGETS', 'YJGETCV', 'YJINTERPOLATIONMETHOD', 'YJINTERPOLATIONMETHOD_Y'];\r\n\r\n // 临时工作簿\r\n const tempSpread = new GC.Spread.Sheets.Workbook();\r\n tempSpread.fromJSON(json);\r\n\r\n // 暂停绘制\r\n tempSpread.suspendPaint();\r\n\r\n // 获取Sheet数量\r\n const sheetCount = tempSpread.getSheetCount();\r\n\r\n for (let iSheet = 0; iSheet < sheetCount; iSheet++) {\r\n // 当前工作表\r\n const sheet = tempSpread.getSheet(iSheet);\r\n\r\n // 暂停公式的计算,提高性能\r\n sheet.suspendCalcService();\r\n\r\n for (var i = 0; i < sheet.getRowCount(); i++) {\r\n for (var j = 0; j < sheet.getColumnCount(); j++) {\r\n // 获取单元格的公式\r\n const cellFormula = sheet.getFormula(i, j);\r\n\r\n // 如果cellFormula不为null或undefined,则说明该单元格引用了公式\r\n if (cellFormula != null && cellFormula != undefined && removeCustomFormulas.some((item) => cellFormula.indexOf(item) > -1)) {\r\n // 获取单元格的值\r\n const cellVal = sheet.getValue(i, j);\r\n\r\n // 移除单元格引用的公式\r\n sheet.getCell(i, j).formula(undefined);\r\n\r\n // 设置单元格的值\r\n sheet.setValue(i, j, cellVal);\r\n }\r\n }\r\n }\r\n\r\n // 恢复计算\r\n sheet.resumeCalcService(false);\r\n }\r\n\r\n // 恢复绘制\r\n tempSpread.resumePaint();\r\n\r\n if (fileName == '') {\r\n fileName = tempSpread.getSheet(0).name();\r\n }\r\n\r\n let options = {\r\n fileType: GC.Spread.Sheets.FileType.excel,\r\n includeBindingSource: true,\r\n includeStyles: true,\r\n includeFormulas: true,\r\n saveAsView: false,\r\n rowHeadersAsFrozenColumns: false,\r\n columnHeadersAsFrozenRows: false,\r\n includeAutoMergedCells: false,\r\n includeCalcModelCache: false,\r\n includeUnusedNames: true,\r\n includeEmptyRegionCells: true,\r\n };\r\n\r\n tempSpread.export(\r\n (blob: any) => {\r\n saveAs(blob, `${fileName}.xlsx`);\r\n },\r\n () => {},\r\n options\r\n );\r\n\r\n // 销毁临时工作簿\r\n tempSpread.destroy();\r\n },\r\n};\r\n"],"names":["CommonUtils","getColLetterName","colIndex","letter","remainder","String","fromCharCode","Math","floor","toUpperCase","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","apply","SuppressedError","EChartsUtilsComm","getRound","roundingVal","accuracy","valIsNegative","abs","inputValStr","toString","indexOf","intVal","parseInt","split","decimalStr","parseFloat","coefficient","retNum","inputVal","decimalStrFirst","substring","length","calcRoundingRet","Number","toFixed","accuracyStr","retNumStr","zeroStr","index","xsPart","calcTrend","x","y","xVal","n","sumX","sumY","sumXY","sumXX","i","slope","intercept","gs","xl","jj","filterNullEmptyErrArray","dataSource","filter","item","undefined","_error","EChartsUtilsAll","chart10","config","xDataArr","yDataArr","sheet","lineJson","JSON","parse","chartLinesJson","chartExtJson","xDataSource","yDataSource","dxsJs","xData","yData","forEach","test","push","xMin","min","xMax","max","yMin","yMax","xAxisMax","xAxisMin","yAxisMax","yAxisMin","seriesData","points","A","N","matrix","row","j","math","pow","vandermondeMatrix","AT","transpose","ATA","multiply","ATb","coefficients","lusolve","valueOf","err","funequation","arrX","arrY","temp","maxIndex","findIndex","xName","chartXName","yName","chartYName","includes","symbol","peakvalue","coordX","lqhhlKs","setValue","col","lqhhlJs","lqhhlSc1","lineData","pointData","coord","lineStyle","color","type","xAxis","yAxis","symbolOffset","label","show","formatter","data","itemStyle","yValIsAllNull","every","ele","grid","top","left","right","bottom","containLabel","tooltip","trigger","datas","ticket","seriesName","title","text","textStyle","fontSize","fontWeight","legend","selected","legendName","selectedMode","axisTick","alignWithLabel","splitLine","name","nameGap","nameRotate","nameLocation","axisLine","series","smooth","symbolSize","lineColor","markPoint","markLine","width","chart11","ceil","upperLimit","lowerLimit","lqhhlSx","curVal","getValue","lqhhlXx","ifHaveIntersectionPoint","y1","y2","y3","y4","getIntersectionPoint","upperIntersectionPoint","lowerIntersectionPoint","upperIntersectionPointTrend","lowerIntersectionPointTrend","index1","validX1","validX2","chart12","avg","avgXIndex","chart13","chart14","chart15","chart16","lines","lqhhlHz","yAxisData","map","isNaN","lqhhlSc2","axisLabel","chart30","jsIsJz","isTwoLine","xDataSource1","xDataSource2","yDataSource1","yDataSource2","chartTitle","lineFunc","isShowMarkPoint","isShowMarkLine","isTwoLineData","cellValJzZjhsl","cellValJzZdgmd","trunc","jsZjhslJz","jsZdgmdJz","outJdZjhsl","outJdZdgmd","outValZjhsl","outValZdgmd","jsZjhslJd","jsZdgmdJd","jsZjhsl","jsZdgmd","coordY","markPointObj","markLineObj","seriesDataObj","maxPointData","lineObj2","maxPointDataX","maxPointDataY","lineObj1","chart50","xDataSourceOld","yDataSourceOld","yDataSourceSxOld","yDataSourceXxOld","allData","ySx","yXx","sort","a","b","yDataSourceSx","yDataSourceXx","sxValNullCount","xDataSx","xDataXx","markLineData","val045","getLineObj","lineType","obj","z","connectNulls","silent","position","nullCount","some","xObj","splitNumber","chart70","ztzl","cllx","logx","logy","curZtzl","jxhslZtzl","curCllx","jxhslCllx","item1","log","item2","abk","ack","dropName","getYOnLine","point1","point2","point3X","logX1","logY1","logX2","logY","exp","zero_ab","zero_ac","HpCoordinates","wl","hp","scHp","scWl","scWp","point_hp","Dy","Dylog","hp0_xab","hp0_xac","hp0_xcenter","Dxlog","adk","wly","wlx","wpy","wpx","wp","hpy2","hpylog2","hp0_xab2","hp0_xac2","hp0_xcenter2","outJdHp","outJdWl","outJdWp","jxhslScHpJd","jxhslScWlJd","jxhslScWpJd","jxhslScHp","jxhslScWl","jxhslScWp","interval","param","minMargin","chart90","xDataCl","yDataSourceCl","markPointData","gsS","jxhslSnShScfc","yDataCopy","curYData","eval","replace","option","opacity","val","chart110","xDataArrSource","yDataArrSource","curXName","chart130","logBase","inverse","chart150","chart170","chart190","_code","chart210","arr","uniqueData","self","t","getXline","chart230","lineCount","xDataSource3","yDataSource3","xData1","xData2","xData3","getHours","getMinutes","curArr","curItemMins","unshift","getxAxisObj","xAxisData","legendData","legendSelected","xValIsAllNull","topmargin","chart250","xmin","xmax","chart270","chart279_280_281","jjNum","chartType","chart290","chart310","yDataCl","chart330","wd015","wd019","wd025","wd031","Infinity","wdBh","wdYs","bszdjBh","bszdjYs","chart350","jsN","hsl","yVal1","yVal2","yVal25","isAllNull","seriesObjs","EChartsUtils","create","GC_1","spread_1","sheet_1","config_1","args_1","GC","spread","isHideChart","isShowCon","isShowVal","floatingObjects","remove","chartId","allRowsTotalHeight","allRowsTotalWidth","allRowsTotalLeft","chartCellHeight","getRowHeight","Spread","Sheets","SheetArea","colHeader","colCount","getColumnWidth","rowHeader","rowCount","fObjPosition","w","h","fcObj","get","FloatingObjects","FloatingObject","allowResize","allowMove","add","height","document","getElementById","divObj","createElement","setAttribute","innerHTML","content","ecObj","setTimeout","initChart","fObj","getCellVals","sheetName","cells","retArr","dataOneArr","dataOneSourceArr","curSheet","getSheetFromName","itemCell","indexCell","curCellVal","xDataOne","yDataOne","xDataOneSource","yDataOneSource","curItemValsX","sheetNameX","xCells","curItemValsY","sheetNameY","yCells","ecDom","echarts","getInstanceByDom","init","renderer","useDirtyRect","animation","setOption","getEChartsObj","SheetUtils","getActiveSheetSelectCells","getActiveSheet","getSelections","setActiveSheetSelectCells","cellObj","setSelection","getAllCellObjsByRanges","selectRanges","isMulColOrder","allCellObjs","getSpans","itemSpanCell","Error","getSpan","orderByJson","getSheetAllCellObjs","curSheetCellRange","getRowCount","getColumnCount","getSheetSelectCellObjs","getActiveSheetSelectCellObjs","getSheetSelectVals","nullUndefinedReplaceVal","selectCells","selectCellVals","cell","cellVal","getActiveSheetSelectVals","getCellType","cellTypeName","cellType","CellTypes","Button","RadioButtonList","CheckBox","CheckBoxList","HyperLink","ComboBox","cellStyle","getStyle","cellButtons","command","dropDowns","showDateRange","setSheetZoom","scale","suspendPaint","sheetCount","getSheetCount","getSheet","zoom","resumePaint","setActiveSheetSelectBgColor","sel","getRange","backColor","setSheetBgColor","setSheetShowPrintPageLine","isShow","isPrintLineVisible","ignoreSheetShowStrs","ignoreStrs","ignorePaint","Text","prototype","paint","ctx","style","options","call","this","arguments","setSheetAuxiliaryLine","lineWidth","colorStr","isHb","floatBottom","floatRight","divBottom","divRight","borderBottom","borderLeft","setActiveSheetWatermark","getCell","watermark","setBindingPath","pathPrev","pathField","setSheetCellDate","isAutoSize","Style","imageType","ButtonImageType","dropdown","DropDownType","dateTimePicker","showTime","dateFormat","shrinkToFit","setStyle","WorkbookUtils","loadSjsFile","fileUrl","succFunc","errorFunc","response","fetch","method","ok","blob","File","sjsBlob","Blob","open","print","printInfo","showRowHeader","Print","PrintVisibilityType","hide","showColumnHeader","rowStart","rowEnd","columnStart","columnEnd","margin","header","footer","paperSize","PaperSize","PaperKind","a4","exportToExcel","fileName","json","toJSON","includeBindingSource","removeCustomFormulas","tempSpread","Workbook","fromJSON","iSheet","suspendCalcService","cellFormula","getFormula","formula","resumeCalcService","fileType","FileType","excel","includeStyles","includeFormulas","saveAsView","rowHeadersAsFrozenColumns","columnHeadersAsFrozenRows","includeAutoMergedCells","includeCalcModelCache","includeUnusedNames","includeEmptyRegionCells","export","saveAs","destroy"],"mappings":"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","x_google_ignoreList":[1]}