| | |
| | | // ====== 开关:1=启用假数据(只替换 DB 查询);0=用真实 DB ====== |
| | | #define USE_FAKE_DB_DEMO 0 |
| | | |
| | | // ====== 开关:1=启用模拟传感器数据生成;0=使用真实数据 ====== |
| | | #define USE_MOCK_SENSOR_DATA 0 |
| | | |
| | | #if USE_FAKE_DB_DEMO |
| | | #include <ctime> |
| | | #include <atlconv.h> // CStringA |
| | |
| | | if (!row.pretty.empty()) { |
| | | SERVO::CGlass tempGlass; |
| | | if (GlassJson::FromString(row.pretty, tempGlass)) { |
| | | #if USE_MOCK_SENSOR_DATA |
| | | // 生成模拟的SVData用于测试 |
| | | GenerateMockSVData(tempGlass); |
| | | #endif |
| | | // 对每个机器生成表格 |
| | | for (const auto& machinePair : tempGlass.getAllSVData()) { |
| | | int machineId = machinePair.first; |
| | |
| | | { |
| | | return std::chrono::duration_cast<std::chrono::milliseconds>(tp.time_since_epoch()).count(); |
| | | } |
| | | |
| | | // 生成模拟的SVData用于测试 |
| | | void CPageGlassList::GenerateMockSVData(SERVO::CGlass& glass) |
| | | { |
| | | // 获取设备数据类型配置 |
| | | auto& dataTypes = SERVO::CServoUtilsTool::getEqDataTypes(); |
| | | |
| | | // 为每个设备生成模拟数据 |
| | | for (const auto& machinePair : dataTypes) { |
| | | int machineId = machinePair.first; |
| | | const auto& dataTypeList = machinePair.second; |
| | | |
| | | // 生成时间序列:从当前时间往前推10分钟,每1秒一个数据点 |
| | | auto now = std::chrono::system_clock::now(); |
| | | auto startTime = now - std::chrono::minutes(10); |
| | | |
| | | // 为每个数据类型生成模拟数据 |
| | | for (const auto& dataType : dataTypeList) { |
| | | std::vector<SERVO::SVDataItem> mockData; |
| | | |
| | | // 生成600个数据点(10分钟 * 60个点/分钟) |
| | | for (int i = 0; i < 600; ++i) { |
| | | auto timestamp = startTime + std::chrono::seconds(i * 1); |
| | | |
| | | // 根据设备类型和数据类型生成不同的模拟值 |
| | | double value = GenerateMockValue(machineId, dataType, i); |
| | | |
| | | mockData.emplace_back(timestamp, value); |
| | | } |
| | | |
| | | // 将模拟数据添加到glass对象中 |
| | | glass.addSVData(machineId, dataType, mockData); |
| | | } |
| | | } |
| | | } |
| | | |
| | | // 根据设备类型和数据类型生成模拟数值 |
| | | double CPageGlassList::GenerateMockValue(int machineId, const std::string& dataType, int index) |
| | | { |
| | | // 基础值范围 |
| | | double baseValue = 0.0; |
| | | double variation = 0.0; |
| | | |
| | | // 根据设备类型设置基础值 |
| | | switch (machineId) { |
| | | case EQ_ID_Bonder1: |
| | | case EQ_ID_Bonder2: |
| | | if (dataType.find("压力") != std::string::npos) { |
| | | baseValue = 50.0; // 压力基础值 |
| | | variation = 10.0; // 压力变化范围 |
| | | } else if (dataType.find("温度") != std::string::npos) { |
| | | baseValue = 180.0; // 温度基础值 |
| | | variation = 5.0; // 温度变化范围 |
| | | } else if (dataType.find("扩展值") != std::string::npos) { |
| | | baseValue = 100.0; // 扩展值基础值 |
| | | variation = 15.0; // 扩展值变化范围 |
| | | } |
| | | break; |
| | | |
| | | case EQ_ID_VACUUMBAKE: |
| | | if (dataType.find("扩展值") != std::string::npos) { |
| | | baseValue = 80.0; |
| | | variation = 12.0; |
| | | } else if (dataType.find("温度") != std::string::npos) { |
| | | baseValue = 200.0; |
| | | variation = 8.0; |
| | | } |
| | | break; |
| | | |
| | | case EQ_ID_BAKE_COOLING: |
| | | if (dataType.find("温度") != std::string::npos) { |
| | | baseValue = 25.0; // 冷却温度 |
| | | variation = 3.0; |
| | | } |
| | | break; |
| | | |
| | | default: |
| | | baseValue = 50.0; |
| | | variation = 5.0; |
| | | break; |
| | | } |
| | | |
| | | // 添加时间相关的趋势和随机变化 |
| | | double timeTrend = sin(index * 0.1) * 2.0; // 正弦波趋势 |
| | | double randomNoise = (rand() % 100 - 50) / 100.0 * variation * 0.3; // 随机噪声 |
| | | |
| | | return baseValue + timeTrend + randomNoise; |
| | | } |