feat: 远程工具
This commit is contained in:
		
							parent
							
								
									9d6b9691a9
								
							
						
					
					
						commit
						e6c94fc951
					
				| @ -1,46 +0,0 @@ | ||||
| // @ts-ignore
 | ||||
| /* eslint-disable */ | ||||
| // @ts-ignore
 | ||||
| import request from '../common/utils/http'; | ||||
| 
 | ||||
| /** 2.无锡所接口请求 无锡所通用接口请求 POST /common/callWxsRest.do */ | ||||
| export async function callWxsRestUsingPost(body: API.Pinyin_20, options?: { [key: string]: any }) { | ||||
|   return request<API.ROfobject>('/common/callWxsRest.do', { | ||||
|     method: 'POST', | ||||
|     headers: { | ||||
|       'Content-Type': 'application/json;charset=UTF-8', | ||||
|     }, | ||||
|     data: body, | ||||
|     ...(options || {}), | ||||
|   }); | ||||
| } | ||||
| 
 | ||||
| /** 3.无锡所接口请求测试 无锡所接口请求测试,返回测试数据 POST /common/callWxsRestTest.do */ | ||||
| export async function callWxsRestTestUsingPost( | ||||
|   body: API.Pinyin_20, | ||||
|   options?: { [key: string]: any }, | ||||
| ) { | ||||
|   return request<API.ROfobject>('/common/callWxsRestTest.do', { | ||||
|     method: 'POST', | ||||
|     headers: { | ||||
|       'Content-Type': 'application/json;charset=UTF-8', | ||||
|     }, | ||||
|     data: body, | ||||
|     ...(options || {}), | ||||
|   }); | ||||
| } | ||||
| 
 | ||||
| /** 1.大屏显示数据查询与控制 大屏显示数据查询与控制 POST /data/examInfoStandardDisplay.ws */ | ||||
| export async function examInfoStandardDisplayUsingPost( | ||||
|   body: API.Pinyin_13, | ||||
|   options?: { [key: string]: any }, | ||||
| ) { | ||||
|   return request<API.ROf5>('/data/examInfoStandardDisplay.ws', { | ||||
|     method: 'POST', | ||||
|     headers: { | ||||
|       'Content-Type': 'application/json;charset=UTF-8', | ||||
|     }, | ||||
|     data: body, | ||||
|     ...(options || {}), | ||||
|   }); | ||||
| } | ||||
| @ -1,31 +0,0 @@ | ||||
| // @ts-ignore
 | ||||
| /* eslint-disable */ | ||||
| import request from '../common/utils/http'; | ||||
| 
 | ||||
| /** 2.考试中心执行参数同步 由外部(考试平台)调用,主动请求参数平台同步基础数据 GET /system/doParamBaseDataSync */ | ||||
| export async function doParamBaseDataSyncUsingGet(options?: { [key: string]: any }) { | ||||
|   return request<API.ROfobject>('/system/doParamBaseDataSync', { | ||||
|     method: 'GET', | ||||
|     ...(options || {}), | ||||
|   }); | ||||
| } | ||||
| 
 | ||||
| /** 3.考试中心执行参数数据同步 由外部(考试平台)调用,主动请求参数平台同步参数数据 GET /system/doParamConfigDataSync */ | ||||
| export async function doParamConfigDataSyncUsingGet(options?: { [key: string]: any }) { | ||||
|   return request<API.ROfobject>('/system/doParamConfigDataSync', { | ||||
|     method: 'GET', | ||||
|     ...(options || {}), | ||||
|   }); | ||||
| } | ||||
| 
 | ||||
| /** 1.用户登录 用户登录接口,获取用户相关信息和登录Token,登录后调用后台接口时,将Token放到请求头中 POST /system/userLogin.do */ | ||||
| export async function userLoginUsingPost(body: API.Pinyin_21, options?: { [key: string]: any }) { | ||||
|   return request<API.ROfobject>('/system/userLogin.do', { | ||||
|     method: 'POST', | ||||
|     headers: { | ||||
|       'Content-Type': 'application/json;charset=UTF-8', | ||||
|     }, | ||||
|     data: body, | ||||
|     ...(options || {}), | ||||
|   }); | ||||
| } | ||||
							
								
								
									
										964
									
								
								entry/src/main/ets/api/typings.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										964
									
								
								entry/src/main/ets/api/typings.d.ts
									
									
									
									
										vendored
									
									
								
							| @ -1,964 +0,0 @@ | ||||
| declare namespace API { | ||||
|   type CarBrand_ = { | ||||
|     /** 品牌名 {type_name} */ | ||||
|     brandName?: string; | ||||
|     /** 创建者 */ | ||||
|     createBy?: string; | ||||
|     /** 创建时间 */ | ||||
|     createTime?: string; | ||||
|     /** 百米脉冲 */ | ||||
|     hundredMeterPulse?: string; | ||||
|     /** 主键 */ | ||||
|     id?: number; | ||||
|     /** 签到序号起始点 */ | ||||
|     signNumber?: number; | ||||
|     /** SIMPLE_NAME */ | ||||
|     simpleName?: string; | ||||
|     /** 更新者 */ | ||||
|     updateBy?: string; | ||||
|     /** 更新时间 */ | ||||
|     updateTime?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type CarInfo_ = { | ||||
|     /** 监管分车时间 */ | ||||
|     assignTime?: string; | ||||
|     /** 车辆品牌id [car_brand.id] {cartypeid} */ | ||||
|     carBrandId?: number; | ||||
|     /** 考车自检状态(0:不用检查,1:待检查,2:检查通过,3:检查不通过) */ | ||||
|     carCheckStatus?: string; | ||||
|     /** 考车实际IP {carip} */ | ||||
|     carIp?: string; | ||||
|     /** 考车对应mac地址 */ | ||||
|     carMac?: string; | ||||
|     /** 考车编号 {carno} */ | ||||
|     carNo?: string; | ||||
|     /** 考车身份证号 */ | ||||
|     cardNoArray?: string; | ||||
|     /** 创建者 */ | ||||
|     createBy?: string; | ||||
|     /** 创建时间 */ | ||||
|     createTime?: string; | ||||
|     /** 删除标记(0:存在,2:已经删除)(status) */ | ||||
|     delFlag?: string; | ||||
|     /** 考点id [sys_dept.dept_id] {exampointid} */ | ||||
|     deptId?: number; | ||||
|     /** 设备号 */ | ||||
|     deviceNo?: string; | ||||
|     /** 考车状态(1:正常,2:停用,3:异常) */ | ||||
|     deviceStatus?: string; | ||||
|     /** 准驾车型 {cartype} */ | ||||
|     drivingLicenseType?: string; | ||||
|     /** 终点库位号 {zdkwh} */ | ||||
|     endPointNo?: string; | ||||
|     /** 考车路线 */ | ||||
|     examLineArray?: string; | ||||
|     /** 所属考官对应的用户id [sys_user.user_id] */ | ||||
|     examManId?: number; | ||||
|     /** 考试场次 {kscc} */ | ||||
|     examRound?: number; | ||||
|     /** 当前登录随车考试员id [examiner_info.id] */ | ||||
|     examinerId?: number; | ||||
|     /** 考场区域代号 */ | ||||
|     fieldId?: string; | ||||
|     /** 百米脉冲 */ | ||||
|     hundredMeterPulse?: string; | ||||
|     /** 主键 */ | ||||
|     id?: number; | ||||
|     /** 监控审核人脸识别方式(0:无人脸识别,1:视频截图方式,2:考车上传方式) {isface} */ | ||||
|     isFace?: string; | ||||
|     /** 是否更新map_collect (0:否,1:是) {is_mapcollect} */ | ||||
|     isMapCollect?: string; | ||||
|     /** 是否需要审核(0:否,1:是) */ | ||||
|     isReview?: string; | ||||
|     /** 上一次登录随车考试员 [examiner_info.id] */ | ||||
|     lastExaminerId?: number; | ||||
|     /** 考车号牌 {carcode} */ | ||||
|     licensePlate?: string; | ||||
|     /** 模型id [model_info.id] {modelid} */ | ||||
|     modelId?: number; | ||||
|     /** 导航线路 {dhxl} */ | ||||
|     navigationLine?: string; | ||||
|     /** 考车对应软件版本 */ | ||||
|     softwareVersion?: string; | ||||
|     /** 更新者 */ | ||||
|     updateBy?: string; | ||||
|     /** 更新时间 */ | ||||
|     updateTime?: string; | ||||
|     /** 车辆型号 */ | ||||
|     vehicleModel?: string; | ||||
|     /** 考车对应车辆识别代号 */ | ||||
|     vin?: string; | ||||
|     /** 考试路线 */ | ||||
|     wayNo?: number; | ||||
|   }; | ||||
| 
 | ||||
|   type ExamInfoVo = { | ||||
|     bk1?: string; | ||||
|     bz1?: string; | ||||
|     cartype?: string; | ||||
|     czlx?: string; | ||||
|     fieldid?: string; | ||||
|     flag?: string; | ||||
|     fz?: string; | ||||
|     jdxx?: string; | ||||
|     jxmc?: string; | ||||
|     kchp?: string; | ||||
|     kfxm?: string; | ||||
|     kscc?: string; | ||||
|     kscx?: string; | ||||
|     ksdd?: string; | ||||
|     kskm?: string; | ||||
|     kslx?: string; | ||||
|     ksmjzp?: string; | ||||
|     kssycs?: string; | ||||
|     ksxl?: string; | ||||
|     ksy1?: string; | ||||
|     ksy1sfzmhm?: string; | ||||
|     ksy2?: string; | ||||
|     ksy2sfzmhm?: string; | ||||
|     kszp?: string; | ||||
|     kszt?: string; | ||||
|     ktbh?: string; | ||||
|     lsh?: string; | ||||
|     motorType?: string; | ||||
|     roadway?: string; | ||||
|     securityGuard?: string; | ||||
|     sfcode?: string; | ||||
|     sfzmhm?: string; | ||||
|     updatetime?: string; | ||||
|     xb?: string; | ||||
|     xh?: string; | ||||
|     xldm?: string; | ||||
|     xm?: string; | ||||
|     ykrq?: string; | ||||
|     yycs?: string; | ||||
|     zkzmbh?: string; | ||||
|     zwxx1?: string; | ||||
|     zwxx2?: string; | ||||
|     zwxx3?: string; | ||||
|     zwxx4?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ExamPointInfo_ = { | ||||
|     /** 考场地址 {address} */ | ||||
|     address?: string; | ||||
|     /** 考场车辆类型(1:小车,2:大车,3:摩托){is_motor} */ | ||||
|     carType?: string; | ||||
|     /** 创建者 */ | ||||
|     createBy?: string; | ||||
|     /** 创建时间 */ | ||||
|     createTime?: string; | ||||
|     /** 所属部门id [sys_dept.dept_id] {organize_id} */ | ||||
|     deptId?: number; | ||||
|     /** 考点名称 {name} */ | ||||
|     deptName?: string; | ||||
|     /** 准驾车型(列表,逗号隔开) {car_type} */ | ||||
|     drivingLicenseType?: string; | ||||
|     /** 考点代码 {code} */ | ||||
|     examPointCode?: string; | ||||
|     /** 考点全称 {fullname} */ | ||||
|     fullName?: string; | ||||
|     /** 主键 */ | ||||
|     id?: number; | ||||
|     /** 联系人 {contact} */ | ||||
|     master?: string; | ||||
|     /** 联系电话 {phone} */ | ||||
|     phone?: string; | ||||
|     /** 电子地图映射信息json */ | ||||
|     photoInfo?: string; | ||||
|     /** 电子地图图片路径 {path} */ | ||||
|     photoPath?: string; | ||||
|     /** 备注 */ | ||||
|     remark?: string; | ||||
|     /** 考试科目 {type} */ | ||||
|     subjectType?: string; | ||||
|     /** 更新者 */ | ||||
|     updateBy?: string; | ||||
|     /** 更新时间 */ | ||||
|     updateTime?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type GpsIPUdpIP_ = { | ||||
|     /** 车辆品牌名称 */ | ||||
|     carBrandName?: string; | ||||
|     /** 准驾车型(C1、C2...) */ | ||||
|     drivingLicenseType?: string; | ||||
|     /** GPS差分服务器地址 */ | ||||
|     gpsAddress?: string; | ||||
|     /** 是否需要自检(0:不需要自检,1:需要自检) */ | ||||
|     isNeedCheck?: string; | ||||
|     /** 百米脉冲 */ | ||||
|     pulse?: string; | ||||
|     /** 考试科目 */ | ||||
|     subjectType?: string; | ||||
|     /** UDP服务器数据端口号 */ | ||||
|     udpDataPort?: string; | ||||
|     /** UDP服务器ip */ | ||||
|     udpIp?: string; | ||||
|     /** UDP服务器消息端口号 */ | ||||
|     udpMessagePort?: string; | ||||
|     /** 语音对讲服务ip */ | ||||
|     voiceIp?: string; | ||||
|     /** 语音对讲服务端口号 */ | ||||
|     voicePort?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type GpsIPUdpIP2 = { | ||||
|     /** 车牌号 */ | ||||
|     licensePlate: string; | ||||
|     /** 评判版本号 */ | ||||
|     softwareVersion: string; | ||||
|   }; | ||||
| 
 | ||||
|   type MarkRuleSet = { | ||||
|     itemName?: string; | ||||
|     itemno?: string; | ||||
|     kfxh?: string; | ||||
|     markcatalog?: string; | ||||
|     markdepend?: string; | ||||
|     markreal?: string; | ||||
|     markserial?: string; | ||||
|     markshow?: string; | ||||
|     markstandard?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type paramConfigDataSyncUsingGETParams = { | ||||
|     /** tableName */ | ||||
|     tableName: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin__ = { | ||||
|     /** 车牌号 */ | ||||
|     licensePlate: string; | ||||
|     /** 考试里程{kslc} */ | ||||
|     mileage: number; | ||||
|     /** 流水号 */ | ||||
|     serialNo: string; | ||||
|     /** 特殊扣分内容 */ | ||||
|     specialSub?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_10 = { | ||||
|     /** 考车id */ | ||||
|     gunCameraInfos?: Pinyin_9[]; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_11 = { | ||||
|     /** 小红球程序编号 */ | ||||
|     deviceNo: string; | ||||
|     /** 小红球消息 */ | ||||
|     message: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_12 = { | ||||
|     kaoShengXinXi?: ExamInfoVo[]; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_13 = { | ||||
|     b2no?: string; | ||||
|     c1no?: string; | ||||
|     c2no?: string; | ||||
|     c5no?: string; | ||||
|     deviceNo?: string; | ||||
|     fieldId?: string; | ||||
|     kscc?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_14 = { | ||||
|     judgeVersion?: string; | ||||
|     kdid?: string; | ||||
|     kskm?: string; | ||||
|     markRuleSet?: MarkRuleSet[]; | ||||
|     shellVersion?: string; | ||||
|     speendParam?: string; | ||||
|     vehicleSpeend?: VehicleSpeend[]; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_15 = { | ||||
|     /** 小红球程序编号 */ | ||||
|     deviceNo: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_16 = { | ||||
|     aqyphoto?: string; | ||||
|     aqysfzmhm?: string; | ||||
|     aqyxm?: string; | ||||
|     bkhgkssj?: string; | ||||
|     jxmc?: string; | ||||
|     kch?: string; | ||||
|     kchp?: string; | ||||
|     kclx?: string; | ||||
|     kcmc?: string; | ||||
|     kscs?: string; | ||||
|     kscx?: string; | ||||
|     ksxl?: string; | ||||
|     ksyphoto?: string; | ||||
|     ksysfzmhm?: string; | ||||
|     ksyxm?: string; | ||||
|     lsh?: string; | ||||
|     sfzmhm?: string; | ||||
|     xm?: string; | ||||
|     yycs?: string; | ||||
|     zp1?: string; | ||||
|     zp2?: string; | ||||
|     zwh?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_17 = { | ||||
|     /** 考车编号 */ | ||||
|     carNo: string; | ||||
|     /** 小红球程序编号 */ | ||||
|     deviceNo: string; | ||||
|     /** 流水号 */ | ||||
|     serialNo: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_18 = { | ||||
|     /** 随车考试员编号 */ | ||||
|     examinerCode?: string; | ||||
|     /** 车牌号 */ | ||||
|     licensePlate: string; | ||||
|     /** 流水号 */ | ||||
|     serialNo: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_19 = { | ||||
|     /** 安徽已考项目 */ | ||||
|     ahykxx?: string; | ||||
|     /** 大车初考项目 */ | ||||
|     firstABykxx?: string; | ||||
|     /** 考试剩余次数 */ | ||||
|     kssycs?: string; | ||||
|     /** 考试预约流水号 */ | ||||
|     lsh?: string; | ||||
|     /** 摩托车考试模式 */ | ||||
|     motorType?: string; | ||||
|     /** 大车补考项目 */ | ||||
|     secondABykxx?: string; | ||||
|     /** 约考信息,内容如:开始时间;里程;考试项目;扣分项目;特殊地方扣分明细 */ | ||||
|     ykxx?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_2 = { | ||||
|     /** 文件base64 */ | ||||
|     examData: string; | ||||
|     /** 考试结束时间 */ | ||||
|     examEndTime: string; | ||||
|     /** 考试开始时间 */ | ||||
|     examStartTime: string; | ||||
|     /** 文件名称(type=2/3时需要传) */ | ||||
|     fileName?: string; | ||||
|     /** 车牌号 */ | ||||
|     licensePlate: string; | ||||
|     /** 流水号 */ | ||||
|     serialNo: string; | ||||
|     /** 文件类型,鸿蒙考车固定传1(0:本地轨迹,1:监管轨迹,2:轨迹回放,3:注意力识别) */ | ||||
|     type: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_20 = { | ||||
|     /** 考车请求时间,跟下面请求数据data中的业务发生时间相同,这里用作设备时差校验 */ | ||||
|     carSendTime: string; | ||||
|     /** 请求数据,详见无锡所接口文档。JSON对象 */ | ||||
|     data: Record<string, any>; | ||||
|     /** 文件列表 */ | ||||
|     files?: WxsBaseFileBean[]; | ||||
|     /** 车牌号 */ | ||||
|     licensePlate: string; | ||||
|     /** 接口编号,例如:02-21-000009(考试开始) */ | ||||
|     restCode: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_21 = { | ||||
|     /** 设备imei号 */ | ||||
|     imei: string; | ||||
|     /** 用户登录时间戳 */ | ||||
|     loginTime: number; | ||||
|     /** md5加密串(根据imei号+时间戳+盐混淆) */ | ||||
|     signKey: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_22 = { | ||||
|     /** 中心服务器当前时间 */ | ||||
|     time?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_23 = { | ||||
|     /** 设备名称 */ | ||||
|     deviceName: string; | ||||
|     /** 设备编号 */ | ||||
|     deviceNo: string; | ||||
|     /** 设备类型(1:考车;2:闸机;3:大屏;4:指纹仪;5:拍照) */ | ||||
|     type: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_24 = { | ||||
|     /** 考试项目 */ | ||||
|     bk1?: string; | ||||
|     /** 备注1 0,0, */ | ||||
|     bz1?: string; | ||||
|     /** 考试车型,考生表的carType */ | ||||
|     cartype?: string; | ||||
|     /** 操作类型 */ | ||||
|     czlx?: string; | ||||
|     /** 考试区域 */ | ||||
|     fieldid?: string; | ||||
|     /** 考试是否合格 */ | ||||
|     flag?: string; | ||||
|     /** 考试分组 */ | ||||
|     fz?: string; | ||||
|     /** 阶段信息 */ | ||||
|     jdxx?: string; | ||||
|     /** 驾校名称 */ | ||||
|     jxmc?: string; | ||||
|     /** 考车号牌 */ | ||||
|     kchp?: string; | ||||
|     /** 扣分项目 */ | ||||
|     kfxm?: string; | ||||
|     /** 考试场次 */ | ||||
|     kscc?: string; | ||||
|     /** 考试车型 */ | ||||
|     kscx?: string; | ||||
|     /** 考试地点,考场编号 */ | ||||
|     ksdd?: string; | ||||
|     /** 考试科目 */ | ||||
|     kskm?: string; | ||||
|     /** 考试类型 */ | ||||
|     kslx?: string; | ||||
|     /** ksmjzp */ | ||||
|     ksmjzp?: string; | ||||
|     /** 考试剩余次数 */ | ||||
|     kssycs?: string; | ||||
|     /** 考试线路-实用 */ | ||||
|     ksxl?: string; | ||||
|     /** 考试员姓名1 */ | ||||
|     ksy1?: string; | ||||
|     /** 考试员1身份证号 */ | ||||
|     ksy1sfzmhm?: string; | ||||
|     /** 考试员随车考试员2 */ | ||||
|     ksy2?: string; | ||||
|     /** 考试员2身份证号 */ | ||||
|     ksy2sfzmhm?: string; | ||||
|     /** 考生照片,base64编码 */ | ||||
|     kszp?: string; | ||||
|     /** 考试状态 */ | ||||
|     kszt?: string; | ||||
|     /** 考台编号 */ | ||||
|     ktbh?: string; | ||||
|     /** 考试预约流水号 */ | ||||
|     lsh?: string; | ||||
|     /** 摩托车考试模式 1.先考科目2,再考科目3 2.科目2 3.科目3 4.先考科目3,再考科目2 */ | ||||
|     motorType?: string; | ||||
|     /** 车道 */ | ||||
|     roadway?: string; | ||||
|     /** 安全员姓名 */ | ||||
|     securityGuard?: string; | ||||
|     /** 6位身份编码 */ | ||||
|     sfcode?: string; | ||||
|     /** 身份证号 */ | ||||
|     sfzmhm?: string; | ||||
|     /** 上车更新时间 */ | ||||
|     updatetime?: string; | ||||
|     /** 考生性别 */ | ||||
|     xb?: string; | ||||
|     /** 序号 */ | ||||
|     xh?: string; | ||||
|     /** 监管线路代码,上传用 */ | ||||
|     xldm?: string; | ||||
|     /** 考生姓名 */ | ||||
|     xm?: string; | ||||
|     /** 约考日期 */ | ||||
|     ykrq?: string; | ||||
|     /** 预约次数 */ | ||||
|     yycs?: string; | ||||
|     /** 准考证明编号,admissionNo */ | ||||
|     zkzmbh?: string; | ||||
|     /** 指纹1 */ | ||||
|     zwxx1?: string; | ||||
|     /** 指纹2 */ | ||||
|     zwxx2?: string; | ||||
|     /** 指纹3 */ | ||||
|     zwxx3?: string; | ||||
|     /** 指纹4 */ | ||||
|     zwxx4?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_25 = { | ||||
|     /** 设备号 */ | ||||
|     deviceNo: string; | ||||
|     /** 照片1 */ | ||||
|     firstImage: string; | ||||
|     /** 照片2 */ | ||||
|     secondImage: string; | ||||
|     /** 身份证号码 */ | ||||
|     sfzh: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_26 = { | ||||
|     /** 车牌号 */ | ||||
|     licensePlate: string; | ||||
|     /** 流水号 */ | ||||
|     serialNo: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_27 = { | ||||
|     /** 类别(1:外壳,2:视屏,3:评判,4:接口) */ | ||||
|     category: string; | ||||
|     /** 车牌号 */ | ||||
|     licensePlate: string; | ||||
|     /** 日志内容 */ | ||||
|     logData: string; | ||||
|     /** 考车日志类型(1:升级日,2:错误日志) */ | ||||
|     logType: string; | ||||
|     /** 考车发生时间(格式:yyyy-MM-dd HH:mm:ss) */ | ||||
|     vehicleTime: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_28 = { | ||||
|     /** 设备编号 */ | ||||
|     deviceNo: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_29 = { | ||||
|     /** 自检结果附带信息 */ | ||||
|     condition: string; | ||||
|     /** 自检结果(1:合格,0:不合格) */ | ||||
|     flag: string; | ||||
|     /** 车牌号 */ | ||||
|     licensePlate: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_3 = { | ||||
|     /** 车牌号 */ | ||||
|     licensePlate: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_30 = { | ||||
|     /** 考车编号 */ | ||||
|     carNo?: string; | ||||
|     /** 车辆类型 */ | ||||
|     carType?: string; | ||||
|     /** 身份证号 */ | ||||
|     cardNo?: string; | ||||
|     /** 设备编号 */ | ||||
|     deviceNo?: string; | ||||
|     faceVerifyRes?: string; | ||||
|     /** fieldId */ | ||||
|     fieldId?: string; | ||||
|     fingerVerifyRes?: string; | ||||
|     /** 体温是否正常标志 */ | ||||
|     health?: string; | ||||
|     /** 6位身份编码  */ | ||||
|     idNoSix?: string; | ||||
|     /** 考官证件号码 */ | ||||
|     kgCardNo?: string; | ||||
|     /** 人工过门禁原因 */ | ||||
|     manualReason?: string; | ||||
|     /** mixModel */ | ||||
|     mixModel?: string; | ||||
|     /** 人脸识别度 */ | ||||
|     rlsbValue?: string; | ||||
|     /** 流水号 */ | ||||
|     serialNo?: string; | ||||
|     sfzzp?: string; | ||||
|     /** 考试科目 */ | ||||
|     subjectType?: string; | ||||
|     /** 体温值 */ | ||||
|     temperature?: string; | ||||
|     /** 体温照片1 */ | ||||
|     twzp1?: string; | ||||
|     /** 体温照片2 */ | ||||
|     twzp2?: string; | ||||
|     /** 照片 */ | ||||
|     zp?: string; | ||||
|     zw1?: string; | ||||
|     zw2?: string; | ||||
|     zw3?: string; | ||||
|     zw4?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_31 = { | ||||
|     /** 模型内容(base64) */ | ||||
|     content: string; | ||||
|     /** 文件名 */ | ||||
|     filename: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_32 = { | ||||
|     /** 车牌号 */ | ||||
|     licensePlate: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_33 = { | ||||
|     /** 车牌号码 */ | ||||
|     licensePlate: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_34 = { | ||||
|     /** 车牌号 */ | ||||
|     licensePlate: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_35 = { | ||||
|     /** 是否需要自检(0:不需要自检,1:需要自检) */ | ||||
|     isNeedCheck?: string; | ||||
|     /** 自检项目 */ | ||||
|     items?: string; | ||||
|     /** 串口号 */ | ||||
|     portNo?: string; | ||||
|     /** 重试次数 */ | ||||
|     retryTime?: string; | ||||
|     /** (1:取反,0:不取反)例如安全带取反且离合器不取反即(1^0)  */ | ||||
|     reverse?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_36 = { | ||||
|     /** 住址 */ | ||||
|     addr?: string; | ||||
|     /** 设备编号 */ | ||||
|     deviceNo?: string; | ||||
|     /** fieldId */ | ||||
|     fieldId?: string; | ||||
|     /** 考官证件号码 */ | ||||
|     kgsfzmhm?: string; | ||||
|     /** 考试科目 */ | ||||
|     kskm?: string; | ||||
|     /** 流水号 */ | ||||
|     lsh?: string; | ||||
|     /** mixModel */ | ||||
|     mixModel?: string; | ||||
|     /** 身份证号 */ | ||||
|     sfzh: string; | ||||
|     /** 姓名 */ | ||||
|     xm?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_37 = { | ||||
|     /** 设备号 */ | ||||
|     deviceNo?: string; | ||||
|     /** 照片1 */ | ||||
|     firstImage?: string; | ||||
|     /** 考试科目 */ | ||||
|     kskm?: string; | ||||
|     /** 认证次数 */ | ||||
|     rzcs?: string; | ||||
|     /** 照片2 */ | ||||
|     secondImage: string; | ||||
|     /** 身份证号码 */ | ||||
|     sfzh: string; | ||||
|     /** 设备类型(1、门禁2、考车3、过程) */ | ||||
|     type: string; | ||||
|     /** 审核类型(2、人工审核) */ | ||||
|     verifyType?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_38 = { | ||||
|     /** 设备硬件号 */ | ||||
|     deviceNo: string; | ||||
|     /** 门禁程序版本号 */ | ||||
|     gateVersion: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_39 = { | ||||
|     /** 随车考试员登录用户名(可以是身份证号、员工号、制卡号等等) */ | ||||
|     examinerName: string; | ||||
|     /** 随车考试员密码 */ | ||||
|     examinerPwd?: string; | ||||
|     /** 车牌号 */ | ||||
|     licensePlate: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_4 = { | ||||
|     /** 考生信息列表 */ | ||||
|     studentList?: Pinyin_24[]; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_40 = { | ||||
|     /** 指纹信息1 */ | ||||
|     finger1?: string; | ||||
|     /** 指纹信息2 */ | ||||
|     finger2?: string; | ||||
|     /** 随车考试员姓名 */ | ||||
|     name?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_5 = { | ||||
|     /** 车牌号码 */ | ||||
|     licensePlate: string; | ||||
|     /** 表名,大写 */ | ||||
|     tableName: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_6 = { | ||||
|     /** car_mac */ | ||||
|     car_mac: string; | ||||
|     /** 设备类型(1:海康,2:大华) */ | ||||
|     equipment_type: string; | ||||
|     /** 第一路通道 */ | ||||
|     first_channel: string; | ||||
|     /** 第一路ip */ | ||||
|     first_ip: string; | ||||
|     /** 第一路密码 */ | ||||
|     first_password: string; | ||||
|     /** 第一路端口 */ | ||||
|     first_port: string; | ||||
|     /** 第一路用户名 */ | ||||
|     first_username: string; | ||||
|     /** 第四路通道 */ | ||||
|     fourth_channel: string; | ||||
|     /** 第四路ip */ | ||||
|     fourth_ip: string; | ||||
|     /** 第四路密码 */ | ||||
|     fourth_password: string; | ||||
|     /** 第四路端口 */ | ||||
|     fourth_port: string; | ||||
|     /** 第四路用户名 */ | ||||
|     fourth_username: string; | ||||
|     /** 连接类型(0:主码流TCP方式,1:子码流TCP方式,2:主码流UDP方式,3:子码流UDP方式) */ | ||||
|     line_type: string; | ||||
|     /** 拍照通道 */ | ||||
|     photo_channel: string; | ||||
|     /** 叠加内容1(1.考生姓名,身份证号,3.当前项目,4.当前时间) */ | ||||
|     photo_overlay_text_content1: string; | ||||
|     /** 叠加内容2(1.考生姓名,身份证号,3.当前项目,4.当前时间,0:空) */ | ||||
|     photo_overlay_text_content2: string; | ||||
|     /** 叠加内容3(1.考生姓名,身份证号,3.当前项目,4.当前时间,0:空) */ | ||||
|     photo_overlay_text_content3: string; | ||||
|     /** 照片叠加文字(1:启用,0:关闭) */ | ||||
|     photo_overlay_text_enable: string; | ||||
|     /** 位置(1:左上角,2:右上角,3:左下角,4.右下角) */ | ||||
|     photo_overlay_text_position: string; | ||||
|     /** 文字大小 */ | ||||
|     photo_overlay_text_size: string; | ||||
|     /** 分割符(1:/,2:*\,3:换行) */ | ||||
|     photo_overlay_text_split: string; | ||||
|     /** 启用过程人脸比对 {process_face_comparion_enable} */ | ||||
|     process_face_comparion_enable: string; | ||||
|     /** 过程人脸比对模式(1:启用,0:关闭) {process_face_comparion_mode} */ | ||||
|     process_face_comparion_mode: string; | ||||
|     /** 第二路通道 */ | ||||
|     second_channel: string; | ||||
|     /** 第二路ip */ | ||||
|     second_ip: string; | ||||
|     /** 第二路密码 */ | ||||
|     second_password: string; | ||||
|     /** 第二路端口 */ | ||||
|     second_port: string; | ||||
|     /** 第二路用户名 */ | ||||
|     second_username: string; | ||||
|     /** 第三路通道 */ | ||||
|     third_channel: string; | ||||
|     /** 第三路ip */ | ||||
|     third_ip: string; | ||||
|     /** 第三路密码 */ | ||||
|     third_password: string; | ||||
|     /** 第三路端口 */ | ||||
|     third_port: string; | ||||
|     /** 第三路用户名 */ | ||||
|     third_username: string; | ||||
|     /** 视频路数 */ | ||||
|     video_channel: string; | ||||
|     /** 录像方式(0:本地录像,1:本地不录象) */ | ||||
|     video_mode: string; | ||||
|     /** 视频遮挡 */ | ||||
|     video_occlusion: string; | ||||
|     /** 视频遮挡范围(1:一路,2:二路,3:三路,4:四路) */ | ||||
|     video_occlusion_range: string; | ||||
|     /** 视频叠加位置X */ | ||||
|     video_overlay_position_x: string; | ||||
|     /** 视频叠加位置Y */ | ||||
|     video_overlay_position_y: string; | ||||
|     /** 视频叠加内容1(1:考生姓名,2:身份证号,3:当前项目,4:当前时间) */ | ||||
|     video_overlay_text_content1: string; | ||||
|     /** 视频叠加内容2(1:考生姓名,2:身份证号,3:当前项目,4:当前时间,0:空) */ | ||||
|     video_overlay_text_content2: string; | ||||
|     /** 视频叠加内容3(1:考生姓名,2:身份证号,3:当前项目,4:当前时间,0:空) */ | ||||
|     video_overlay_text_content3: string; | ||||
|     /** 视频叠加文字(1:启用,0:关闭) */ | ||||
|     video_overlay_text_enable: string; | ||||
|     /** 视频叠加分割符(1:/,2:*\,3:换行) */ | ||||
|     video_overlay_text_split: string; | ||||
|     /** 录像范围(1:一路,2:二路,3:三路,4:四路) */ | ||||
|     video_range: string; | ||||
|     /** 本考车对应视频合成服务器IP(填错将不能开始考试) */ | ||||
|     video_synthesis_server_ip: string; | ||||
|     /** 本考车对应视频合成服务器端口(填错将不能开始考试) */ | ||||
|     video_synthesis_server_port: string; | ||||
|     /** 本考车对应视频合成信息处理系统IP(填错或不填将可能导致录像丢失) */ | ||||
|     video_synthesis_system_ip: string; | ||||
|     /** 本考车对应视频合成信息处理系统本地响应端口(填错或不填将可能导致录像丢失) */ | ||||
|     video_synthesis_system_port: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_7 = { | ||||
|     /** 车牌号 */ | ||||
|     licensePlate: string; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_8 = { | ||||
|     /** 车辆品牌列表 */ | ||||
|     carBrandList?: CarBrand_[]; | ||||
|     /** 考车列表 */ | ||||
|     carInfoList?: CarInfo_[]; | ||||
|     /** 考点列表 */ | ||||
|     examPointInfoList?: ExamPointInfo_[]; | ||||
|   }; | ||||
| 
 | ||||
|   type Pinyin_9 = { | ||||
|     /** 摄像头通道号 */ | ||||
|     channel?: string; | ||||
|     /** 硬盘录像机ip */ | ||||
|     deviceIP?: string; | ||||
|     /** 监管场地编号 */ | ||||
|     equipmentId?: string; | ||||
|     /** 非全景绑定的全景 */ | ||||
|     fullId?: string; | ||||
|     /** 全景区域坐标 */ | ||||
|     gpsArea?: string; | ||||
|     /** 摄像头id */ | ||||
|     id?: string; | ||||
|     /** 是否全景摄像头 */ | ||||
|     isFull?: string; | ||||
|     /** 硬盘录像机密码 */ | ||||
|     password?: string; | ||||
|     /** 硬盘录像机端口 */ | ||||
|     port?: string; | ||||
|     /** 硬盘录像机用户名 */ | ||||
|     user?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROf_ = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     data?: Pinyin_4; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROf10 = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     data?: Pinyin_31; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROf11 = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     data?: Pinyin_35; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROf12 = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     data?: Pinyin_40; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROf2 = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     data?: Pinyin_6; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROf3 = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     data?: Pinyin_8; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROf4 = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     data?: Pinyin_10; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROf5 = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     data?: Pinyin_12; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROf6 = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     data?: Pinyin_14; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROf7 = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     data?: Pinyin_16; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROf8 = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     data?: Pinyin_19; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROf9 = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     data?: Pinyin_22; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROfGpsIPUdpIP_ = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     data?: GpsIPUdpIP_; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROfListOfobject = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     /** 承载数据 */ | ||||
|     data?: Record<string, any>[]; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type ROfobject = { | ||||
|     /** 状态码 1成功 0通用失败 */ | ||||
|     code: number; | ||||
|     /** 承载数据 */ | ||||
|     data?: Record<string, any>; | ||||
|     /** 返回消息 */ | ||||
|     msg: string; | ||||
|   }; | ||||
| 
 | ||||
|   type VehicleSpeend = { | ||||
|     carType?: string; | ||||
|     speend?: string; | ||||
|   }; | ||||
| 
 | ||||
|   type WxsBaseFileBean = { | ||||
|     /** 文件内容base64编码 */ | ||||
|     data: string; | ||||
|     /** 文件类别或id */ | ||||
|     fileid: string; | ||||
|   }; | ||||
| } | ||||
| @ -12,7 +12,7 @@ const TAG = '[updateModelAndCar]' | ||||
| export async function updateModelAndCar(flag){ | ||||
|   const data:any = await getModalValueCdAndCar({ carid: globalThis.carInfo.carId }) | ||||
| 
 | ||||
|   const outFile = flag ? '/data/storage/el2/base/haps/entry/files/' : '/mnt/hmdfs/100/account/device_view/local/files/duolun/models' | ||||
|     const outFile = flag ? '/data/storage/el2/base/haps/entry/files/' : '/mnt/hmdfs/100/account/device_view/local/files/duolun/models' | ||||
|   const httpPath = flag ? data.getModalValueCdAndCarRsp.body.appPath : data.getModalValueCdAndCarRsp.body.filePath | ||||
|   const arr = httpPath.split('/') | ||||
|   let path | ||||
|  | ||||
| @ -1,7 +1,5 @@ | ||||
| //import UdpClient from './UdpClient';
 | ||||
| import UdpClientByCenter from './UdpClientByCenter'; | ||||
| import { getSyncData } from '../service/initable'; | ||||
| import { getChuankouFn,uploadLogFile} from '../../common/service/indexService'; | ||||
| import { getChuankouFn, uploadLogFile } from '../../common/service/indexService'; | ||||
| import FileUtil from '../../common/utils/File'; | ||||
| import { GlobalConfig } from '../../config/index'; | ||||
| import { Array2Byte, string2Bytes } from './tools'; | ||||
| @ -11,20 +9,17 @@ export async function sendMsg(val) { | ||||
| } | ||||
| 
 | ||||
| export async function getUDP(context, errorFlag?) { | ||||
|   return new Promise(async (reslove, reject) => { | ||||
|   return new Promise(async (resolve, reject) => { | ||||
|     const fileUtil = new FileUtil(context) | ||||
|     const data = await fileUtil.readFile(GlobalConfig.comoonfileWriteAddress + '/config/ipConfig.txt'); | ||||
|     console.log('ttttt', data) | ||||
|     if (data === '' || data === undefined) { | ||||
|       console.log(` getUDP  has no IPConfigTable `); | ||||
|       globalThis.udpClient = {} | ||||
|       globalThis.host = '' | ||||
|       reslove('') | ||||
|       resolve('') | ||||
|     } else { | ||||
|       const result = JSON.parse(data) | ||||
|       console.log(` getUDP  has IPConfigTable `); | ||||
|       if (globalThis.udpClient && globalThis.udpClient.closeUdp) { | ||||
|         console.log(` getUDP  has udclent close and rebind `); | ||||
|         globalThis.udpClient.closeUdp(() => { | ||||
|           setTimeout(() => { | ||||
|             globalThis.udpClient.rebindUdp(result.udplocalIp, result.udplocalIpPort, result.udpOppositeIp, | ||||
| @ -32,22 +27,17 @@ export async function getUDP(context, errorFlag?) { | ||||
|             globalThis.udpClient.sendMsg('111', null) | ||||
|             globalThis.host = `http://${result.centerIp}:${result.centerPort}` | ||||
|             globalThis.udpClient.onError_Callback(() => { | ||||
|               console.log('getUDPgetUDPgetUDP') | ||||
|               getUDP(context, true) | ||||
|               if (errorFlag && globalThis.udpClient && globalThis.udpClient.onMessage_1) { | ||||
|                 globalThis.udpClient.onMessage_1 = globalThis.udpClient.onMessage_1 | ||||
|               } | ||||
|             }) | ||||
|             reslove(`http://${result.centerIp}:${result.centerPort}`) | ||||
| 
 | ||||
|             // globalThis.udpClient.onError_resend(globalThis.udpClient.onMessage_1?globalThis.udpClient.onMessage_1:()=>{})
 | ||||
|             resolve(`http://${result.centerIp}:${result.centerPort}`) | ||||
|           }, 1000) | ||||
|         }) | ||||
| 
 | ||||
|       } else { | ||||
|         // 未绑定
 | ||||
|         console.log(` getUDP  has no  udclent and  bind `); | ||||
|         console.log('ttttttdata', JSON.stringify(result)) | ||||
|         const udpClient: UdpClientByCenter = | ||||
|           new UdpClientByCenter(result.udplocalIp, result.udplocalIpPort, result.udpOppositeIp, | ||||
|             result.udpOppositeIpPort) | ||||
| @ -64,78 +54,12 @@ export async function getUDP(context, errorFlag?) { | ||||
|           } | ||||
|         }) | ||||
|         getChuankouFn() | ||||
|         reslove(`http://${result.centerIp}:${result.centerPort}`) | ||||
|         resolve(`http://${result.centerIp}:${result.centerPort}`) | ||||
| 
 | ||||
|       } | ||||
| 
 | ||||
|     } | ||||
|     return | ||||
|     getSyncData('IpConfigTable').then((result: Array<any>) => { | ||||
|       if (result.length) { | ||||
|         console.log(` getUDP  has IPConfigTable `); | ||||
|         if (globalThis.udpClient && globalThis.udpClient.closeUdp) { | ||||
|           console.log(` getUDP  has udclent close and rebind `); | ||||
|           globalThis.udpClient.closeUdp(() => { | ||||
|             setTimeout(() => { | ||||
|               globalThis.udpClient.rebindUdp(result[0].udplocalIp, result[0].udplocalIpPort, result[0].udpOppositeIp, | ||||
|                 result[0].udpOppositeIpPort) | ||||
|               globalThis.udpClient.sendMsg('111', null) | ||||
|               globalThis.host = `http://${result[0].centerIp}:${result[0].centerPort}` | ||||
|               globalThis.udpClient.onError_Callback(() => { | ||||
|                 console.log('getUDPgetUDPgetUDP') | ||||
|                 getUDP(true, context) | ||||
|                 if (errorFlag && globalThis.udpClient && globalThis.udpClient.onMessage_1) { | ||||
|                   globalThis.udpClient.onMessage_1 = globalThis.udpClient.onMessage_1 | ||||
|                 } | ||||
|               }) | ||||
|               reslove(`http://${result[0].centerIp}:${result[0].centerPort}`) | ||||
| 
 | ||||
|               // globalThis.udpClient.onError_resend(globalThis.udpClient.onMessage_1?globalThis.udpClient.onMessage_1:()=>{})
 | ||||
|             }, 1000) | ||||
|           }) | ||||
| 
 | ||||
|         } else { | ||||
|           // 未绑定
 | ||||
|           console.log(` getUDP  has no  udclent and  bind `); | ||||
|           const udpClient: UdpClientByCenter = | ||||
|             new UdpClientByCenter(result[0].udplocalIp, result[0].udplocalIpPort, result[0].udpOppositeIp, | ||||
|               result[0].udpOppositeIpPort) | ||||
|           udpClient.bindUdp() | ||||
|           udpClient.sendMsg('111') | ||||
|           globalThis.host = `http://${result[0].centerIp}:${result[0].centerPort}` | ||||
|           globalThis.udpClient = udpClient | ||||
| 
 | ||||
|           globalThis.udpClient.onMessage_1(() => { | ||||
|             console.log('getUDPonMessage_1msgmsgByGloalUdp') | ||||
| 
 | ||||
|           }) | ||||
|           globalThis.udpClient.onError_Callback(() => { | ||||
|             getUDP(true, context) | ||||
|             if (errorFlag && globalThis.udpClient && globalThis.udpClient.onMessage_1) { | ||||
|               globalThis.udpClient.onMessage_1 = globalThis.udpClient.onMessage_1 | ||||
|             } | ||||
|           }) | ||||
|           // udpClient.onError_resend(globalThis.udpClient.onMessage_1?globalThis.udpClient.onMessage_1:()=>{})
 | ||||
|           getChuankouFn() | ||||
|           reslove(`http://${result[0].centerIp}:${result[0].centerPort}`) | ||||
| 
 | ||||
| 
 | ||||
|         } | ||||
| 
 | ||||
|       } else { | ||||
|         console.log(` getUDP  has no IPConfigTable `); | ||||
|         // if(globalThis.udpClient)
 | ||||
|         // {
 | ||||
|         //   console.log(` getUDP2  has IPConfigTable ,has udpClient ,close it`);
 | ||||
|         //   globalThis.udpClient.closeUdp(async ()=>{ })
 | ||||
|         // }
 | ||||
|         globalThis.udpClient = {} | ||||
|         // globalThis.udpClient.onMessage_1 = () => {}
 | ||||
|         globalThis.host = '' | ||||
|         reslove('') | ||||
| 
 | ||||
|       } | ||||
|     }) | ||||
|   }) | ||||
| 
 | ||||
| } | ||||
| @ -187,7 +111,7 @@ export async function getUDP2(context, errorFlag?) { | ||||
|               console.info('surenjun', `接收到平台扣分请求,请求指令为:${val.body[1]}`) | ||||
|               globalThis.udpEvent.sendOnKf(val.body[1]) | ||||
|             } | ||||
|             if(val.body[0] == 6){ | ||||
|             if (val.body[0] == 6) { | ||||
|               console.info('surenjun', `接收到平台停考指令,请求指令为:${val.body[1]}`) | ||||
|               globalThis.judgeUdp.askStopExam(val.body[1]) | ||||
|             } | ||||
| @ -199,7 +123,7 @@ export async function getUDP2(context, errorFlag?) { | ||||
|               console.info('surenjun', 'GlobalUdp收到endExam事件') | ||||
|               globalThis.udpEvent.sendEndExam(val.body[1]) | ||||
|             } | ||||
|             if(val.body[0] == 18){ | ||||
|             if (val.body[0] == 18) { | ||||
|               //上传日志和轨迹
 | ||||
|               uploadLogFile() | ||||
|             } | ||||
| @ -221,10 +145,10 @@ export async function getUDP2(context, errorFlag?) { | ||||
|               placeId: globalThis.carInfo.examinationRoomId | ||||
|             } | ||||
|             globalThis.udpClient2.send(param) | ||||
|           }else if(val.id == '39'){ | ||||
|           } else if (val.id == '39') { | ||||
|             //确定远程终止
 | ||||
|             const lsh = val.body.map(byte => String.fromCharCode(byte)).join('') | ||||
|             if( lsh == globalThis.lsh ){ | ||||
|             if (lsh == globalThis.lsh) { | ||||
|               globalThis.udpEvent.sendStopExam() | ||||
|               globalThis.judgeUdp.confirmStopExam(globalThis.signNum) | ||||
|             } | ||||
| @ -236,67 +160,7 @@ export async function getUDP2(context, errorFlag?) { | ||||
|     } | ||||
|   } | ||||
|   return | ||||
|   console.log(` getUDP2  enter`); | ||||
|   getSyncData('IpConfigTable').then(async (result: Array<any>) => { | ||||
|     if (result.length) { | ||||
|       console.log(` getUDP2  has IPConfigTable `); | ||||
|       if (globalThis.udpClient2 && globalThis.udpClient2.closeUdp) { | ||||
|         console.log(` getUDP2  has udclent ,close and rebind `); | ||||
|         globalThis.udpClient2.closeUdp(async () => { | ||||
|           setTimeout(() => { | ||||
|             globalThis.udpClient2.rebindUdp(result[0].udplocalIp, '8800', globalThis.carInfo?.udpAddress, | ||||
|               globalThis.carInfo?.messagePort) | ||||
|             globalThis.udpClient2.onError_Callback(() => { | ||||
|               getUDP2(true); | ||||
|               if (errorFlag && globalThis.udpClient2 && globalThis.udpClient2.onMessage_2) { | ||||
|                 globalThis.udpClient2.onMessage_2 = globalThis.udpClient2.onMessage_2 | ||||
|               } | ||||
|             }) | ||||
|           }, 1000) | ||||
|         }) | ||||
|       } else { | ||||
|         // 未绑定
 | ||||
|         console.log(` getUDP2  has no  udclent and  bind `); | ||||
|         const udpClient2: UdpClientByCenter = | ||||
|           new UdpClientByCenter(result[0].udplocalIp, '8800', globalThis.carInfo?.udpAddress, | ||||
|             globalThis.carInfo?.messagePort) | ||||
|         await udpClient2.bindUdp() | ||||
|         await udpClient2.onError_Callback(() => { | ||||
|           getUDP2(true); | ||||
|           if (errorFlag && globalThis.udpClient2 && globalThis.udpClient2.onMessage_2) { | ||||
|             globalThis.udpClient2.onMessage_2 = globalThis.udpClient2.onMessage_2 | ||||
|           } | ||||
|         }) | ||||
|         if (!errorFlag) { | ||||
|           await udpClient2.onMessage_2((val) => { | ||||
|             if (val.id == '32') { | ||||
|               globalThis.signNum = val.body[1] | ||||
| 
 | ||||
|             } else if (val.id == '46') { | ||||
|               let tmpList = [] | ||||
|               const str = globalThis.lsh | ||||
|               for (let i = 0; i < str.length; i++) { | ||||
|                 tmpList.push(this.string2Bytes(str.charCodeAt(i), 1 * 8)[0]) | ||||
|               } | ||||
|               const param = { | ||||
|                 id: 47, | ||||
|                 list: tmpList, | ||||
|                 carNo: globalThis.carInfo.carNo, | ||||
|                 placeId: globalThis.carInfo.examinationRoomId | ||||
|               } | ||||
|               globalThis.udpClient2.send(param) | ||||
|             } | ||||
|           }) | ||||
|         } | ||||
|         globalThis.udpClient2 = udpClient2 | ||||
| 
 | ||||
|       } | ||||
|     } else { | ||||
|       globalThis.udpClient2 = {} | ||||
|       globalThis.udpClient2.setMsgCallBack = () => { | ||||
|       } | ||||
|     } | ||||
|   }) | ||||
| } | ||||
| 
 | ||||
| export async function setTopLineUdp() { | ||||
| @ -325,7 +189,6 @@ export async function setJudgeUdp() { | ||||
|   const config = JSON.parse(data) | ||||
| 
 | ||||
|   //
 | ||||
|   // const config = await getSyncData('IpConfigTable');
 | ||||
|   let udpIndex = 0; | ||||
|   let currentUdpIndex = 0; | ||||
|   let judgeUdpTimer | ||||
| @ -343,15 +206,12 @@ export async function setJudgeUdp() { | ||||
|     ) | ||||
|     console.info('surenjun hintPort=> ', globalThis.carInfo?.hintPort) | ||||
| 
 | ||||
|     await udpClientbyCenter.onError_Callback(() => { | ||||
|     udpClientbyCenter.onError_Callback(() => { | ||||
|     }) | ||||
|     await udpClientbyCenter.bindUdp() | ||||
|     await udpClientbyCenter.onMessage_2((val) => { | ||||
|     udpClientbyCenter.bindUdp() | ||||
|     udpClientbyCenter.onMessage_2((val) => { | ||||
|     }) | ||||
| 
 | ||||
|     //远程监听开始考试、结束考试、扣分指令
 | ||||
| 
 | ||||
|     // globalThis.judgeUdpClient = udpClientbyCenter;
 | ||||
|     return { | ||||
|       send(bytes) { | ||||
|         if (udpIndex > currentUdpIndex) { | ||||
| @ -388,11 +248,11 @@ export async function setJudgeUdp() { | ||||
|       }, | ||||
| 
 | ||||
|       //申请语音对讲
 | ||||
|       askVoice(){ | ||||
|         console.log('surenjun','发送语音对讲') | ||||
|       askVoice() { | ||||
|         console.log('surenjun', '发送语音对讲') | ||||
|         //udp bug 连发消息
 | ||||
|         let num =0; | ||||
|         let timer = setInterval(()=>{ | ||||
|         let num = 0; | ||||
|         let timer = setInterval(() => { | ||||
|           globalThis.udpClient2.sendMsgExt({ | ||||
|             id: 49, | ||||
|             list: ['1'], | ||||
| @ -400,15 +260,15 @@ export async function setJudgeUdp() { | ||||
|             placeId: globalThis.carInfo.examinationRoomId, | ||||
|           }) | ||||
|           num++; | ||||
|           if(num >=5){ | ||||
|           if (num >= 5) { | ||||
|             clearInterval(timer) | ||||
|           } | ||||
|         },200) | ||||
|         }, 200) | ||||
| 
 | ||||
|       }, | ||||
| 
 | ||||
|       //查询远程终止考试
 | ||||
|       askStopExam(directives){ | ||||
|       askStopExam(directives) { | ||||
|         globalThis.udpClient2.sendMsgExt({ | ||||
|           id: 38, | ||||
|           list: [directives], | ||||
| @ -417,11 +277,11 @@ export async function setJudgeUdp() { | ||||
|         }) | ||||
|       }, | ||||
|       // 确定远程终止考试
 | ||||
|       confirmStopExam(directives){ | ||||
|         console.log('surenjun','确定远程终止考试 directives=》'+directives) | ||||
|       confirmStopExam(directives) { | ||||
|         console.log('surenjun', '确定远程终止考试 directives=》' + directives) | ||||
|         globalThis.udpClient2.sendMsgExt({ | ||||
|           id: 40, | ||||
|           list: [directives,1], | ||||
|           list: [directives, 1], | ||||
|           carNo: globalThis.carInfo.carNo, | ||||
|           placeId: globalThis.carInfo.examinationRoomId | ||||
|         }) | ||||
|  | ||||
| @ -1,6 +1,13 @@ | ||||
| import webSocket from '@ohos.net.webSocket' | ||||
| import promptAction from '@ohos.promptAction' | ||||
| import router from '@ohos.router' | ||||
| import fs from '@ohos.file.fs'; | ||||
| import request from '@ohos.request'; | ||||
| import common from '@ohos.app.ability.common'; | ||||
| import zlib from '@ohos.zlib'; | ||||
| import appRecovery from '@ohos.app.ability.appRecovery'; | ||||
| import power from '@ohos.power'; | ||||
| import preferences from '@ohos.data.preferences'; | ||||
| 
 | ||||
| enum PlatFormEventType { | ||||
|   RestartDevice = "1", | ||||
| @ -39,34 +46,155 @@ const routerMap = { | ||||
|   SignDisplay: 12, | ||||
| } | ||||
| 
 | ||||
| export const gpsConfig = [ | ||||
|   { label: "差分状态", prop: "cfzt" }, | ||||
|   { label: "经纬度收星数", prop: "sxs" }, | ||||
|   { label: "龄期", prop: "lq" }, | ||||
|   { label: "海拔高", prop: "hb" }, | ||||
|   { label: "高度差", prop: "gdc" }, | ||||
|   { label: "纬度", prop: "wd" }, | ||||
|   { label: "经度", prop: "jd" }, | ||||
|   { label: "纬度因子", prop: "wdyz" }, | ||||
|   { label: "经度因子", prop: "jdyz" }, | ||||
|   { label: "速度", prop: "sd" }, | ||||
|   { label: "航向角", prop: "hxj" }, | ||||
|   { label: "航向角状态", prop: "hxjzt" }, | ||||
|   { label: "航向角收星数", prop: "hxjsxs" }, | ||||
|   { label: "俯仰角", prop: "fyj" }, | ||||
|   { label: "年月日", prop: "nyr" }, | ||||
|   { label: "时分秒", prop: "sfm" } | ||||
| ] | ||||
| 
 | ||||
| interface PlatformEvent<T = any> { | ||||
|   serialNumber: string | ||||
|   eventType: PlatFormEventType // 操作类型(1:重启设备 2:重启程序 3:日志列表 4:上传日志 5:考试镜像开始(1:1)6:考试镜像结束(1:1)7:考试镜像命令下发 8:考试镜像数据上报 9:设备注册 10:平台注册11:摆渡机注册 12:终端在线状态上报) | ||||
|   uploadType: string //1:平台下发 2:终端上传 | ||||
|   eventType: PlatFormEventType // 操作类型(1:重启设备 2:重启程序 3:日志列表 4:上传日志 5:考试镜像开始(1:1)6:考试镜像结束(1:1)7:考试镜像命令下发 8:考试镜像数据上报 9:设备注册 10:平台注册11:摆渡机注册 12:终端在线状态上报) | ||||
|   uploadType: string //1:平台下发 2:终端上传 | ||||
|   deviceNo: string | ||||
|   data: T | ||||
| } | ||||
| 
 | ||||
| export interface DataParams { | ||||
|   page: string; | ||||
|   page: number; | ||||
|   data: string; | ||||
| } | ||||
| 
 | ||||
| export interface StudentData { | ||||
|   select: number | ||||
|   students: Array<{ | ||||
|     id: string // 流水号 | ||||
|     name: string // 姓名 | ||||
|     idCard: string // 身份证 | ||||
|     avatar?: string // 头像base64 考虑要不要传 | ||||
|     subject: string // 科目 | ||||
|     examCount: string // 剩余考试次数 | ||||
|     examLine: string // 考试线路 | ||||
|     examiner: string // 考官姓名 | ||||
|     id: string // 流水号 | ||||
|     name: string // 姓名 | ||||
|     idCard: string // 身份证 | ||||
|     avatar?: string // 头像base64 考虑要不要传 | ||||
|     subject: string // 科目 | ||||
|     examCount: string // 剩余考试次数 | ||||
|     examLine: string // 考试线路 | ||||
|     examiner: string // 考官姓名 | ||||
|   }> | ||||
| } | ||||
| 
 | ||||
| interface FileInfo { | ||||
|   fileName: string | ||||
|   lastUpdateTime: string | ||||
|   fileSize: number | ||||
| } | ||||
| 
 | ||||
| const Tag = "[websocket]" | ||||
| const SystemLogDir = "/data/log/hilog" | ||||
| const AppLogDir = '/mnt/hmdfs/100/account/device_view/local/files/duolun/logs' | ||||
| 
 | ||||
| async function sleep(duration: number) { | ||||
|   return new Promise<void>((resolve, _reject) => { | ||||
|     setTimeout(() => { | ||||
|       resolve() | ||||
|     }, duration) | ||||
|   }) | ||||
| } | ||||
| 
 | ||||
| function formatDate(date: Date | string | number, fmt = 'yyyy-MM-dd') { | ||||
|   date = date instanceof Date ? date : new Date(date); | ||||
| 
 | ||||
|   const pad = (n) => (n < 10 ? `0${n}` : `${n}`); | ||||
|   const pad3 = (n) => (n < 10 ? `00${n}` : n < 100 ? `0${n}` : `${n}`); | ||||
| 
 | ||||
|   return fmt | ||||
|     .replace(/yyyy/g, date.getFullYear().toString()) | ||||
|     .replace(/yy/g, `${date.getFullYear()}`.slice(-2)) | ||||
|     .replace(/MM/g, pad(date.getMonth() + 1)) | ||||
|     .replace(/M/g, (date.getMonth() + 1).toString()) | ||||
|     .replace(/dd/g, pad(date.getDate())) | ||||
|     .replace(/d/g, (date.getDate()).toString()) | ||||
|     .replace(/HH/g, pad(date.getHours())) | ||||
|     .replace(/H/g, (date.getHours()).toString()) | ||||
|     .replace(/hh/g, pad(date.getHours() % 12 || 12)) | ||||
|     .replace(/h/g, (date.getHours() % 12 || 12).toString()) | ||||
|     .replace(/mm/g, pad(date.getMinutes())) | ||||
|     .replace(/m/g, date.getMinutes().toString()) | ||||
|     .replace(/ss/g, pad(date.getSeconds())) | ||||
|     .replace(/s/g, date.getSeconds().toString()) | ||||
|     .replace(/SSS/g, pad3(date.getMilliseconds())) | ||||
|     .replace(/S/g, date.getMilliseconds().toString()) | ||||
|     .replace(/a/g, date.getHours() < 12 ? '上午' : '下午') | ||||
|     .replace(/A/g, date.getHours() < 12 ? 'AM' : 'PM') | ||||
|     .replace(/q/g, Math.floor((date.getMonth() + 3) / 3).toString()); | ||||
| } | ||||
| 
 | ||||
| function getSystemLogList(year: string, month: string, date: string) { | ||||
|   let list: FileInfo[] = [] | ||||
|   try { | ||||
|     list = fs.listFileSync(SystemLogDir).filter(name => { | ||||
|       return new RegExp(year + month + date).test(name) | ||||
|     }).map(name => { | ||||
|       let info = fs.statSync(SystemLogDir + '/' + name) | ||||
|       return { | ||||
|         fileName: name, | ||||
|         lastUpdateTime: formatDate(info.mtime, 'yyyy-MM-dd HH:mm:ss'), | ||||
|         fileSize: info.size | ||||
|       } | ||||
|     }) | ||||
| 
 | ||||
|   } catch (e) { | ||||
|     console.log(Tag, JSON.stringify(e)) | ||||
|   } | ||||
|   return list | ||||
| } | ||||
| 
 | ||||
| function getAppLogList(year: string, month: string, date: string) { | ||||
|   let list: FileInfo[] = [] | ||||
|   const path = AppLogDir + `/${year}_${month}_${date}` | ||||
|   if (!fs.accessSync(path)) { | ||||
|     return [] | ||||
|   } | ||||
|   list = fs.listFileSync(path).map(name => { | ||||
|     let info = fs.statSync(path + '/' + name) | ||||
|     return { | ||||
|       fileName: name, | ||||
|       lastUpdateTime: formatDate(info.mtime, 'yyyy-MM-dd HH:mm:ss'), | ||||
|       fileSize: info.size | ||||
|     } | ||||
|   }) | ||||
|   return list | ||||
| } | ||||
| 
 | ||||
| function uploadFile(context: common.UIAbilityContext, serialNumber: string, filename: string, ext: string) { | ||||
|   return new Promise<void>((resolve, reject) => { | ||||
|     return request.uploadFile(context, { | ||||
|       url: `http://88.22.20.30:8080/ws-signaling-0.0.1/api/file/upload?serialNumber=${serialNumber}`, | ||||
|       header: { 'Accept': '*/*', 'Content-Type': 'multipart/form-data' }, | ||||
|       method: 'post', | ||||
|       files: [{ filename, name: 'file', uri: `internal://cache/${filename}`, type: ext }], | ||||
|       data: [{ name: "serialNumber", value: serialNumber }] | ||||
|     }).then(task => { | ||||
|       task.on("fail", (err) => { | ||||
|         reject(err) | ||||
|       }) | ||||
|       task.on("complete", () => { | ||||
|         resolve() | ||||
|       }) | ||||
|     }).catch(reject).finally(() => { | ||||
|       fs.unlinkSync(`internal://cache/${filename}`) | ||||
|     }) | ||||
|   }) | ||||
| } | ||||
| 
 | ||||
| export class RemoteToolWebsocket { | ||||
|   private instance: webSocket.WebSocket | ||||
| @ -74,9 +202,14 @@ export class RemoteToolWebsocket { | ||||
|   private serialNumber: string = "" | ||||
|   private reconnectCount: number = 0 | ||||
|   private url: string = '' | ||||
|   private onStartCallback: Array<() => void> = [] | ||||
|   private onStartCallback: Array<{ | ||||
|     page: number, | ||||
|     cb: () => void | ||||
|   }> = [] | ||||
|   public isStart: boolean = false | ||||
|   private isRegister: boolean = false | ||||
|   private context: common.UIAbilityContext | ||||
|   private store: preferences.Preferences | null = null | ||||
| 
 | ||||
|   constructor() { | ||||
|     if (!RemoteToolWebsocket.instance) { | ||||
| @ -85,36 +218,153 @@ export class RemoteToolWebsocket { | ||||
|     return RemoteToolWebsocket.instance | ||||
|   } | ||||
| 
 | ||||
|   private sendReply(serialNumber: string, eventType: string) { | ||||
|   private handleSignal(msg: string) { | ||||
|     let data = msg.split(",") | ||||
|     let plc = [ | ||||
|       data[2], //左方向灯 | ||||
|       data[3], //右方向灯 | ||||
|       data[7], //近光灯 | ||||
|       data[8], //远光灯 | ||||
|       data[9], //示廓灯 | ||||
|       data[20], //双跳灯 | ||||
|       data[10], //雾灯 | ||||
|       data[4], //喇叭 | ||||
|       data[5], //点火1 | ||||
|       data[6], //点火2 | ||||
|       data[11], //雨刮器 | ||||
|       data[4], //脚刹 | ||||
|       data[13], //手刹 | ||||
|       data[17], //离合 | ||||
|       data[18], //副刹车 | ||||
|       data[19], //安全带 | ||||
|       data[14], //主驾驶门 | ||||
|       data[21], //其他门 | ||||
|       data[23], //车速 | ||||
|       data[25], //发动机转速 | ||||
|       data[22], //转速过高 | ||||
|       data[28], //档位 | ||||
|       data[27]?.split("_")[0], //方向盘角度 | ||||
|       data[24], //累计脉冲 | ||||
|       data[26], //熄火次数 | ||||
|       data[29], //超声波1 | ||||
|       data[30], //超声波2 | ||||
|       data[31], //超声波3 | ||||
|       data[32], //超声波4 | ||||
|       data[33], //触摸1 | ||||
|       data[34], //触摸2 | ||||
|       data[35], //触摸3 | ||||
|       '0,1,2', //车辆状态 | ||||
|       data[15], //NC | ||||
|       data[16], //SA15 | ||||
|       data[36], //SCIO | ||||
|       data[37], //SC1A_C | ||||
|       data[38], //SC1B_C | ||||
|       data[39], //SC2A_C | ||||
|       data[40], //SC2B_C | ||||
|       data[41], //SC3A_C | ||||
|       data[42], //SC3B_C | ||||
|       data[43], //SC4A_C | ||||
|       data[44], //SC4B_C | ||||
|       data[45], //SC5A_C | ||||
|       data[46], //SC5B_C | ||||
|       data[47], //SC6A_C | ||||
|       data[48],//SC6B_C | ||||
|     ] | ||||
|     const hours = Number(data[94]?.substring(0, 2)) + 8 | ||||
|     let time = (hours > 9 ? hours : '0' + hours) + data[94]?.substring(2, data[94]?.length - 2) | ||||
|     let gps = [ | ||||
|       data[83], // 差分状态 | ||||
|       data[84], // 经纬度收星数 | ||||
|       data[87], // 龄期 | ||||
|       data[85], // 海拔高 | ||||
|       data[86], // 高度差 | ||||
|       data[96], // 纬度 | ||||
|       data[95], // 经度 | ||||
|       data[88], // 纬度因子 | ||||
|       data[89], // 经度因子 | ||||
|       data[97], // 速度 | ||||
|       data[90], // 航向角 | ||||
|       data[92]?.split('-')[0], // 航向角状态 | ||||
|       data[92]?.split('-')[1], // 航向角收星数 | ||||
|       data[91], // 俯仰角 | ||||
|       data[93], // 年月日 | ||||
|       time,// 时分秒 | ||||
|     ] | ||||
|     return [...plc, ...gps].join(",") | ||||
|   } | ||||
| 
 | ||||
|   private sendReply(serialNumber: string, eventType: string, data?: string) { | ||||
|     this.send(JSON.stringify({ | ||||
|       serialNumber, | ||||
|       eventType, | ||||
|       uploadType: "2", | ||||
|       deviceNo: globalThis.deviceNo | ||||
|       deviceNo: globalThis.deviceNo, | ||||
|       data | ||||
|     })) | ||||
|   } | ||||
| 
 | ||||
|   private onMessage() { | ||||
|     this.instance.on("message", (err, event: string) => { | ||||
|     this.instance.on("message", async (err, event: string) => { | ||||
|       const data = JSON.parse(event) as PlatformEvent; | ||||
|       console.log("websocket", event) | ||||
|       console.log(Tag, 'receive', event) | ||||
|       switch (data.eventType) { | ||||
|         case PlatFormEventType.RestartDevice: | ||||
|           try { | ||||
|             power.reboot("remote tools command") | ||||
|             this.sendReply(data.serialNumber, data.eventType, JSON.stringify({ | ||||
|               code: "200", | ||||
|               msg: "重启成功" | ||||
|             })) | ||||
|           } catch (e) { | ||||
|             this.sendReply(data.serialNumber, data.eventType, JSON.stringify({ | ||||
|               code: "500", | ||||
|               msg: e | ||||
|             })) | ||||
|           } | ||||
|           break | ||||
|         case PlatFormEventType.RestartApp: | ||||
|           let lastTime: number = await this.store.get('lastRestartTime', 0) as number | ||||
|           let now = new Date().getTime() | ||||
|           if (now - lastTime < 60 * 1000) { | ||||
|             this.sendReply(data.serialNumber, data.eventType, JSON.stringify({ | ||||
|               code: "500", | ||||
|               msg: "1分钟内只能重启一次!" | ||||
|             })) | ||||
|           } else { | ||||
|             await this.store.put('lastRestartTime', new Date().getTime()) | ||||
|             await this.store.put('serialNumber', data.serialNumber) | ||||
|             await this.store.flush() | ||||
|             appRecovery.restartApp() | ||||
|             setTimeout(async () => { | ||||
|               this.sendReply(data.serialNumber, PlatFormEventType.RestartApp, JSON.stringify({ | ||||
|                 code: "500", | ||||
|                 msg: "重启失败" | ||||
|               })) | ||||
|               await this.store.put('serialNumber', "") | ||||
|               await this.store.flush() | ||||
|             }, 2000) | ||||
|           } | ||||
|           break | ||||
|         case PlatFormEventType.UploadLogList: | ||||
|           this.onUploadLogList(data.serialNumber) | ||||
|           let date = JSON.parse(data.data).logDate | ||||
|           this.onUploadLogList(data.serialNumber, date) | ||||
|           break | ||||
|         case PlatFormEventType.UploadLog: | ||||
|           this.onUploadLogFile(data.serialNumber) | ||||
|           let fileName = JSON.parse(data.data).fileName | ||||
|           this.onUploadLogFile(data.serialNumber, fileName) | ||||
|           break | ||||
|         case PlatFormEventType.StartSync: | ||||
|           this.isStart = true | ||||
|           this.serialNumber = data.serialNumber | ||||
|           this.sendReply(this.serialNumber, data.eventType) | ||||
|           await sleep(1000) | ||||
|           this.sendRouter("", routerMap[router.getState().name]) | ||||
|           this.onStartCallback.forEach(cb => cb()) | ||||
|           await sleep(1000) | ||||
|           this.onStartCallback.forEach(item => { | ||||
|             if (item.page === routerMap[router.getState().name]) { | ||||
|               item.cb() | ||||
|             } | ||||
|           }) | ||||
|           break | ||||
|         case PlatFormEventType.StopSync: | ||||
|           this.isStart = false | ||||
| @ -127,32 +377,139 @@ export class RemoteToolWebsocket { | ||||
|           console.warn("Unknown event type:", data.eventType); | ||||
|       } | ||||
|     }) | ||||
|     this.instance.on("close", async () => { | ||||
|       this.isStart = false | ||||
|       console.log(Tag, "close") | ||||
|       await this.init(this.url, this.context) | ||||
|       await this.register() | ||||
|       this.isStart = true | ||||
|     }) | ||||
|   } | ||||
| 
 | ||||
|   private send(data: string) { | ||||
|     return this.instance.send(data) | ||||
|       .then(() => { | ||||
|         console.log(Tag, 'send success') | ||||
|         console.log(Tag, 'send success, data:', data) | ||||
|       }) | ||||
|       .catch((err) => { | ||||
|         console.log(Tag, 'send error: ', JSON.stringify(err)) | ||||
|       }) | ||||
|   } | ||||
| 
 | ||||
|   private onUploadLogList(serialNumber: string) { | ||||
| 
 | ||||
|   private onUploadLogList(serialNumber: string, time: string) { | ||||
|     console.log(Tag, serialNumber, time) | ||||
|     let year = time.split("-")[0] | ||||
|     let month = time.split("-")[1] | ||||
|     let date = time.split("-")[2] | ||||
|     let systemList = getSystemLogList(year, month, date) | ||||
|     let appList = getAppLogList(year, month, date) | ||||
|     let list = [...systemList, ...appList] | ||||
|     list.forEach(item => { | ||||
|       console.log(Tag, JSON.stringify(item)) | ||||
|     }) | ||||
|     this.send(JSON.stringify({ | ||||
|       serialNumber: serialNumber, | ||||
|       eventType: PlatFormEventType.UploadLogList, | ||||
|       uploadType: "2", | ||||
|       deviceNo: globalThis.deviceNo, | ||||
|       data: JSON.stringify({ | ||||
|         code: "200", | ||||
|         logList: list, | ||||
|       }) | ||||
|     })) | ||||
|   } | ||||
| 
 | ||||
|   private onUploadLogFile(serialNumber: string) { | ||||
| 
 | ||||
|   private onUploadLogFile(serialNumber: string, file: string) { | ||||
|     const reply = (error?: object | string) => { | ||||
|       this.send(JSON.stringify({ | ||||
|         serialNumber: serialNumber, | ||||
|         eventType: PlatFormEventType.UploadLog, | ||||
|         uploadType: "2", | ||||
|         deviceNo: globalThis.deviceNo, | ||||
|         data: JSON.stringify({ | ||||
|           code: error ? "500" : '200', | ||||
|           msg: error || undefined | ||||
|         }) | ||||
|       })) | ||||
|     } | ||||
|     try { | ||||
|       if (/hilog/.test(file)) { | ||||
|         fs.copyFileSync('/data/log/hilog/' + file, this.context.cacheDir + '/' + file) | ||||
|         zlib.compressFile(this.context.cacheDir + '/' + file, this.context.cacheDir + '/' + file + '.zip', { | ||||
|           level: zlib.CompressLevel.COMPRESS_LEVEL_DEFAULT_COMPRESSION, | ||||
|           memLevel: zlib.MemLevel.MEM_LEVEL_DEFAULT, | ||||
|           strategy: zlib.CompressStrategy.COMPRESS_STRATEGY_DEFAULT_STRATEGY | ||||
|         }) | ||||
|           .then(() => { | ||||
|             return uploadFile(this.context, serialNumber, file + '.zip', 'zip') | ||||
|           }) | ||||
|           .then(() => { | ||||
|             reply() | ||||
|           }) | ||||
|           .catch((err) => { | ||||
|             reply(err) | ||||
|           }) | ||||
|           .finally(() => { | ||||
|             fs.unlinkSync(this.context.cacheDir + '/' + file) | ||||
|             fs.unlinkSync(this.context.cacheDir + '/' + file + '.zip') | ||||
|           }) | ||||
|       } else { | ||||
|         let tempDir = this.context.cacheDir + '/' + file | ||||
|         fs.mkdirSync(tempDir) | ||||
|         let date: string = file.substring(0, 10) | ||||
|         let path = AppLogDir + "/" + date + '/' + file | ||||
|         let list = fs.listFileSync(path) | ||||
|         list.forEach(name => { | ||||
|           fs.copyFileSync(path + '/' + name, tempDir + '/' + name) | ||||
|         }) | ||||
|         zlib.compressFile(tempDir, tempDir + '.zip', { | ||||
|           level: zlib.CompressLevel.COMPRESS_LEVEL_DEFAULT_COMPRESSION, | ||||
|           memLevel: zlib.MemLevel.MEM_LEVEL_DEFAULT, | ||||
|           strategy: zlib.CompressStrategy.COMPRESS_STRATEGY_DEFAULT_STRATEGY | ||||
|         }) | ||||
|           .then(() => { | ||||
|             return uploadFile(this.context, serialNumber, file + '.zip', 'zip') | ||||
|           }) | ||||
|           .then(() => { | ||||
|             reply() | ||||
|           }) | ||||
|           .catch((err) => { | ||||
|             reply(err) | ||||
|           }) | ||||
|           .finally(() => { | ||||
|             fs.rmdirSync(this.context.cacheDir + '/' + file) | ||||
|             fs.unlinkSync(this.context.cacheDir + '/' + file + '.zip') | ||||
|           }) | ||||
|       } | ||||
|     } catch (err) { | ||||
|       this.send(JSON.stringify({ | ||||
|         serialNumber: serialNumber, | ||||
|         eventType: PlatFormEventType.UploadLogList, | ||||
|         uploadType: "2", | ||||
|         deviceNo: globalThis.deviceNo, | ||||
|         data: JSON.stringify({ | ||||
|           code: "500", | ||||
|           msg: err | ||||
|         }) | ||||
|       })) | ||||
|       console.log(Tag, JSON.stringify(err)) | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   init(url: string) { | ||||
|   async init(url: string, context: common.UIAbilityContext) { | ||||
|     if (!this.store) { | ||||
|       try { | ||||
|         this.store = await preferences.getPreferences(context, "websocket") | ||||
|       } catch (e) { | ||||
|         console.log(Tag, JSON.stringify(e)) | ||||
|       } | ||||
|     } | ||||
|     this.context = context | ||||
|     this.url = url | ||||
|     this.instance = webSocket.createWebSocket() | ||||
|     this.onMessage() | ||||
|     return this.instance.connect(url).then(() => { | ||||
|       console.log(Tag, 'connect success') | ||||
|       console.log(Tag, 'connect success', 'address', this.url) | ||||
|       this.reconnectCount = 0 | ||||
|     }).catch((err) => { | ||||
|       console.log(Tag, 'connect error: ', JSON.stringify(err)) | ||||
| @ -162,15 +519,56 @@ export class RemoteToolWebsocket { | ||||
|           message: "websocket connect failed" | ||||
|         }) | ||||
|       } else { | ||||
|         this.init(url) | ||||
|         this.init(url, context) | ||||
|       } | ||||
|     }) | ||||
|   } | ||||
| 
 | ||||
|   register() { | ||||
|   async register() { | ||||
|     if (this.isRegister) { | ||||
|       return | ||||
|     } | ||||
| 
 | ||||
|     this.sendData({ | ||||
|       page: 20, | ||||
|       data: JSON.stringify({ | ||||
|         time: new Date().getTime().toString(), | ||||
|         signal: this.handleSignal(""), | ||||
|         error: '', | ||||
|         vehicle: globalThis.carInfo.kscx, | ||||
|         carId: globalThis.carInfo.plateNo | ||||
|       }) | ||||
|     }) | ||||
| 
 | ||||
|     setInterval(() => { | ||||
|       if (this.isStart && [11, 12].includes(routerMap[router.getState().name])) { | ||||
|         this.sendData({ | ||||
|           page: 20, | ||||
|           data: JSON.stringify({ | ||||
|             time: new Date().getTime().toString(), | ||||
|             signal: this.handleSignal(""), | ||||
|             error: '', | ||||
|             vehicle: globalThis.carInfo.kscx, | ||||
|             carId: globalThis.carInfo.plateNo | ||||
|           }) | ||||
|         }) | ||||
|       } | ||||
|     }, 2000) | ||||
| 
 | ||||
|     globalThis.udpClient.onMessage_1(async (msg: string) => { | ||||
|       if (this.isStart) { | ||||
|         this.sendData({ | ||||
|           page: 20, | ||||
|           data: JSON.stringify({ | ||||
|             time: new Date().getTime().toString(), | ||||
|             signal: this.handleSignal(msg), | ||||
|             error: '', | ||||
|             vehicle: globalThis.carInfo.kscx, | ||||
|             carId: globalThis.carInfo.plateNo | ||||
|           }) | ||||
|         }) | ||||
|       } | ||||
|     }); | ||||
|     return this.send(JSON.stringify({ | ||||
|       serialNumber: this.serialNumber, | ||||
|       eventType: PlatFormEventType.DeviceRegister, | ||||
| @ -182,10 +580,25 @@ export class RemoteToolWebsocket { | ||||
|         plateNo: globalThis.carInfo.plateNo, | ||||
|         vehicleKind: globalThis.carInfo.kscx | ||||
|       }) | ||||
|     })) | ||||
|     })).then(async () => { | ||||
| 
 | ||||
|       let lastSerialNumber = await this.store.get('serialNumber', "") as string | ||||
|       if (lastSerialNumber) { | ||||
|         this.sendReply(lastSerialNumber, PlatFormEventType.RestartApp, JSON.stringify({ | ||||
|           code: "200", | ||||
|           msg: "重启成功" | ||||
|         })) | ||||
|         await this.store.put('serialNumber', "") | ||||
|         await this.store.flush() | ||||
|       } | ||||
|       this.isRegister = true | ||||
|     }) | ||||
|   } | ||||
| 
 | ||||
|   sendData<T = object>(data: T) { | ||||
|     if (!this.isStart) { | ||||
|       return Promise.resolve() | ||||
|     } | ||||
|     return this.send(JSON.stringify({ | ||||
|       serialNumber: this.serialNumber, | ||||
|       eventType: PlatFormEventType.SyncData, | ||||
| @ -199,6 +612,9 @@ export class RemoteToolWebsocket { | ||||
|   } | ||||
| 
 | ||||
|   sendRouter(from: string, to: string) { | ||||
|     if (!this.isStart) { | ||||
|       return Promise.resolve() | ||||
|     } | ||||
|     return this.send(JSON.stringify({ | ||||
|       serialNumber: this.serialNumber, | ||||
|       eventType: PlatFormEventType.SyncData, | ||||
| @ -214,11 +630,14 @@ export class RemoteToolWebsocket { | ||||
|     })) | ||||
|   } | ||||
| 
 | ||||
|   onStart(cb: () => void) { | ||||
|     this.onStartCallback.push(cb) | ||||
|   onStart(cb: () => void, page: number) { | ||||
|     this.onStartCallback.push({ | ||||
|       page, | ||||
|       cb | ||||
|     }) | ||||
|   } | ||||
| 
 | ||||
|   offStart(cb: () => void) { | ||||
|     this.onStartCallback = this.onStartCallback.filter(item => item != cb) | ||||
|   offStart(page: number) { | ||||
|     this.onStartCallback = this.onStartCallback.filter(item => item.page != page) | ||||
|   } | ||||
| } | ||||
| @ -1,19 +1,21 @@ | ||||
| import UIAbility from '@ohos.app.ability.UIAbility'; | ||||
| import hilog from '@ohos.hilog'; | ||||
| import window from '@ohos.window'; | ||||
| import relationalStore from '@ohos.data.relationalStore' | ||||
| import abilityAccessCtrl, { Permissions } from '@ohos.abilityAccessCtrl'; | ||||
| // import featureAbility from '@ohos.ability.featureAbility' | ||||
| import { makedir } from '../common/service/fileService' | ||||
| import { Array2Byte } from '../common/utils/tools' | ||||
| import { GlobalConfig } from '../config/global' | ||||
| import { tcpUtil } from '../common/utils/TcpRequest'; | ||||
| import DB from '../common/database/DbSql'; | ||||
| import { initTable } from '../common/service/initable'; | ||||
| import { RemoteToolWebsocket } from '../common/utils/RemotetoolWebsocket'; | ||||
| import appRecovery from '@ohos.app.ability.appRecovery'; | ||||
| 
 | ||||
| export default class EntryAbility extends UIAbility { | ||||
|   async onCreate(want, launchParam) { | ||||
|     appRecovery.enableAppRecovery( | ||||
|       appRecovery.RestartFlag.ALWAYS_RESTART, | ||||
|       appRecovery.SaveOccasionFlag.SAVE_WHEN_ERROR, | ||||
|       appRecovery.SaveModeFlag.SAVE_WITH_FILE | ||||
|     ); | ||||
|     try { | ||||
|       console.log("sql first") | ||||
|       await DB.init(this.context) | ||||
| @ -35,17 +37,13 @@ export default class EntryAbility extends UIAbility { | ||||
|   } | ||||
| 
 | ||||
|   async onWindowStageCreate(windowStage: window.WindowStage) { | ||||
|     // this.context | ||||
|     // Main window is created, set main page for this ability | ||||
|     hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageCreate'); | ||||
|     new RemoteToolWebsocket().init("ws://88.22.20.30:1989/sig/v1") | ||||
| 
 | ||||
|     globalThis.carInfo = {} | ||||
|     globalThis.examinerInfo = {} | ||||
|     globalThis.deviceNo = ''; | ||||
|     globalThis.hasAuth = false | ||||
| 
 | ||||
|     // globalThis.judgeVersion ='2024.08.24.1' | ||||
|     // globalThis.version ='2023.12.13.01'; | ||||
|     globalThis.version = GlobalConfig.version.wx.km2[0]; | ||||
|     globalThis.judgeVersion = GlobalConfig.version.wx.km2[1]; | ||||
|     globalThis.tcpSendNum = 0 | ||||
| @ -76,28 +74,26 @@ export default class EntryAbility extends UIAbility { | ||||
|         hilog.error(0x0000, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err) ?? ''); | ||||
|         return; | ||||
|       } | ||||
|       new RemoteToolWebsocket().init("ws://88.22.20.30:1989/sig/v1", this.context) | ||||
|       hilog.info(0x0000, 'testTag', 'Succeeded in loading the content. Data: %{public}s', JSON.stringify(data) ?? ''); | ||||
|     }); | ||||
| 
 | ||||
|     this.creatFiles(); | ||||
|     this.createFiles(); | ||||
|   } | ||||
| 
 | ||||
|   onWindowStageDestroy() { | ||||
|     // Main window is destroyed, release UI related resources | ||||
|     hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageDestroy'); | ||||
|   } | ||||
| 
 | ||||
|   onForeground() { | ||||
|     // Ability has brought to foreground | ||||
|     hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onForeground'); | ||||
|   } | ||||
| 
 | ||||
|   onBackground() { | ||||
|     // Ability has back to background | ||||
|     hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onBackground'); | ||||
|   } | ||||
| 
 | ||||
|   creatFiles() { | ||||
|   createFiles() { | ||||
|     makedir('/testFile'); | ||||
|   } | ||||
| } | ||||
| @ -5,7 +5,6 @@ import { setCurrentTime } from '../common/service/timeService'; | ||||
| import { getCurrentTime, string2Bytes } from '../common/utils/tools'; | ||||
| import { FileHelper } from '../common/service/FileHelper'; | ||||
| import { getEsCarModel, getSyncData, } from '../common/service/initable'; | ||||
| import FileUtil from '../common/utils/File'; | ||||
| import { getUDP, getUDP2 } from '../common/utils/GlobalUdp'; | ||||
| import { initJudgeUdp } from '../common/utils/UdpJudge'; | ||||
| import { judgeConfig } from './judgeSDK/utils/judgeConfig'; | ||||
| @ -20,11 +19,8 @@ import { delPic } from '../common/service/videoService'; | ||||
| import imageBtn from './compontents/imageBtn'; | ||||
| import VoiceAnnounce from './judgeSDK/utils/voiceAnnouncements'; | ||||
| import { updateModelAndCar } from '../common/autoUpdate/index' | ||||
| // import  {uploadLogFile} from '../common/service/indexService' | ||||
| import { getModalValueCdAndCar } from '../api'; | ||||
| import { RemoteToolWebsocket } from '../common/utils/RemotetoolWebsocket'; | ||||
| 
 | ||||
| // import VoiceAnnounce from './judgeSDK/utils/voiceAnnouncements'; | ||||
| 
 | ||||
| @Entry | ||||
| @Component | ||||
| @ -61,12 +57,10 @@ struct Index { | ||||
|     alignment: DialogAlignment.Center, | ||||
|   }, | ||||
|   ) | ||||
|   private fileUtil: FileUtil | ||||
|   private interval = null; | ||||
|   // private vocObj = null; | ||||
|   private avPlayer | ||||
|   private workerInstance = null; | ||||
|   private context = getContext(this) as common.UIAbilityContext; | ||||
|   private remoteToolWebsocket: RemoteToolWebsocket = new RemoteToolWebsocket() | ||||
| 
 | ||||
|   @Styles | ||||
|   commStyle(){ | ||||
| @ -74,7 +68,6 @@ struct Index { | ||||
|     .height(69 * this.ratio * this.dialogRatio) | ||||
|     .backgroundImage($r('app.media.button_nor')) | ||||
|     .backgroundImageSize({ width: '100%', height: '100%' }) | ||||
|     // .margin({ bottom: 12 * this.ratio }) | ||||
|   } | ||||
| 
 | ||||
|   build() { | ||||
| @ -110,14 +103,9 @@ struct Index { | ||||
|             imageBtn({ btnWidth: '28%', btnHeight: '71%', imgSrc: $r('app.media.index_lw') }) | ||||
|               .margin({ left: 80 * globalThis.ratio }) | ||||
|               .onClick(async () => { | ||||
|                 // this.vocObj.playAudio({ | ||||
|                 //   type: 1, | ||||
|                 //   name: 'button_media.wav' | ||||
|                 // }) | ||||
|                 // ||!this.initParamFlag | ||||
| 
 | ||||
|                 if (this.loading) { | ||||
|                   // globalThis.title = '正在初始化,请等待5s后重试' | ||||
|                   // this.errorDialog.open() | ||||
| 
 | ||||
|                   return | ||||
|                 } | ||||
|                 setTimeout(() => { | ||||
| @ -157,10 +145,7 @@ struct Index { | ||||
|                 if (this.loading) { | ||||
|                   return | ||||
|                 } | ||||
|                 // this.vocObj.playAudio({ | ||||
|                 //   type: 1, | ||||
|                 //   name: 'button_media.wav' | ||||
|                 // }) | ||||
| 
 | ||||
|                 if (judgeConfig.isTrajectoryOpen) { | ||||
|                   router.pushUrl({ | ||||
|                     url: 'pages/UserInfo', | ||||
| @ -171,6 +156,7 @@ struct Index { | ||||
|                 getSyncData('MA_SYSSET').then(data => { | ||||
|                   console.log('datadata', JSON.stringify(data)) | ||||
|                   if (data?.[0]) { | ||||
|                     this.remoteToolWebsocket.sendRouter("1", "9") | ||||
|                     router.pushUrl({ | ||||
|                       url: 'pages/UserInfo', | ||||
|                     }, router.RouterMode.Single) | ||||
| @ -186,10 +172,7 @@ struct Index { | ||||
|               if (this.loading) { | ||||
|                 return | ||||
|               } | ||||
|               // this.vocObj.playAudio({ | ||||
|               //   type: 1, | ||||
|               //   name: 'button_media.wav' | ||||
|               // }) | ||||
| 
 | ||||
|               router.pushUrl({ | ||||
|                 url: 'pages/CarCheck' | ||||
|               }, router.RouterMode.Single); | ||||
| @ -212,11 +195,7 @@ struct Index { | ||||
|               .fontSize(18 * globalThis.ratio) | ||||
|               .width('30%') | ||||
|               .margin({ bottom: 10 }) | ||||
|             // Text('V 1.0') | ||||
|             //   .fontColor('#CCAE7A') | ||||
|             //   .fontSize(22 * globalThis.ratio) | ||||
|             //   .width('30%') | ||||
|             //   .margin({ bottom: 10 }) | ||||
| 
 | ||||
|             Text('授权信息:' + (this.hasAuth ? '已授权' : '未授权')) | ||||
|               .fontColor('#CCAE7A') | ||||
|               .fontSize(18 * globalThis.ratio) | ||||
| @ -261,10 +240,7 @@ struct Index { | ||||
|             .commStyle() | ||||
|             .onClick(() => { | ||||
|               this.dialogVisiable = false | ||||
|               // this.vocObj.playAudio({ | ||||
|               //   type: 1, | ||||
|               //   name: 'button_media.wav' | ||||
|               // }) | ||||
| 
 | ||||
|             }).margin({ right: 10 * this.ratio }) | ||||
| 
 | ||||
|             Flex({ justifyContent: FlexAlign.Center, alignItems: ItemAlign.Center }) { | ||||
| @ -275,11 +251,7 @@ struct Index { | ||||
|             } | ||||
|             .commStyle() | ||||
|             .onClick(() => { | ||||
|               // this.vocObj.playAudio({ | ||||
|               //   type: 1, | ||||
|               //   name: 'button_media.wav' | ||||
|               // }) | ||||
|               router.back() | ||||
|               this.context.terminateSelf() | ||||
|             }) | ||||
|           }.position({ y: 265 * this.ratio * this.dialogRatio, x: 115 * this.ratio * this.dialogRatio }) | ||||
| 
 | ||||
| @ -380,11 +352,9 @@ struct Index { | ||||
|         //判断是否能点开始考试 | ||||
|         if (sys.v_no === '305') { | ||||
|           console.log('syssyssyssys') | ||||
|           // this.delLoading=true | ||||
|           // globalThis.param854Str=sys.v_value | ||||
| 
 | ||||
|           delPic(Number(sys.v_value), 1) | ||||
|           delPic(Number(sys.v_value), 2) | ||||
|           // this.delLoading=false | ||||
| 
 | ||||
|         } | ||||
|       }) | ||||
| @ -400,9 +370,7 @@ struct Index { | ||||
|     if (this.loading) { | ||||
|       return | ||||
|     } | ||||
|     // let mode=globalThis.timeInfo?.mode?globalThis.timeInfo?.mode:1 | ||||
| 
 | ||||
|     // console.log('mode',mode) | ||||
| 
 | ||||
|     const param = { | ||||
|       carId: globalThis.carInfo?.carId, | ||||
| @ -438,23 +406,10 @@ struct Index { | ||||
|         this.loadingText = '正在安装考车最新版本,请稍候……' | ||||
|         return false | ||||
|       } | ||||
|       // DB.queryListBySql('select * from MA_SYSSET', [{ | ||||
|       //   name: "v_no", | ||||
|       //   type: ColumnType.STRING, | ||||
|       //   columnName: "v_no" | ||||
|       // }]).then((res) => { | ||||
|       //   console.log('sql success', JSON.stringify(res)) | ||||
|       // }).catch((err) => { | ||||
|       //   console.log('sql error1', err) | ||||
|       // }) | ||||
| 
 | ||||
|       if (ret) { | ||||
|         if (globalThis.singlePlay) { | ||||
|           router.pushUrl({ | ||||
|             url: 'pages/userInfo' | ||||
|           }, router.RouterMode.Single) | ||||
|           return | ||||
|         } | ||||
|         if (globalThis.singlePlay) { | ||||
|           this.remoteToolWebsocket.sendRouter("1", "9") | ||||
|           router.pushUrl({ | ||||
|             url: 'pages/UserInfo', | ||||
|           }, router.RouterMode.Single) | ||||
| @ -486,47 +441,6 @@ struct Index { | ||||
| 
 | ||||
|       } | ||||
|     }) | ||||
|     // workerInstance.postMessage(param); | ||||
|     // workerInstance.onmessage = (e: MessageEvents): void => { | ||||
|     //   console.log("baoyihu after postMessage :", JSON.stringify(e.data)); | ||||
|     //   // @ts-ignore | ||||
|     //   let workData: WorkData = e.data; | ||||
|     //   this.loading = false | ||||
|     //   if (workData.isComplete) { | ||||
|     //     if(globalThis.singlePlay){ | ||||
|     //       router.pushUrl({ | ||||
|     //         url: 'pages/UserInfo', | ||||
|     //       }, router.RouterMode.Single) | ||||
|     //       return | ||||
|     //     } | ||||
|     //     getSyncData('MA_SYSSET').then(data => { | ||||
|     //       console.log('datadata', JSON.stringify(data)) | ||||
|     //       // @ts-ignore | ||||
|     //       data.forEach(sys => { | ||||
|     //         //判断是否能点开始考试 | ||||
|     //         if(sys.v_no === '854'){ | ||||
|     //           globalThis.param854Str=sys.v_value | ||||
|     //         } | ||||
|     //         if (sys.v_no === '824'&&decodeURIComponent(sys.v_value)=='0') { | ||||
|     //           // this.Param612Str= decodeURIComponent(sys.v_value) | ||||
|     //           router.pushUrl({ | ||||
|     //             url:'pages/CarCheck', | ||||
|     //             params: { | ||||
|     //               'fromIndex':true | ||||
|     //             } | ||||
|     //           }, router.RouterMode.Single) | ||||
|     //         }else{ | ||||
|     //           router.pushUrl({ | ||||
|     //             url: 'pages/ExaminerLogin', | ||||
|     //           }, router.RouterMode.Single) | ||||
|     //         } | ||||
|     //       }) | ||||
|     //     }); | ||||
|     // | ||||
|     //   } | ||||
|     //   workerInstance.terminate(); | ||||
|     // | ||||
|     // } | ||||
|   } | ||||
| 
 | ||||
|   async heartMsg() { | ||||
| @ -556,17 +470,10 @@ struct Index { | ||||
|     await this.userAuth(); | ||||
|     console.log('globalThis.singlePlay', globalThis.singlePlay) | ||||
|     if (globalThis.singlePlay == undefined || globalThis.singlePlay == null) { | ||||
|       // setVideoParam() | ||||
|       console.log('diyidiy') | ||||
|       this.context.resourceManager.getRawFileContent("welcome.wav") | ||||
|         .then(value => { | ||||
|           this.avPlayer.playAudio(['welcome.wav']) | ||||
| 
 | ||||
|           // this.vocObj.playAudio({ | ||||
|           //   type: 1, | ||||
|           //   name: 'welcome.wav' | ||||
|           // }) | ||||
|           // let rawFile = value; | ||||
|         }) | ||||
|         .catch(error => { | ||||
|           console.log("getRawFileContent promise error is " + error); | ||||
| @ -575,9 +482,7 @@ struct Index { | ||||
|       globalThis.singlePlay = false | ||||
|     } | ||||
|     this.isSingle = globalThis.singlePlay | ||||
|     // this.loading = false | ||||
|     this.num = 0 | ||||
|     // const TcpClient: TcpClient =new TcpClient(result[0].tcplocalIp, result[0].tcplocalIpPort,result[0].tcpOppositeIp,result[0].tcpOppositePort) | ||||
|     globalThis.lsh = '1111111111111' | ||||
| 
 | ||||
|   } | ||||
| @ -587,7 +492,6 @@ struct Index { | ||||
|     const time = await getCurrentTime() | ||||
|     const date = time.split(' ')[0] | ||||
|     this.fileHelper.createAlbum('jt') | ||||
|     // this.fileHelper.createAlbum('2025-01-02') | ||||
|     this.fileHelper.createAlbum('pz'); | ||||
|     this.fileHelper.createAlbum(date); | ||||
| 
 | ||||
| @ -628,7 +532,7 @@ struct Index { | ||||
|     await getDeviceInfo(this.context) | ||||
| 
 | ||||
|     await getCarInfo() | ||||
|     new RemoteToolWebsocket().register() | ||||
|     this.remoteToolWebsocket.register() | ||||
|     await getUDP2(this.context, false) | ||||
|     getTCP() | ||||
|     this.deviceId = globalThis.carInfo.carNo | ||||
|  | ||||
| @ -9,7 +9,6 @@ import Judge from './judgeSDK/judge'; | ||||
| import { defaultJudgeConfigObj } from './judgeSDK/utils//judgeCommon'; | ||||
| import { uploadExamMileage } from '../api/judge' | ||||
| import DwztErrorPopup from './compontents/judge/DwztErrorPopup' | ||||
| import { debounce } from '../common/utils/tools' | ||||
| import MsgPopup from './compontents/judge/MsgPopup' | ||||
| 
 | ||||
| import { | ||||
| @ -26,25 +25,64 @@ import { | ||||
| } from './judgeSDK/api/judgeSDK.d'; | ||||
| 
 | ||||
| import { chunkArr, formatTime, getCurrentHourTime, getCurrentTime } from '../common/utils/tools'; | ||||
| import { examJudgeEndExam } from './judgeSDK/api/index'; | ||||
| import { getSyncData } from '../common/service/initable'; | ||||
| import { judgeConfig } from './judgeSDK/utils/judgeConfig'; | ||||
| import FileUtil from '../common/utils/File'; | ||||
| import SignDisplayCom from './compontents/signDisplayCom'; | ||||
| import promptAction from '@ohos.promptAction'; | ||||
| import { voiceService } from '../common/service/voiceService'; | ||||
| import { DataParams, RemoteToolWebsocket } from '../common/utils/RemotetoolWebsocket'; | ||||
| 
 | ||||
| @Entry | ||||
| @Component | ||||
| struct Index { | ||||
|   @State @Watch('syncData') currentList: string[] = [] | ||||
|   @State @Watch('syncData') timestamp: number = 0 | ||||
|   private remoteToolWebsocket: RemoteToolWebsocket = new RemoteToolWebsocket() | ||||
|   private syncToolData = () => { | ||||
|     this.syncData() | ||||
|   } | ||||
| 
 | ||||
|   syncData() { | ||||
|     if (this.remoteToolWebsocket.isStart) { | ||||
|       this.remoteToolWebsocket.sendData<DataParams>({ | ||||
|         page: 11, | ||||
|         data: JSON.stringify({ | ||||
|           user: { | ||||
|             name: this.name, // 姓名 | ||||
|             idCard: this.idCard, // 身份证 | ||||
|             subject: this.examSubject, // 科目 | ||||
|             examCount: this.kssycs, // 剩余考试次数 | ||||
|           }, | ||||
|           projects: this.projects.map(item => ({ | ||||
|             code: item.projectCode, | ||||
|             status: item.type | ||||
|           })), | ||||
|           deduction: this.kfArr.map(item => ({ | ||||
|             code: item.markcatalog | ||||
|           })), | ||||
|           exam: { | ||||
|             startTime: this.timestamp.toString(), // 开始时间 | ||||
|             examLine: this.wayno, // 考试线路 | ||||
|             examMile: `${this.jl},${this.examMileage}`, // 考试里程 已行驶,应行驶 | ||||
|             score: this.totalScore, // 当前分数 | ||||
|           }, | ||||
|           deducted: this.isDeductedPopShow ? 1 : 0, | ||||
|           deductionList: this.currentList.map(item => ({ code: item })), // 扣分列表 | ||||
|           error: '', | ||||
|         }) | ||||
|       }) | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   async aboutToDisappear() { | ||||
|     this.remoteToolWebsocket.offStart(11) | ||||
|     clearInterval(this.mileageTimer) | ||||
|   } | ||||
| 
 | ||||
|   async aboutToAppear() { | ||||
|     this.remoteToolWebsocket.onStart(this.syncToolData, 11) | ||||
|     globalThis.windowClass.setWindowSystemBarEnable([]) | ||||
|     const time = await getCurrentTime() | ||||
| 
 | ||||
|     this.timestamp = new Date(time).getTime() | ||||
|     this.startTime = time.split(' ')[1] | ||||
|     this.startFullTime = await getCurrentTime(1); | ||||
|     this.startHourTime = await getCurrentHourTime() | ||||
| @ -961,6 +999,9 @@ struct Index { | ||||
|               this.isDeductedPopShow = false | ||||
|               this.popTimer = null; | ||||
|             }, 500) | ||||
|           }, | ||||
|           onListChange: (list: string[]) => { | ||||
|             this.currentList = list | ||||
|           } | ||||
|         }) | ||||
|       } | ||||
| @ -982,10 +1023,6 @@ struct Index { | ||||
|           .backgroundImage($rawfile('judge/close.png'), ImageRepeat.NoRepeat) | ||||
|           .backgroundImageSize({ width: '33.33%', height: '33.33%' }) | ||||
|           .onClick(() => { | ||||
|             // this.vocObj.playAudio({ | ||||
|             //   type: 1, | ||||
|             //   name: 'button_media.wav' | ||||
|             // }) | ||||
|             this.signDisplayComVisible = false | ||||
|           }) | ||||
|         }.width('100%').height('100%').position({ y: 0 }).backgroundColor('rgba(0,0,0,0.6)') | ||||
| @ -1331,7 +1368,7 @@ struct Index { | ||||
|   } | ||||
|   scroller: Scroller = new Scroller() | ||||
|   //页面通用字体大小 | ||||
|   @State wayno: number = 0 | ||||
|   @State @Watch('syncData') wayno: number = 0 | ||||
|   @State FONTSIZE: number = 30 | ||||
|   @State BIGFONTSIZE: number = 32 | ||||
|   //结束考试弹窗 | ||||
| @ -1345,29 +1382,29 @@ struct Index { | ||||
|   //考试用时 | ||||
|   @State examTime: number = 0 | ||||
|   //开始时间 | ||||
|   @State startTime: string = '00:00:00' | ||||
|   @State @Watch('syncData') startTime: string = '00:00:00' | ||||
|   @State startFullTime: string = '' | ||||
|   @State startHourTime: string = '' | ||||
|   @State startExamTime: string = '' | ||||
|   //科目类型 | ||||
|   @State examSubject: 2 | 3 = 3; | ||||
|   @State @Watch('syncData') examSubject: 2 | 3 = 3; | ||||
|   @State ddxkTime: number = 0; | ||||
|   @State ddxkKsxmArr: string[] = [] | ||||
|   @State ddxkKfArr: string[] = [] | ||||
|   @State xmmcStr: string = '' | ||||
|   @State carztStr: string = '' | ||||
|   @State kfArr: { | ||||
|   @State @Watch('syncData') kfArr: { | ||||
|     xmmcStr?: string, | ||||
|     score: string, | ||||
|     desc: string | ||||
|     markcatalog: string | ||||
|   }[] = [] | ||||
|   @State name: string = '' | ||||
|   @State idCard: string = '' | ||||
|   @State @Watch('syncData') name: string = '' | ||||
|   @State @Watch('syncData') idCard: string = '' | ||||
|   @State singlePlay: boolean = false; | ||||
|   @State totalScore: number = 100 | ||||
|   @State @Watch('syncData') totalScore: number = 100 | ||||
|   //模拟考试项目 | ||||
|   @State projects: Project[] = [] | ||||
|   @State @Watch('syncData') projects: Project[] = [] | ||||
|   @State projectsObj: ProjectObj = {} | ||||
|   @State projectsCenterObj: ProjectObj = {} | ||||
|   @State markRuleListObj: MarkRule = {} | ||||
| @ -1380,8 +1417,8 @@ struct Index { | ||||
|   @State lsh: string = '' | ||||
|   @State kszp: string = '' | ||||
|   @State ksdd: string = '' | ||||
|   @State kssycs: string = '' | ||||
|   @State ksxl: string = '' | ||||
|   @State @Watch('syncData') kssycs: string = '' | ||||
|   @State @Watch('syncData') ksxl: string = '' | ||||
|   @State kslx: string = '' | ||||
|   //监管线路代码 | ||||
|   @State xldm: string = '' | ||||
| @ -1394,14 +1431,14 @@ struct Index { | ||||
|   @State syssetParam386ET3: boolean = false; | ||||
|   @State carType: string = '' | ||||
|   @State carName: string = '' | ||||
|   @State isDeductedPopShow: boolean = false | ||||
|   @State @Watch('syncData') isDeductedPopShow: boolean = false | ||||
|   @State isAmplifyPopShow: boolean = false | ||||
|   @State amplifiedImgIndex: number = 0 | ||||
|   @State judge: any = {} | ||||
|   //行驶距离 | ||||
|   @State jl: number = 0 | ||||
|   @State @Watch('syncData') jl: number = 0 | ||||
|   //应考里程 | ||||
|   @State examMileage: string = '0' | ||||
|   @State @Watch('syncData') examMileage: string = '0' | ||||
|   @State artSubject3Projects: string[] = ['直线', '会车', '变道', '超车', '掉头', '停车'] | ||||
|   @State artSubject3ProjectsCodesArr: string[] = ['3', '9', '4', '10', '12', '11'] | ||||
|   @State manualMarkRules: MarkRule[] = [] | ||||
|  | ||||
| @ -3,6 +3,7 @@ import MA_SYSTEMPARM from '../common/constants/MA_SYSTEMPARM'; | ||||
| import AccountTable from '../common/database/tables/AccountTable'; | ||||
| import { getSyncData } from '../common/service/initable'; | ||||
| import router from '@ohos.router'; | ||||
| import { RemoteToolWebsocket } from '../common/utils/RemotetoolWebsocket'; | ||||
| 
 | ||||
| const cBg = $rawfile('judge/km3/road/luxian_pre.png'); | ||||
| const lBg = $rawfile('judge/km3/road/luxian_nor.png'); | ||||
| @ -15,6 +16,7 @@ const ltBg = $rawfile('judge/km3/road/luxian_nor.png'); | ||||
| export default struct Index { | ||||
|   @State @Watch('outClick') outFlag: boolean = false; | ||||
|   @State roadObj: any = {} | ||||
|   private remoteToolWebsocket: RemoteToolWebsocket = new RemoteToolWebsocket() | ||||
| 
 | ||||
|   async aboutToAppear() { | ||||
|     //读取systemparam表的no1等于4的 | ||||
| @ -32,7 +34,7 @@ export default struct Index { | ||||
|   build() { | ||||
|     Column() { | ||||
|       TopLogo({ outFlag: $outFlag }) | ||||
|       Flex({wrap:FlexWrap.Wrap,direction:FlexDirection.Row,justifyContent:FlexAlign.Start}){ | ||||
|       Flex({ wrap: FlexWrap.Wrap, direction: FlexDirection.Row, justifyContent: FlexAlign.Start }) { | ||||
|         List({}) { | ||||
|           ListItem() { | ||||
|             Column() { | ||||
| @ -56,9 +58,10 @@ export default struct Index { | ||||
|             const roadArr = Reflect.ownKeys(this.roadObj).map((roadKey) => { | ||||
|               return this.roadObj[roadKey] | ||||
|             }); | ||||
|             const wayno = roadArr[Math.floor(Math.random()*roadArr.length)]; | ||||
|             const wayno = roadArr[Math.floor(Math.random() * roadArr.length)]; | ||||
|             this.goJudge(wayno) | ||||
|           }) | ||||
| 
 | ||||
|           ForEach(Reflect.ownKeys(this.roadObj), (roadIndex) => { | ||||
|             ListItem() { | ||||
|               Column() { | ||||
| @ -68,6 +71,7 @@ export default struct Index { | ||||
|                 .backgroundImageSize({ width: '100%', height: '100%' }) | ||||
|                 .width(90) | ||||
|                 .height(80) | ||||
| 
 | ||||
|                 Text(`线路${this.roadObj[roadIndex] + ''}`) { | ||||
|                 }.fontColor('#FFF2D9').fontSize(24).padding({ top: 10 }) | ||||
|               } | ||||
| @ -92,15 +96,17 @@ export default struct Index { | ||||
|   goJudge(wayno) { | ||||
|     let currentParams: any = router.getParams() || {}; | ||||
|     const {sczb,kfdm} = currentParams; | ||||
|     this.remoteToolWebsocket.sendRouter("10", "11") | ||||
|     router.replaceUrl({ | ||||
|       url: 'pages/Judge', | ||||
|       params:{ | ||||
|       params: { | ||||
|         sczb, | ||||
|         kfdm, | ||||
|         wayno, | ||||
|       } | ||||
|     }, router.RouterMode.Single); | ||||
| 
 | ||||
|     }, router.RouterMode.Single) | ||||
|   } | ||||
| 
 | ||||
|   outClick() { | ||||
|   } | ||||
|   outClick(){} | ||||
| } | ||||
| @ -126,15 +126,15 @@ struct UserInfo { | ||||
|         const {examSubject} = globalThis.carInfo; | ||||
|         this.currentUser.id = '0' | ||||
|         await upDateTableByArray('USER', [this.currentUser]) | ||||
|         this.remoteToolWebsocket.sendRouter("9", examSubject == 3 ? '10' : '11') | ||||
|         router.pushUrl({ | ||||
|           url: examSubject == 3 ? 'pages/Roads' : 'pages/Judge', | ||||
|           params: { | ||||
|             sczb: Number(this.isBoardPrePareSetPopupOpen), | ||||
|             kfdm: this.sczbkf, | ||||
|           } | ||||
|         }, router.RouterMode.Single); | ||||
|         }, router.RouterMode.Single) | ||||
|         this.ksksLimit = false | ||||
| 
 | ||||
|         this.stopDeviceById() | ||||
|         return | ||||
|       } | ||||
| @ -187,14 +187,17 @@ struct UserInfo { | ||||
|   ] | ||||
|   private fileUtil: FileUtil | ||||
|   private remoteToolWebsocket: RemoteToolWebsocket = new RemoteToolWebsocket() | ||||
|   private syncToolData = () => { | ||||
|     this.syncData() | ||||
|   } | ||||
| 
 | ||||
|   syncData() { | ||||
|     if (this.remoteToolWebsocket.isStart) { | ||||
|       this.remoteToolWebsocket.sendData<DataParams>({ | ||||
|         page: "9", | ||||
|         page: 9, | ||||
|         data: JSON.stringify({ | ||||
|           select: this.select, | ||||
|           students: this.dataList.map(item => ({ | ||||
|           student: this.dataList.map(item => ({ | ||||
|             id: item.lsh, | ||||
|             name: item.xm, | ||||
|             idCard: item.sfzmhm, | ||||
| @ -211,12 +214,12 @@ struct UserInfo { | ||||
|   aboutToAppear() { | ||||
|     this.fileUtil = new FileUtil(this.context) | ||||
|     this.avPlayer = new VoiceAnnounce(); | ||||
|     this.remoteToolWebsocket.onStart(this.syncData) | ||||
|     this.remoteToolWebsocket.onStart(this.syncToolData, 9) | ||||
|   } | ||||
| 
 | ||||
|   aboutToDisappear() { | ||||
|     this.outClick() | ||||
|     this.remoteToolWebsocket.offStart(this.syncData) | ||||
|     this.remoteToolWebsocket.offStart(9) | ||||
|   } | ||||
| 
 | ||||
|   async onPageShow() { | ||||
| @ -939,8 +942,6 @@ struct UserInfo { | ||||
|       console.info('surenjun', '播放结束开始考试接口调用') | ||||
|       const {code,keystr,message} = await this.beginExam() || {}; | ||||
|       console.info('surenjun', '开始考试接口调用结束') | ||||
|       // console.info('surenjun',code +'') | ||||
|       //@ts-ignore TODO code转换 | ||||
| 
 | ||||
|       if (code != 1) { | ||||
|         avPlayer.playAudio([code == -200 ? 'voice/photo_error.mp3' : 'voice/监管审核未通过.mp3']); | ||||
| @ -956,6 +957,7 @@ struct UserInfo { | ||||
|       await upDateTableByArray('USER', [this.currentUser]) | ||||
|       this.stepFlag = false | ||||
|       this.isLoadingPopupVisible = false | ||||
|       this.remoteToolWebsocket.sendRouter("9", "11") | ||||
|       router.pushUrl({ | ||||
|         url: 'pages/Judge', | ||||
|         params: { | ||||
| @ -965,7 +967,7 @@ struct UserInfo { | ||||
|           //真实监管项目 | ||||
|           kString: decodeURIComponent(keystr || '') | ||||
|         } | ||||
|       }, router.RouterMode.Single); | ||||
|       }, router.RouterMode.Single) | ||||
|       this.updateTimeLimit = false | ||||
|       this.stopDeviceById() | ||||
|       this.stepFlag = false | ||||
| @ -1080,11 +1082,11 @@ struct UserInfo { | ||||
|   // 开始考试 | ||||
|   async beginExam() { | ||||
|     const carInfo = globalThis.carInfo; | ||||
|     const {carId,examinationRoomId} = carInfo; | ||||
|     const { examSubject,plateNo } = carInfo; | ||||
|     const date = new Date() | ||||
|     globalThis.startHourTime = await getCurrentHourTime() | ||||
|     const photoBase64 = await this.getPhoto(); | ||||
|     // const photoBase64 = await this.getPhoto(); | ||||
|     const photoBase64: string = ''; | ||||
|     if (photoBase64 == '') { | ||||
|       this.ksksLimit = false | ||||
|       this.isLoadingPopupVisible = false | ||||
|  | ||||
| @ -1,175 +1,233 @@ | ||||
| import {MarkRule} from '../../judgeSDK/api/judgeSDK' | ||||
| import { MarkRule } from '../../judgeSDK/api/judgeSDK' | ||||
| import EndPoPup from './EndPopup'; | ||||
| 
 | ||||
| interface SEL{ | ||||
|   fontColor:string | ||||
|   bgColor:string | ||||
| interface SEL { | ||||
|   fontColor: string | ||||
|   bgColor: string | ||||
| } | ||||
| 
 | ||||
| @Component | ||||
| export default struct  DeductedPopup { | ||||
| export default struct DeductedPopup { | ||||
|   constructor() { | ||||
|     super() | ||||
|   } | ||||
| 
 | ||||
|   @State fontSize:number = 30 | ||||
|   @State unselected:SEL = {fontColor:'#000000', bgColor:'#CCC4B8'} | ||||
|   @State selected:SEL =   {fontColor:'#FFAD33', bgColor:'#26231E'} | ||||
| 
 | ||||
|   @State currentIndex:number = 0 | ||||
|   @State currentPageIndex:number = 0 | ||||
|   @State fontSize: number = 30 | ||||
|   @State unselected: SEL = { fontColor: '#000000', bgColor: '#CCC4B8' } | ||||
|   @State selected: SEL = { fontColor: '#FFAD33', bgColor: '#26231E' } | ||||
|   @State currentIndex: number = 0 | ||||
|   @State currentPageIndex: number = 0 | ||||
|   //通用评判扣分 | ||||
|   @State currentUniversalPageIndex:number = 0; | ||||
|   private  markRules:MarkRule[] = [] | ||||
|   @State universalMarkRules:MarkRule[] = [] | ||||
|   @State manualMarkRules:MarkRule[] = [] | ||||
|   @State lineBg:Array<string> = ['#4D4136','#26231E'] | ||||
|   @State selectedLine:number = undefined | ||||
|   @State endPopupVisible:boolean = false | ||||
|   private  closePopup:Function = ()=> {} | ||||
|   private  confirmMark:Function = (itemno:number,serial:string) => {} | ||||
|   @State selectedLineStyle:SEL = { | ||||
|     fontColor:'#FFF', | ||||
|     bgColor:'#B36E00' | ||||
|   @State currentUniversalPageIndex: number = 0; | ||||
|   private markRules: MarkRule[] = [] | ||||
|   @State universalMarkRules: MarkRule[] = [] | ||||
|   @State manualMarkRules: MarkRule[] = [] | ||||
|   @State lineBg: Array<string> = ['#4D4136', '#26231E'] | ||||
|   @State selectedLine: number = undefined | ||||
|   @State endPopupVisible: boolean = false | ||||
|   private closePopup: Function = () => { | ||||
|   } | ||||
|   private confirmMark: Function = (itemno: number, serial: string) => { | ||||
|   } | ||||
|   @State selectedLineStyle: SEL = { | ||||
|     fontColor: '#FFF', | ||||
|     bgColor: '#B36E00' | ||||
|   } | ||||
|   @Prop defaultTabIndex: number = 0 | ||||
|   @Prop @Watch('changeCurrentItems') currentItems: string[] = []; | ||||
|   @State preCurrentItemsLength: number = 0 | ||||
|   onListChange?: (list: string[]) => void | ||||
| 
 | ||||
|   @Prop defaultTabIndex:number = 0 | ||||
|   @Prop @Watch('changeCurrentItems') currentItems:string[] = []; | ||||
|   @State preCurrentItemsLength:number = 0 | ||||
| 
 | ||||
|   aboutToAppear(){ | ||||
|   aboutToAppear() { | ||||
|     //@ts-ignore | ||||
|     this.universalMarkRules = this.markRules.filter(item => (this.currentItems.includes(item.itemno) || this.currentItems.includes(item.itemno + ''))); | ||||
|     this.currentIndex = this.defaultTabIndex | ||||
|     if(this.currentIndex == 1){ | ||||
|       this.universalMarkRules = this.markRules.filter(item => item.itemno == 20 ) | ||||
|     if (this.currentIndex == 1) { | ||||
|       this.universalMarkRules = this.markRules.filter(item => item.itemno == 20) | ||||
|     } | ||||
|     this.preCurrentItemsLength = this.currentItems.length | ||||
|   } | ||||
| 
 | ||||
|   changeCurrentItems(){ | ||||
|     if(this.currentItems?.length && (this.currentItems?.length >= this.preCurrentItemsLength)){ | ||||
|   changeCurrentItems() { | ||||
|     if (this.currentItems?.length && (this.currentItems?.length >= this.preCurrentItemsLength)) { | ||||
|       //@ts-ignore | ||||
|       this.universalMarkRules = this.markRules.filter(item => (this.currentItems.includes(item.itemno) || this.currentItems.includes(item.itemno + ''))); | ||||
|       this.currentIndex = this.defaultTabIndex | ||||
|       if(this.currentIndex == 1){ | ||||
|         this.universalMarkRules = this.markRules.filter(item => item.itemno == 20 ) | ||||
|       if (this.currentIndex == 1) { | ||||
|         this.universalMarkRules = this.markRules.filter(item => item.itemno == 20) | ||||
|       } | ||||
|       this.preCurrentItemsLength = this.currentItems.length | ||||
|     }else{ | ||||
|     } else { | ||||
|       this.preCurrentItemsLength = 0 | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   //上一页 下一页 | ||||
|   goPage(typeIndex){ | ||||
|   goPage(typeIndex) { | ||||
|     const currentIndex = this.currentIndex | ||||
|     if(currentIndex){ | ||||
|     if (currentIndex) { | ||||
|       //通用评判 | ||||
|       typeIndex ? (this.currentUniversalPageIndex += 1) : (this.currentUniversalPageIndex -= 1) | ||||
|     }else{ | ||||
|     } else { | ||||
|       typeIndex ? (this.currentPageIndex += 1) : (this.currentPageIndex -= 1) | ||||
|     } | ||||
|     this.selectedLine = -1 | ||||
|   } | ||||
| 
 | ||||
|   //选中扣分项 | ||||
|   getSelectedLine(index){ | ||||
|   getSelectedLine(index) { | ||||
|     const {selectedLine,selectedLineStyle,lineBg} = this; | ||||
|     if(selectedLine === index){ | ||||
|     if (selectedLine === index) { | ||||
|       return selectedLineStyle.bgColor | ||||
|     } | ||||
|     if(index % 2 === 0){ | ||||
|     if (index % 2 === 0) { | ||||
|       return lineBg[0] | ||||
|     }else{ | ||||
|     } else { | ||||
|       return lineBg[1] | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   //获取当前页的数据 | ||||
|   getCurrentMarkRuleList(){ | ||||
|   getCurrentMarkRuleList() { | ||||
|     const {currentIndex,currentUniversalPageIndex,currentPageIndex,markRules,universalMarkRules} = this; | ||||
|     if(currentIndex){ | ||||
|     if (currentIndex) { | ||||
|       this.onListChange(universalMarkRules.slice(currentUniversalPageIndex * 7, (currentUniversalPageIndex + 1) * 7) | ||||
|         .map(item => item.markcatalog)) | ||||
|       //通用评判 | ||||
|       return universalMarkRules.slice(currentUniversalPageIndex*7,(currentUniversalPageIndex + 1)*7) | ||||
|     }else{ | ||||
|       return universalMarkRules.slice(currentPageIndex*7,(currentPageIndex + 1)*7) | ||||
|       return universalMarkRules.slice(currentUniversalPageIndex * 7, (currentUniversalPageIndex + 1) * 7) | ||||
|     } else { | ||||
|       this.onListChange(universalMarkRules.slice(currentPageIndex * 7, (currentPageIndex + 1) * 7) | ||||
|         .map(item => item.markcatalog)) | ||||
|       return universalMarkRules.slice(currentPageIndex * 7, (currentPageIndex + 1) * 7) | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   build(){ | ||||
|     Column(){ | ||||
|       Column(){ | ||||
|         Column(){ | ||||
|           Row(){ | ||||
|             Row(){ | ||||
|               ForEach(['人工评判','通用评判'],(text,index)=>{ | ||||
|                 Row(){ | ||||
|                   Text(text).fontColor(index === this.currentIndex ? this.selected.fontColor : this.unselected.fontColor).fontSize(this.fontSize).fontWeight(500) | ||||
|   build() { | ||||
|     Column() { | ||||
|       Column() { | ||||
|         Column() { | ||||
|           Row() { | ||||
|             Row() { | ||||
|               ForEach(['人工评判', '通用评判'], (text, index) => { | ||||
|                 Row() { | ||||
|                   Text(text) | ||||
|                     .fontColor(index === this.currentIndex ? this.selected.fontColor : this.unselected.fontColor) | ||||
|                     .fontSize(this.fontSize) | ||||
|                     .fontWeight(500) | ||||
|                 } | ||||
|                 .width(140).height(60) | ||||
|                 .backgroundColor(index === this.currentIndex ? this.selected.bgColor: this.unselected.bgColor ).justifyContent(FlexAlign.Center).justifyContent(FlexAlign.Center) | ||||
|                 .borderRadius({topLeft:20,topRight:20}).margin({right:10}) | ||||
|                 .onClick(()=>{ | ||||
|                 .width(140) | ||||
|                 .height(60) | ||||
|                 .backgroundColor(index === this.currentIndex ? this.selected.bgColor : this.unselected.bgColor) | ||||
|                 .justifyContent(FlexAlign.Center) | ||||
|                 .justifyContent(FlexAlign.Center) | ||||
|                 .borderRadius({ topLeft: 20, topRight: 20 }) | ||||
|                 .margin({ right: 10 }) | ||||
|                 .onClick(() => { | ||||
|                   this.currentIndex = index; | ||||
|                   this.selectedLine = -1; | ||||
|                   if(index === 1) { | ||||
|                     this.universalMarkRules = this.markRules.filter(item => item.itemno == 20 ) | ||||
|                   }else{ | ||||
|                   if (index === 1) { | ||||
|                     this.universalMarkRules = this.markRules.filter(item => item.itemno == 20) | ||||
|                   } else { | ||||
|                     //@ts-ignore | ||||
|                     this.universalMarkRules = this.markRules.filter(item => (this.currentItems.includes(item.itemno) || this.currentItems.includes(item.itemno+''))) | ||||
|                     this.universalMarkRules = this.markRules.filter(item => (this.currentItems.includes(item.itemno) || this.currentItems.includes(item.itemno + ''))) | ||||
|                   } | ||||
|                 }) | ||||
|               }) | ||||
|             } | ||||
|             Row(){ | ||||
|               if( | ||||
|                 (Math.ceil(this.universalMarkRules.length / 7 - 1)) >= (this.currentIndex ? this.currentUniversalPageIndex: this.currentPageIndex) && | ||||
|                   (this.currentIndex ? this.currentUniversalPageIndex: this.currentPageIndex) > 0 | ||||
|               ){ | ||||
|                 Row(){ | ||||
|                   Image($rawfile(`judge/km3/zuo_nor.png`)).height(15).margin({left:20,top:0}) | ||||
|                   Text('上一页'){}.fontColor('#FFF').fontSize(this.fontSize) | ||||
|                 }.width(150).height(60).justifyContent(FlexAlign.Start).alignItems(VerticalAlign.Center).backgroundImage($rawfile(`judge/km3/button_nor.png`)).backgroundImageSize({width:'100%',height:'100%'}).margin({right:30}) | ||||
|                 .onClick(()=>{this.goPage(0)}) | ||||
| 
 | ||||
|             Row() { | ||||
|               if ( | ||||
|                 (Math.ceil(this.universalMarkRules.length / 7 - 1)) >= (this.currentIndex ? this.currentUniversalPageIndex : this.currentPageIndex) && | ||||
|                   (this.currentIndex ? this.currentUniversalPageIndex : this.currentPageIndex) > 0 | ||||
|               ) { | ||||
|                 Row() { | ||||
|                   Image($rawfile(`judge/km3/zuo_nor.png`)).height(15).margin({ left: 20, top: 0 }) | ||||
|                   Text('上一页') { | ||||
|                   }.fontColor('#FFF').fontSize(this.fontSize) | ||||
|                 } | ||||
|                 .width(150) | ||||
|                 .height(60) | ||||
|                 .justifyContent(FlexAlign.Start) | ||||
|                 .alignItems(VerticalAlign.Center) | ||||
|                 .backgroundImage($rawfile(`judge/km3/button_nor.png`)) | ||||
|                 .backgroundImageSize({ width: '100%', height: '100%' }) | ||||
|                 .margin({ right: 30 }) | ||||
|                 .onClick(() => { | ||||
|                   this.goPage(0) | ||||
|                 }) | ||||
|               } | ||||
| 
 | ||||
|               if( | ||||
|                 (Math.ceil(this.universalMarkRules.length / 7 - 1))  > (this.currentIndex ? this.currentUniversalPageIndex: this.currentPageIndex) | ||||
|               ){ | ||||
|                 Row(){ | ||||
|                   Text('下一页'){}.fontColor('#FFF').fontSize(this.fontSize).padding({left:30}) | ||||
|                   Image($rawfile(`judge/km3/you_nor.png`)).height(15).margin({right:6,top:0}) | ||||
|                 }.width(150).height(60).justifyContent(FlexAlign.Start).alignItems(VerticalAlign.Center).backgroundImage($rawfile(`judge/km3/button_nor.png`)).backgroundImageSize({width:'100%',height:'100%'}).margin({right:30}) | ||||
|                 .onClick(()=>{this.goPage(1)}) | ||||
|               if ( | ||||
|                 (Math.ceil(this.universalMarkRules.length / 7 - 1)) > (this.currentIndex ? this.currentUniversalPageIndex : this.currentPageIndex) | ||||
|               ) { | ||||
|                 Row() { | ||||
|                   Text('下一页') { | ||||
|                   }.fontColor('#FFF').fontSize(this.fontSize).padding({ left: 30 }) | ||||
| 
 | ||||
|                   Image($rawfile(`judge/km3/you_nor.png`)).height(15).margin({ right: 6, top: 0 }) | ||||
|                 } | ||||
|                 .width(150) | ||||
|                 .height(60) | ||||
|                 .justifyContent(FlexAlign.Start) | ||||
|                 .alignItems(VerticalAlign.Center) | ||||
|                 .backgroundImage($rawfile(`judge/km3/button_nor.png`)) | ||||
|                 .backgroundImageSize({ width: '100%', height: '100%' }) | ||||
|                 .margin({ right: 30 }) | ||||
|                 .onClick(() => { | ||||
|                   this.goPage(1) | ||||
|                 }) | ||||
|               } | ||||
| 
 | ||||
|               Row(){ | ||||
|                 Text('扣  分'){}.fontColor('#FFF').fontSize(this.fontSize).padding({left:35}) | ||||
|               }.width(140).height(60).justifyContent(FlexAlign.Start).alignItems(VerticalAlign.Center).backgroundImage($rawfile(`judge/km3/button_nor.png`)).backgroundImageSize({width:'100%',height:'100%'}) | ||||
|               .onClick(()=>{ | ||||
|               Row() { | ||||
|                 Text('扣  分') { | ||||
|                 }.fontColor('#FFF').fontSize(this.fontSize).padding({ left: 35 }) | ||||
|               } | ||||
|               .width(140) | ||||
|               .height(60) | ||||
|               .justifyContent(FlexAlign.Start) | ||||
|               .alignItems(VerticalAlign.Center) | ||||
|               .backgroundImage($rawfile(`judge/km3/button_nor.png`)) | ||||
|               .backgroundImageSize({ width: '100%', height: '100%' }) | ||||
|               .onClick(() => { | ||||
|                 this.endPopupVisible = true | ||||
|               }) | ||||
|             } | ||||
|           }.width('100%').justifyContent(FlexAlign.SpaceBetween) | ||||
|           Column(){ | ||||
|             ForEach(this.getCurrentMarkRuleList(),(item,index) => { | ||||
|               Row(){ | ||||
|                 Row(){ | ||||
|                   Text(`${item.markshow} (${item.markcatalog})`).fontColor('#FFF').fontSize(this.fontSize).fontWeight(600) | ||||
| 
 | ||||
|           Column() { | ||||
|             ForEach(this.getCurrentMarkRuleList(), (item, index) => { | ||||
|               Row() { | ||||
|                 Row() { | ||||
|                   Text(`${item.markshow} (${item.markcatalog})`) | ||||
|                     .fontColor('#FFF') | ||||
|                     .fontSize(this.fontSize) | ||||
|                     .fontWeight(600) | ||||
|                 }.width(1000) | ||||
|                 Row(){ | ||||
| 
 | ||||
|                 Row() { | ||||
|                   Text(item.markreal + '').fontColor('#FFF').fontSize(this.fontSize).fontWeight(600) | ||||
|                 } | ||||
|               } | ||||
|               .width('100%').justifyContent(FlexAlign.SpaceBetween).alignItems(VerticalAlign.Center).constraintSize({minHeight:70}) | ||||
|               .padding({left:20,right:20}) | ||||
|               .width('100%') | ||||
|               .justifyContent(FlexAlign.SpaceBetween) | ||||
|               .alignItems(VerticalAlign.Center) | ||||
|               .constraintSize({ minHeight: 70 }) | ||||
|               .padding({ left: 20, right: 20 }) | ||||
|               .backgroundColor(this.getSelectedLine(index)) | ||||
|               .onClick(()=>{this.selectedLine = index}) | ||||
|               .onClick(() => { | ||||
|                 this.selectedLine = index | ||||
|               }) | ||||
|             }) | ||||
|           } | ||||
|         } | ||||
|       }.width(1200).height(620).position({x:30,y:315}).backgroundColor('#E6E3DF').padding({top:15,bottom:15,left:25,right:25}).borderRadius(20) | ||||
|       } | ||||
|       .width(1200) | ||||
|       .height(620) | ||||
|       .position({ x: 30, y: 315 }) | ||||
|       .backgroundColor('#E6E3DF') | ||||
|       .padding({ top: 15, bottom: 15, left: 25, right: 25 }) | ||||
|       .borderRadius(20) | ||||
| 
 | ||||
|       // Row(){}.width(100).height(100).position({y:'85%',x:'50%'}).backgroundImage($rawfile('judge/km3/close_nor.png')).backgroundImageSize({width:'100%',height:'100%'}) | ||||
|       //结束考试弹窗 | ||||
|       if (this.endPopupVisible) { | ||||
| @ -179,12 +237,14 @@ export default struct  DeductedPopup { | ||||
|             this.endPopupVisible = false; | ||||
|           }, | ||||
|           confirmFn: async () => { | ||||
|             const index = this.currentIndex ? this.currentUniversalPageIndex: this.currentPageIndex; | ||||
|             const index = this.currentIndex ? this.currentUniversalPageIndex : this.currentPageIndex; | ||||
|             const mark = this.universalMarkRules[index * 7 + this.selectedLine] | ||||
|             mark && this.confirmMark(mark.itemno,mark.markserial) | ||||
|             mark && this.confirmMark(mark.itemno, mark.markserial) | ||||
|           } | ||||
|         }) | ||||
|       } | ||||
|     }.width('100%').height('100%').position({y:0}).onClick(()=>{this.closePopup()}) | ||||
|     }.width('100%').height('100%').position({ y: 0 }).onClick(() => { | ||||
|       this.closePopup() | ||||
|     }) | ||||
|   } | ||||
| } | ||||
| @ -1,9 +1,8 @@ | ||||
| 
 | ||||
| 
 | ||||
| { | ||||
|   "module": { | ||||
|     "name": "entry", | ||||
|     "type": "entry", | ||||
|     "srcEntry": "./ets/entryability/EntryAbility.ets", | ||||
|     "description": "$string:module_desc", | ||||
|     "mainElement": "EntryAbility", | ||||
|     "deviceTypes": [ | ||||
| @ -13,17 +12,16 @@ | ||||
|     "deliveryWithInstall": true, | ||||
|     "installationFree": false, | ||||
|     "pages": "$profile:main_pages", | ||||
| 
 | ||||
|     "abilities": [ | ||||
|       { | ||||
|         "name": "EntryAbility", | ||||
|         "srcEntrance": "./ets/entryability/EntryAbility.ets", | ||||
|         "srcEntry": "./ets/entryability/EntryAbility.ets", | ||||
|         "description": "$string:EntryAbility_desc", | ||||
|         "icon": "$media:logo_app", | ||||
|         "label": "$string:EntryAbility_label", | ||||
|         "startWindowIcon": "$media:icon", | ||||
|         "startWindowBackground": "$color:start_window_background", | ||||
|         "visible": true, | ||||
|         "exported": true, | ||||
|         "skills": [ | ||||
|           { | ||||
|             "entities": [ | ||||
| @ -36,9 +34,13 @@ | ||||
|         ] | ||||
|       } | ||||
|     ], | ||||
|     "requestPermissions":[ | ||||
|       {"name": "ohos.permission.CONNECTIVITY_INTERNAL"}, | ||||
|       {"name": "ohos.permission.SET_TIME"}, | ||||
|     "requestPermissions": [ | ||||
|       { | ||||
|         "name": "ohos.permission.CONNECTIVITY_INTERNAL" | ||||
|       }, | ||||
|       { | ||||
|         "name": "ohos.permission.SET_TIME" | ||||
|       }, | ||||
|       { | ||||
|         "name": "ohos.permission.INTERNET" | ||||
|       }, | ||||
| @ -102,26 +104,6 @@ | ||||
|           "when": "always" | ||||
|         } | ||||
|       }, | ||||
|       //      { | ||||
|       //        "name": "ohos.permission.READ_MEDIA", | ||||
|       //        "reason": "$string:module_desc", | ||||
|       //        "usedScene": { | ||||
|       //          "abilities": [ | ||||
|       //            "MainAbility" | ||||
|       //          ], | ||||
|       //          "when": "always" | ||||
|       //        } | ||||
|       //      }, | ||||
|       //      { | ||||
|       //        "name": "ohos.permission.WRITE_MEDIA", | ||||
|       //        "reason": "$string:module_desc", | ||||
|       //        "usedScene": { | ||||
|       //          "abilities": [ | ||||
|       //            "MainAbility" | ||||
|       //          ], | ||||
|       //          "when": "always" | ||||
|       //        } | ||||
|       //      }, | ||||
|       { | ||||
|         "name": "ohos.permission.FILE_ACCESS_MANAGER", | ||||
|         "reason": "$string:module_desc", | ||||
| @ -135,7 +117,6 @@ | ||||
|       { | ||||
|         "name": "ohos.permission.STORAGE_MANAGER" | ||||
|       }, | ||||
| 
 | ||||
|       { | ||||
|         "name": "ohos.permission.GET_BUNDLE_INFO_PRIVILEGED", | ||||
|         "reason": "$string:module_desc", | ||||
| @ -145,7 +126,7 @@ | ||||
|           ], | ||||
|           "when": "always" | ||||
|         } | ||||
|       } | ||||
|       }, | ||||
|     ] | ||||
|   } | ||||
| } | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user