廖井涛
93 分钟以前 f7a2fcdda7f1120498c5c5f75c5a99955fc54b43
north-glass-erp/northglass-erp/src/views/pp/glassOptimize/OptimizeParms.vue
@@ -24,6 +24,14 @@
};
const saveToDatabase = () => {
  if (settings.server.haveOptimaMark === '1' && settings.server.haveQMark === '1') {
    ElMessage.warning('是否生成OPTIMA打标信息和是否生成速刻打标信息不能同时为是');
    return;
  }
  if (settings.server.printLayouts === '0' && settings.server.printReport === '0') {
    ElMessage.warning('版图和报告不能同时不打印,请至少选择一项');
    return;
  }
  console.log(settings)
  request.post(`/glassOptimize/optimizeParms/${username}`, settings).then((res) => {
    if (res.code == 200 && res.data === true) {
@@ -34,28 +42,114 @@
  });
};
// 修改 fetchSettings 方法
const fetchSettings = async (username) => {
  try {
    const response = await request.post(`/glassOptimize/selectOptimizeParms/${username}`);
    if (response.code == 200) {
      if (!response.data) {
        console.error('响应数据为空');
        return;
    let parsedData = {};
    if (response.code == 200 && response.data) {
      try {
        parsedData = JSON.parse(response.data);
      } catch (parseError) {
        console.error('解析响应数据失败:', parseError);
        parsedData = {};
      }
      const parsedData = JSON.parse(response.data);
      if (!parsedData.server) {
        parsedData.server = {};
      }
      if (!parsedData.server.fileMode) {
        parsedData.server.fileMode = '1'; // 默认为单文件模式
      }
      Object.assign(settings, parsedData);
      console.log('设置已更新:', settings);
    } else {
      console.error('请求失败,状态码:', response.code);
      console.log('未获取到设置数据或响应失败,使用默认设置');
      parsedData = {};
    }
    // 确保所有模块都存在
    if (!parsedData.optimization) parsedData.optimization = {};
    if (!parsedData.display) parsedData.display = {};
    if (!parsedData.cutting) parsedData.cutting = {};
    if (!parsedData.server) parsedData.server = {};
    if (!parsedData.tempering) parsedData.tempering = {};
    parsedData.optimization.yShapeJoinOptimization = parsedData.optimization.yShapeJoinOptimization !== undefined ? parsedData.optimization.yShapeJoinOptimization : true;
    parsedData.optimization.smallPieceRotationProhibited = parsedData.optimization.smallPieceRotationProhibited !== undefined ? parsedData.optimization.smallPieceRotationProhibited : true;
    // parsedData.optimization.maxFramesOnSite = parsedData.optimization.maxFramesOnSite !== undefined ? parsedData.optimization.maxFramesOnSite : 10;
    parsedData.optimization.bendEdgeDistance = parsedData.optimization.bendEdgeDistance !== undefined ? parsedData.optimization.bendEdgeDistance : 10;
    // parsedData.optimization.positiveTolerance = parsedData.optimization.positiveTolerance !== undefined ? parsedData.optimization.positiveTolerance : 0;
    // parsedData.optimization.negativeTolerance = parsedData.optimization.negativeTolerance !== undefined ? parsedData.optimization.negativeTolerance : 0;
    parsedData.optimization.cutterOriginPosition = parsedData.optimization.cutterOriginPosition !== undefined ? parsedData.optimization.cutterOriginPosition : 1;
    // parsedData.optimization.uniformShapeEdgeTrimAmount = parsedData.optimization.uniformShapeEdgeTrimAmount !== undefined ? parsedData.optimization.uniformShapeEdgeTrimAmount : 0;
    parsedData.optimization.optimizationMethod = parsedData.optimization.optimizationMethod !== undefined ? parsedData.optimization.optimizationMethod : '1';
    parsedData.optimization.travType = parsedData.optimization.travType !== undefined ? parsedData.optimization.travType : 'X';
    parsedData.optimization.rackCycleQty = parsedData.optimization.rackCycleQty !== undefined ? parsedData.optimization.rackCycleQty :5;
    // 为 display 参数添加默认值
    parsedData.display.themeColor = parsedData.display.themeColor !== undefined ? parsedData.display.themeColor : '#5168c8';
    parsedData.display.includeProductEdge = parsedData.display.includeProductEdge !== undefined ? parsedData.display.includeProductEdge : true;
    parsedData.display.includeIrregularEdge = parsedData.display.includeIrregularEdge !== undefined ? parsedData.display.includeIrregularEdge : true;
    // parsedData.display.mergeByFrameNumber = parsedData.display.mergeByFrameNumber !== undefined ? parsedData.display.mergeByFrameNumber : true;
    parsedData.display.frameNumber = parsedData.display.frameNumber !== undefined ? parsedData.display.frameNumber : true;
    parsedData.display.orderNumber = parsedData.display.orderNumber !== undefined ? parsedData.display.orderNumber : true;
    parsedData.display.productName = parsedData.display.productName !== undefined ? parsedData.display.productName : true;
    parsedData.display.processingInfo = parsedData.display.processingInfo !== undefined ? parsedData.display.processingInfo : true;
    parsedData.display.remarks = parsedData.display.remarks !== undefined ? parsedData.display.remarks : true;
    parsedData.display.floorNumber = parsedData.display.floorNumber !== undefined ? parsedData.display.floorNumber : true;
    parsedData.display.edgeLength = parsedData.display.edgeLength !== undefined ? parsedData.display.edgeLength : false;
    parsedData.display.manufacturingProcess = parsedData.display.manufacturingProcess !== undefined ? parsedData.display.manufacturingProcess : false;
    parsedData.display.identifier = parsedData.display.identifier !== undefined ? parsedData.display.identifier : false;
    // 为 cutting 参数添加默认值
    parsedData.cutting.cutting_direction = parsedData.cutting.cutting_direction !== undefined ? parsedData.cutting.cutting_direction : true;
    parsedData.cutting.show_cutting_path = parsedData.cutting.show_cutting_path !== undefined ? parsedData.cutting.show_cutting_path : true;
    parsedData.cutting.force_continuous_cutting = parsedData.cutting.force_continuous_cutting !== undefined ? parsedData.cutting.force_continuous_cutting : true;
    // parsedData.cutting.min_radius = parsedData.cutting.min_radius !== undefined ? parsedData.cutting.min_radius : 0;
    // parsedData.cutting.min_parallel_offset = parsedData.cutting.min_parallel_offset !== undefined ? parsedData.cutting.min_parallel_offset : 0;
    // parsedData.cutting.t_shaped_recess = parsedData.cutting.t_shaped_recess !== undefined ? parsedData.cutting.t_shaped_recess : 0;
    // parsedData.cutting.down_cut_spacing = parsedData.cutting.down_cut_spacing !== undefined ? parsedData.cutting.down_cut_spacing : 0;
    // parsedData.cutting.lift_retract = parsedData.cutting.lift_retract !== undefined ? parsedData.cutting.lift_retract : 0;
    // 为 server 参数添加默认值
    parsedData.server.printLayouts = parsedData.server.printLayouts !== undefined ? parsedData.server.printLayouts : '1';
    parsedData.server.printReport = parsedData.server.printReport !== undefined ? parsedData.server.printReport : '1';
    parsedData.server.layoutRows = parsedData.server.layoutRows !== undefined ? parsedData.server.layoutRows : '2';
    parsedData.server.layoutColumns = parsedData.server.layoutColumns !== undefined ? parsedData.server.layoutColumns : '2';
    parsedData.server.glassInfoShow = parsedData.server.glassInfoShow !== undefined ? parsedData.server.glassInfoShow : '2';
    parsedData.server.cutInfoShow = parsedData.server.cutInfoShow !== undefined ? parsedData.server.cutInfoShow : '1';
    parsedData.server.fileMode = parsedData.server.fileMode !== undefined ? parsedData.server.fileMode : '1';
    parsedData.server.haveMark = parsedData.server.haveMark !== undefined ? parsedData.server.haveMark : '1';
    parsedData.server.haveOptimaMark = parsedData.server.haveOptimaMark !== undefined ? parsedData.server.haveOptimaMark : '1';
    parsedData.server.haveQMark = parsedData.server.haveQMark !== undefined ? parsedData.server.haveQMark : '1';
    parsedData.server.glassIdMode = parsedData.server.glassIdMode !== undefined ? parsedData.server.glassIdMode : '1';
    parsedData.server.optimaMarkPosition = parsedData.server.optimaMarkPosition !== undefined ? parsedData.server.optimaMarkPosition : '1';
    parsedData.server.optimaMarkName = parsedData.server.optimaMarkName !== undefined ? parsedData.server.optimaMarkName : 'erweima_8mm';
    parsedData.server.optimaMarkWidth = parsedData.server.optimaMarkWidth !== undefined ? parsedData.server.optimaMarkWidth : 8;
    parsedData.server.optimaMarkHeight = parsedData.server.optimaMarkHeight !== undefined ? parsedData.server.optimaMarkHeight : 8;
    parsedData.server.output_format = parsedData.server.output_format !== undefined ? parsedData.server.output_format : '';
    parsedData.server.open_folder_after_save = parsedData.server.open_folder_after_save !== undefined ? parsedData.server.open_folder_after_save : '';
    parsedData.server.g_code_file_format = parsedData.server.g_code_file_format !== undefined ? parsedData.server.g_code_file_format : '';
    parsedData.server.btl_file_save_path = parsedData.server.btl_file_save_path !== undefined ? parsedData.server.btl_file_save_path : '';
    parsedData.server.optima_file_save_path = parsedData.server.optima_file_save_path !== undefined ? parsedData.server.optima_file_save_path : '';
    parsedData.server.optimization_depth_limit_enable = parsedData.server.optimization_depth_limit_enable !== undefined ? parsedData.server.optimization_depth_limit_enable : '';
    // 为 tempering 参数添加默认值
    parsedData.tempering.furnaceLength = parsedData.tempering.furnaceLength !== undefined ? parsedData.tempering.furnaceLength : 5000;
    parsedData.tempering.furnaceWidth = parsedData.tempering.furnaceWidth !== undefined ? parsedData.tempering.furnaceWidth : 2800;
    parsedData.tempering.maxLoadingRate = parsedData.tempering.maxLoadingRate !== undefined ? parsedData.tempering.maxLoadingRate : 50;
    parsedData.tempering.chaosLevel = parsedData.tempering.chaosLevel !== undefined ? parsedData.tempering.chaosLevel : 0;
    parsedData.tempering.temperingTime = parsedData.tempering.temperingTime !== undefined ? parsedData.tempering.temperingTime : 160;
    parsedData.tempering.defaultTemperingMode = parsedData.tempering.defaultTemperingMode !== undefined ? parsedData.tempering.defaultTemperingMode : 'auto';
    parsedData.tempering.maxArea = parsedData.tempering.maxArea !== undefined ? parsedData.tempering.maxArea : 0;
    parsedData.tempering.maxPieceCount = parsedData.tempering.maxPieceCount !== undefined ? parsedData.tempering.maxPieceCount : 10;
    parsedData.tempering.xAxisInterval = parsedData.tempering.xAxisInterval !== undefined ? parsedData.tempering.xAxisInterval : 80;
    parsedData.tempering.yAxisInterval = parsedData.tempering.yAxisInterval !== undefined ? parsedData.tempering.yAxisInterval : 80;
    Object.assign(settings, parsedData);
    console.log('设置已更新:', settings);
    // 为 optimization 参数设置默认值
    initializeOptimizationDefaults();
  } catch (error) {
    console.error('请求发生错误:', error);
    // 出现错误时也设置默认值
    setDefaultSettings();
  }
};
@@ -65,22 +159,18 @@
// 参数映射表,用于将英文参数名映射为中文名称和类型
const paramMapping = {
  optimizationMethod: { name: '优化方式', type: 'select' },
  smallPieceRotationProhibited: { name: '小片允许旋转', type: 'checkbox' },
  cutterOriginPosition: { name: '切割机原点位置', type: 'select' },
  travType: { name: '横切', type: 'select' },
  uniformShapeEdgeTrimAmount: { name: '统一设置异形修边量', type: 'text' },
  yShapeJoinOptimization: { name: '异形拼接优化', type: 'checkbox' },
  autoMiddleEmptyPairing: { name: '自动中空配对', type: 'checkbox' },
  smallPieceRotationProhibited: { name: '小片旋转', type: 'checkbox' },
  optimizationIterations: { name: '重复优化次数', type: 'text' },
  maxFramesOnSite: { name: '现场最大可放架子数量', type: 'text' },
  rackCycleQty: { name: '循环落架数', type: 'text' },
  bendEdgeDistance: { name: '掰边距(mm)', type: 'text' },
  positiveTolerance: { name: '正公差(mm)', type: 'text' },
  negativeTolerance: { name: '负公差(mm)', type: 'text' },
  cutterOriginPosition: { name: '切割机原点位置', type: 'select' },
  uniformShapeEdgeTrimAmount: { name: '统一设置异形修边量', type: 'text' },
  optimizationMethod: { name: '优化方式', type: 'select' },
  travType: { name: '横切', type: 'select' },
  optimizationIterations: { name: '重复优化次数', type: 'text' },
  finishedProductGrindingAmount: { name: '成品默认磨量', type: 'text' },
  rawPieceEdgeTrimAmount: { name: '原片默认修边量', type: 'text' },
  finishedSinglePieceBelowGrindingAmount: { name: '成品单片小于多少时磨量为', type: 'text' },
  rackCycleQty: { name: '循环落架数', type: 'text' }
};
// 动态生成参数列表
@@ -128,6 +218,14 @@
        <div class="sidebar-header">输出</div>
        <div class="sidebar-content">结果输出设置</div>
      </div>
      <div
          @click="selectComponent('mark')"
          :class="{ active: currentComponent === 'mark' }"
          class="sidebar-item"
      >
        <div class="sidebar-header">打标</div>
        <div class="sidebar-content">打标设置</div>
      </div>
      <div
        @click="selectComponent('tempering')"
@@ -137,6 +235,14 @@
        <div class="sidebar-header">钢化</div>
        <div class="sidebar-content">钢化设置</div>
      </div>
      <div
          @click="selectComponent('print')"
          :class="{ active: currentComponent === 'print' }"
          class="sidebar-item"
      >
        <div class="sidebar-header">打印</div>
        <div class="sidebar-content">打印设置</div>
      </div>
    </div>
    <div class="main-content">
@@ -144,7 +250,7 @@
        <div class="display-settings">
          <h2>版图显示设置</h2>
          <div class="form-group">
            <label>矩形成品显示颜色</label>
            <label>版图显示颜色设置</label>
            <input type="color" v-model="settings.display.themeColor" />
          </div>
          <div class="form-group">
@@ -154,10 +260,6 @@
          <div class="form-group">
            <label>异形尺寸包含磨边量</label>
            <input type="checkbox" v-model="settings.display.includeIrregularEdge" />
          </div>
          <div class="form-group">
            <label>按架号合并版图</label>
            <input type="checkbox" v-model="settings.display.mergeByFrameNumber" />
          </div>
          <div style="border: 1px solid #d2d0d0; margin-top: 20px;">
            <div style="background-color: #D5EAFF;">小片信息</div>
@@ -238,12 +340,89 @@
          </div>
        </div>
      </template>
      <template v-else-if="currentComponent === 'print'">
        <div class="display-settings">
          <h2>打印设置</h2>
          <div class="form-group">
            <label>是否打印版图</label>
            <div style="margin-left: 3px;"></div>
            <div class="radio-group">
              <input
                  type="radio"
                  id="printLayouts"
                  value="1"
                  v-model="settings.server.printLayouts"
              />
              <label for="printLayouts">是</label>
              <input
                  type="radio"
                  id="noPrintLayouts"
                  value="0"
                  v-model="settings.server.printLayouts"
                  style="margin-left: 20px;"
              />
              <label for="noPrintLayouts">否</label>
            </div>
          </div>
          <div class="form-group">
            <label>是否打印报告</label>
            <div style="margin-left: 3px;"></div>
            <div class="radio-group">
              <input
                  type="radio"
                  id="printReport"
                  value="1"
                  v-model="settings.server.printReport"
              />
              <label for="printReport">是</label>
              <input
                  type="radio"
                  id="noPrintReport"
                  value="0"
                  v-model="settings.server.printReport"
                  style="margin-left: 20px;"
              />
              <label for="noPrintReport">否</label>
            </div>
          </div>
          <div class="form-group">
            <label>布局选择</label>
            <select v-model="settings.server.layoutRows" class="cs" style="width: 10px; margin-right: 5px;">
              <option value="1">一行</option>
              <option value="2">两行</option>
              <option value="3">三行</option>
              <option value="4">四行</option>
            </select>
            <select v-model="settings.server.layoutColumns" class="cs" style="width: 10px;">
              <option value="1">一列</option>
              <option value="2">两列</option>
            </select>
          </div>
          <div class="form-group">
            <label>小片信息</label>
            <select v-model="settings.server.glassInfoShow" class="cs" style="width: 10px; margin-right: 10px;">
              <option value="0">不显示</option>
              <option value="1">显示在右侧</option>
              <option value="2">显示在下侧</option>
            </select>
          </div>
          <div class="form-group">
            <label>切割信息</label>
            <select v-model="settings.server.cutInfoShow" class="cs" style="width: 10px; margin-right: 10px;">
              <option value="0">不显示</option>
              <option value="1">显示</option>
            </select>
          </div>
        </div>
      </template>
      <template v-else-if="currentComponent === 'server'">
        <div class="display-settings">
          <h2>结果输出设置</h2>
          <div class="form-group">
            <label>文件模式</label>
            <label>切割文件保存模式</label>
            <div style="margin-left: 3px;"></div>
            <div class="radio-group">
              <input
                  type="radio"
@@ -263,14 +442,15 @@
              <label for="multiFile">多文件</label>
            </div>
          </div>
          <div class="form-group">
            <label>工程文件保存路径</label>
            <input type="text" v-model="settings.server.output_format" />
          </div>
          <div class="form-group">
            <label>切割代码保存路径</label>
            <input type="text" v-model="settings.server.cutting_code_save_path" />
          </div>
<!--          <div class="form-group">-->
<!--            <label>切割代码保存路径</label>-->
<!--            <input type="text" v-model="settings.server.cutting_code_save_path" />-->
<!--          </div>-->
          <div class="form-group">
            <label>保存文件后打开所在文件夹</label>
            <input type="text" v-model="settings.server.open_folder_after_save" />
@@ -279,10 +459,10 @@
            <label>G代码文件格式</label>
            <input type="text" v-model="settings.server.g_code_file_format" />
          </div>
          <div class="form-group">
            <label>TRF文件保存路径</label>
            <input type="text" v-model="settings.server.trf_file_save_path" />
          </div>
<!--          <div class="form-group">-->
<!--            <label>TRF文件保存路径</label>-->
<!--            <input type="text" v-model="settings.server.trf_file_save_path" />-->
<!--          </div>-->
          <div class="form-group">
            <label>保特罗文件保存路径</label>
            <input type="text" v-model="settings.server.btl_file_save_path" />
@@ -295,9 +475,139 @@
            <label>优化深度限制启用</label>
            <input type="text" v-model="settings.server.optimization_depth_limit_enable" />
          </div>
          <div class="form-group">
            <label>原片切材率计算</label>
            <input type="text" v-model="settings.server.original_sheet_material_calculation" />
<!--          <div class="form-group">-->
<!--            <label>原片切材率计算</label>-->
<!--            <input type="text" v-model="settings.server.original_sheet_material_calculation" />-->
<!--          </div>-->
        </div>
      </template>
      <template v-else-if="currentComponent === 'mark'">
        <div class="display-settings">
          <h2>打标设置</h2>
          <div style=" margin-top: 10px;padding: 4px; border-radius: 8px;">
            <div class="form-group">
              <label>是否打标</label>
              <div style="margin-left: 3px;"></div>
              <div class="radio-group">
                <input
                    type="radio"
                    id="singleFile"
                    value="1"
                    v-model="settings.server.haveMark"
                />
                <label for="singleFile">是</label>
                <input
                    type="radio"
                    id="multiFile"
                    value="0"
                    v-model="settings.server.haveMark"
                    style="margin-left: 20px;"
                />
                <label for="multiFile">否</label>
              </div>
            </div>
            <div class="form-group">
              <label>是否生成OPTIMA打标信息</label>
              <div style="margin-left: 3px;"></div>
              <div class="radio-group">
                <input
                    type="radio"
                    id="singleFile"
                    value="1"
                    v-model="settings.server.haveOptimaMark"
                />
                <label for="singleFile">是</label>
                <input
                    type="radio"
                    id="multiFile"
                    value="0"
                    v-model="settings.server.haveOptimaMark"
                    style="margin-left: 20px;"
                />
                <label for="multiFile">否</label>
              </div>
            </div>
            <div class="form-group">
              <label>是否生成速刻打标信息</label>
              <div style="margin-left: 28px;"></div>
              <div class="radio-group">
                <input
                    type="radio"
                    id="singleFile"
                    value="1"
                    v-model="settings.server.haveQMark"
                />
                <label for="singleFile">是</label>
                <input
                    type="radio"
                    id="multiFile"
                    value="0"
                    v-model="settings.server.haveQMark"
                    style="margin-left: 20px;"
                />
                <label for="multiFile">否</label>
              </div>
            </div>
            <div class="form-group">
              <label>玻璃ID模式</label>
              <div style="margin-left: 28px;"></div>
              <div class="radio-group">
                <input
                    type="radio"
                    id="singleFile"
                    value="1"
                    v-model="settings.server.glassIdMode"
                />
                <label for="singleFile">固定长度</label>
                <input
                    type="radio"
                    id="multiFile"
                    value="2"
                    v-model="settings.server.glassIdMode"
                    style="margin-left: 20px;"
                />
                <label for="multiFile">自动长度</label>
              </div>
            </div>
            <div class="form-group">
              <label>默认二维码位置</label>
              <div style="margin-left: 28px;"></div>
              <div class="radio-group">
                <input
                    type="radio"
                    id="singleFile"
                    value="1"
                    v-model="settings.server.optimaMarkPosition"
                />
                <label for="singleFile">长边对角</label>
                <input
                    type="radio"
                    id="multiFile"
                    value="2"
                    v-model="settings.server.optimaMarkPosition"
                    style="margin-left: 20px;"
                />
                <label for="multiFile">长边同边</label>
              </div>
            </div>
            <div class="form-group">
              <label>二维码文件名称(.ez3)</label>
              <input type="text" v-model="settings.server.optimaMarkName" />
            </div>
            <div class="form-group">
              <label>宽(mm)</label>
              <input type="text" v-model="settings.server.optimaMarkWidth" />
            </div>
            <div class="form-group">
              <label>高(mm)</label>
              <input type="text" v-model="settings.server.optimaMarkHeight" />
            </div>
          </div>
        </div>
      </template>
@@ -314,11 +624,11 @@
            <input type="number" v-model="settings.tempering.furnaceWidth" step="1" />
          </div>
          <div class="form-group">
            <label>最大装载率(%)</label>
            <label>钢化最大装载率(%)</label>
            <input type="number" v-model="settings.tempering.maxLoadingRate" step="1" />
          </div>
          <div class="form-group">
            <label>混乱程度(%)</label>
            <label>工程混排等级(%)</label>
            <input type="number" v-model="settings.tempering.chaosLevel" step="1" />
          </div>
          <div class="form-group">
@@ -395,6 +705,8 @@
          </div>
        </div>
      </template>
    </div>
    <button class="button" style="height: 40px;" @click="saveToDatabase">保存</button>