Commit 8a0e6a23893c31af57d81da15bfb6a9526ff3c29
Merge branch 'fix/DEFECT-1475' into 'main_dev'
属性下发时int和double相乘缩放因子 See merge request yunteng/thingskit-front!789
Showing
1 changed file
with
17 additions
and
6 deletions
| ... | ... | @@ -30,7 +30,9 @@ | 
| 30 | 30 | const modBUSForm = ref<any>({}); | 
| 31 | 31 | const isShowModBUS = ref<Boolean>(false); //用于判断标识符类型是否时自定义还是modBUS | 
| 32 | 32 | const isShowActionType = ref<Boolean>(true); //判断设备属性标识符为modBus时没有填写扩展描述 | 
| 33 | - const formField = ref(''); | |
| 33 | + const formField = ref(''); //存一个表单取值的field | |
| 34 | + const zoomFactorValue = ref<number>(1); //缩放因子 | |
| 35 | + const isShowMultiply = ref<Boolean>(false); // 只有tcp --> int和double类型才相乘缩放因子 | |
| 34 | 36 | |
| 35 | 37 | const [register] = useModalInner(async (params: ModalParamsType<DeviceModelOfMatterAttrs>) => { | 
| 36 | 38 | const { record } = params; | 
| ... | ... | @@ -39,8 +41,11 @@ | 
| 39 | 41 | const { type } = dataType || {}; | 
| 40 | 42 | const { codeType, deviceProfile } = deviceDetail || {}; | 
| 41 | 43 | const { transportType } = deviceProfile || {}; | 
| 42 | - const { registerAddress, actionType } = extensionDesc || {}; | |
| 44 | + const { registerAddress, actionType, zoomFactor } = extensionDesc || {}; //获取扩展描述内容 | |
| 45 | + | |
| 43 | 46 | formField.value = identifier; | 
| 47 | + zoomFactorValue.value = zoomFactor ? Number(zoomFactor) : 1; | |
| 48 | + isShowMultiply.value = type == 'INT' || type == 'DOUBLE' ? true : false; | |
| 44 | 49 | |
| 45 | 50 | let schemas = [{ dataType: dataType, identifier, functionName: name } as StructJSON]; | 
| 46 | 51 | |
| ... | ... | @@ -60,7 +65,7 @@ | 
| 60 | 65 | modBUSForm.value = { | 
| 61 | 66 | crc: 'CRC_16_LOWER', | 
| 62 | 67 | deviceCode: '01', | 
| 63 | - method: actionType, | |
| 68 | + method: actionType == '16' ? '10' : actionType, | |
| 64 | 69 | registerAddress, | 
| 65 | 70 | registerNumber: 1, | 
| 66 | 71 | registerValues: [], | 
| ... | ... | @@ -104,11 +109,17 @@ | 
| 104 | 109 | if (!flag) return; | 
| 105 | 110 | |
| 106 | 111 | const oldValue = getFieldsValue()[unref(formField)]; | 
| 107 | - modBUSForm.value.registerValues = [oldValue]; | |
| 108 | 112 | modBUSForm.value.registerNumber = 1; | 
| 113 | + modBUSForm.value.registerValues = [oldValue]; | |
| 114 | + if (unref(isShowMultiply) && unref(modBUSForm).method == '06') { | |
| 115 | + //bool类型的就不用去乘缩放因子了 | |
| 116 | + modBUSForm.value.registerValues = [oldValue * unref(zoomFactorValue)]; | |
| 117 | + } | |
| 109 | 118 | |
| 110 | - if (unref(modBUSForm).method == '16') { | |
| 111 | - const newValue = getArray(SingleToHex(oldValue)); | |
| 119 | + if (unref(modBUSForm).method == '16' || unref(modBUSForm).method == '10') { | |
| 120 | + const newValue = getArray( | |
| 121 | + SingleToHex(unref(isShowMultiply) ? oldValue * unref(zoomFactorValue) : oldValue) | |
| 122 | + ); | |
| 112 | 123 | modBUSForm.value.registerValues = newValue; | 
| 113 | 124 | modBUSForm.value.registerNumber = 2; | 
| 114 | 125 | modBUSForm.value.method = '10'; | ... | ... |