選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

deviceInfo.vue 17KB

6ヶ月前
6ヶ月前
6ヶ月前
6ヶ月前
6ヶ月前
1年前
1年前
1年前
6ヶ月前
6ヶ月前
6ヶ月前
6ヶ月前
1年前
1年前
8ヶ月前
1年前
6ヶ月前
6ヶ月前
6ヶ月前
6ヶ月前
6ヶ月前
6ヶ月前
6ヶ月前
6ヶ月前
6ヶ月前
6ヶ月前
6ヶ月前
1年前
8ヶ月前
1年前
8ヶ月前
7ヶ月前
1年前
3ヶ月前
1年前
1年前
6ヶ月前
1年前
6ヶ月前
1年前
9ヶ月前
9ヶ月前
6ヶ月前
6ヶ月前
6ヶ月前
6ヶ月前
3ヶ月前
6ヶ月前
7ヶ月前
7ヶ月前
7ヶ月前
7ヶ月前
7ヶ月前
5ヶ月前
6ヶ月前
7ヶ月前
6ヶ月前
7ヶ月前
6ヶ月前
5ヶ月前
6ヶ月前
5ヶ月前
7ヶ月前
1年前
1年前
7ヶ月前
7ヶ月前
9ヶ月前
7ヶ月前
8ヶ月前
9ヶ月前
1年前
9ヶ月前
1年前
9ヶ月前
1年前
6ヶ月前
9ヶ月前
1年前
6ヶ月前
1年前
6ヶ月前
1年前
6ヶ月前
1年前
8ヶ月前
8ヶ月前
8ヶ月前
8ヶ月前
8ヶ月前
8ヶ月前
8ヶ月前
8ヶ月前
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574
  1. <template>
  2. <view class="wrapper">
  3. <view class="info-card">
  4. <view class="title">卡信息</view>
  5. <view class="cell">
  6. <view class="cell-left">卡号</view>
  7. <view class="cell-right">{{ card.cardNo }}</view>
  8. </view>
  9. <view class="cell">
  10. <view class="cell-left">用户姓名</view>
  11. <view class="cell-right">{{ card.userNameStr }}</view>
  12. </view>
  13. <view class="cell">
  14. <view class="cell-left">身份证号</view>
  15. <view class="cell-right">{{ card.idNumStr }}</view>
  16. </view>
  17. <view class="cell">
  18. <view class="cell-left">车辆类型</view>
  19. <view class="cell-right">{{ card.typeStr }}</view>
  20. </view>
  21. <view class="cell">
  22. <view class="cell-left">车牌号</view>
  23. <view class="cell-right">{{ card.vehiclePlate }}</view>
  24. </view>
  25. <view class="cell">
  26. <view class="cell-left">车牌颜色</view>
  27. <view class="cell-right">{{ card.colorStr }}</view>
  28. </view>
  29. <view class="cell">
  30. <view class="cell-left">启用时间</view>
  31. <view class="cell-right">{{ card.startTime }}</view>
  32. </view>
  33. <view class="cell">
  34. <view class="cell-left">结束时间</view>
  35. <view class="cell-right">{{ card.endTime }}</view>
  36. </view>
  37. <view class="cell">
  38. <view class="cell-left">卡签绑定</view>
  39. <view class="cell-right">{{ card.favourableStr }}</view>
  40. </view>
  41. <view class="cell">
  42. <view class="cell-left">校验值</view>
  43. <view class="cell-right">{{ card.money }}</view>
  44. </view>
  45. <view class="cell">
  46. <view class="cell-left">版本号</view>
  47. <view class="cell-right">{{ card.version }}</view>
  48. </view>
  49. <view class="cell" v-if="state.cardStatus">
  50. <view class="cell-left">卡状态</view>
  51. <view class="cell-right">{{getCodeName('CARD_STATE_TYPE',state.cardStatus)}}</view>
  52. </view>
  53. <view class="cell" v-if="state.cardTypeName">
  54. <view class="cell-left">卡类型</view>
  55. <view class="cell-right">{{state.cardTypeName}}</view>
  56. </view>
  57. </view>
  58. <view class="info-card">
  59. <view class="title">OBU信息</view>
  60. <view class="cell">
  61. <view class="cell-left">obu号</view>
  62. <view class="cell-right">{{ obu.num }}</view>
  63. </view>
  64. <view class="cell">
  65. <view class="cell-left">车辆类型</view>
  66. <view class="cell-right">{{ obu.typeStr }}</view>
  67. </view>
  68. <view class="cell">
  69. <view class="cell-left">车辆用户类型</view>
  70. <view class="cell-right">{{ obu.userTypeStr }}</view>
  71. </view>
  72. <view class="cell">
  73. <view class="cell-left">车牌号</view>
  74. <view class="cell-right">{{ obu.vehiclePlate }}</view>
  75. </view>
  76. <view class="cell">
  77. <view class="cell-left">车牌颜色</view>
  78. <view class="cell-right">{{ obu.vehiclePlateColorStr }}</view>
  79. </view>
  80. <view class="cell">
  81. <view class="cell-left">核定载人数</view>
  82. <view class="cell-right">{{ obu.approvedCount }}</view>
  83. </view>
  84. <view class="cell">
  85. <view class="cell-left">车辆识别代号</view>
  86. <view class="cell-right">{{ obu.vin }}</view>
  87. </view>
  88. <view class="cell">
  89. <view class="cell-left">车牌发动机号</view>
  90. <view class="cell-right">{{ obu.engineNum }}</view>
  91. </view>
  92. <view class="cell">
  93. <view class="cell-left">车轴数</view>
  94. <view class="cell-right">{{ obu.axleCount }}</view>
  95. </view>
  96. <view class="cell">
  97. <view class="cell-left">车轮数</view>
  98. <view class="cell-right">{{ obu.wheelCount }}</view>
  99. </view>
  100. <view class="cell">
  101. <view class="cell-left">轴距</view>
  102. <view class="cell-right">{{ obu.axleDistance }}</view>
  103. </view>
  104. <view class="cell">
  105. <view class="cell-left">外廓尺寸</view>
  106. <view class="cell-right">{{ obu.outsideDimensions }}mm</view>
  107. </view>
  108. <view class="cell">
  109. <view class="cell-left">启用时间</view>
  110. <view class="cell-right">{{ obu.startTime }}</view>
  111. </view>
  112. <view class="cell">
  113. <view class="cell-left">结束时间</view>
  114. <view class="cell-right">{{ obu.endTime }}</view>
  115. </view>
  116. <view class="cell">
  117. <view class="cell-left">是否激活</view>
  118. <view class="cell-right">{{ obu.isJHStr }}</view>
  119. </view>
  120. <view class="cell">
  121. <view class="cell-left">拆卸状态</view>
  122. <view class="cell-right">{{obu.loadStatus=='01'?'正常':'已拆卸'}}</view>
  123. </view>
  124. <view class="cell">
  125. <view class="cell-left">版本号</view>
  126. <view class="cell-right">{{ obu.version }}</view>
  127. </view>
  128. <view class="cell" v-if="state.obuStatus">
  129. <view class="cell-left">签状态</view>
  130. <view class="cell-right">{{getCodeName('OBU_STATE_TYPE',state.obuStatus)}}</view>
  131. </view>
  132. </view>
  133. <view class="btn" @click="back">返回</view>
  134. </view>
  135. </template>
  136. <script setup>
  137. import {
  138. getCodeName
  139. } from "@/datas/queryKey.js";
  140. import {
  141. reactive
  142. } from "vue";
  143. import {
  144. onLoad,
  145. onUnload
  146. } from "@dcloudio/uni-app";
  147. import {
  148. requestNew
  149. } from "@/utils/network/request";
  150. import {cardObuQuery,obuFileDataDecrypt,cardObuQueryinLog} from "@/utils/network/api";
  151. import {
  152. getVehicleType
  153. } from "@/subpackage/after-sale/js/vehicleType.js"
  154. import {
  155. getVehiclePlateColor
  156. } from "@/datas/vehiclePlateColor.js"
  157. import {
  158. decryptCardVehicleInformation
  159. } from "@/datas/publicRequest";
  160. const cmd = require("../../../static/etcUtil/cmdConfig.js");
  161. const tools = require("../../../static/etcUtil/tools.js");
  162. const datas = require("../../../static/etcUtil/datas.js");
  163. const bluetoothUtil = require("../../../static/etcUtil/index.js");
  164. const card = reactive({
  165. cardNo: "",
  166. startTime: "",
  167. endTime: "",
  168. userName: "",
  169. userNameStr:"",
  170. idNum: "",
  171. idNumStr:"",
  172. vehiclePlate: "",
  173. vehiclePlateColor: "",
  174. color: "",
  175. colorStr:"",
  176. version: "",
  177. type: "",
  178. typeStr:"",
  179. favourable: "",
  180. favourableStr:"",
  181. money: "",
  182. v_userType: ""
  183. })
  184. const obu = reactive({
  185. num: "",
  186. startTime: "",
  187. endTime: "",
  188. version: "",
  189. approvedCount: "",
  190. axleCount: "",
  191. axleDistance: "",
  192. engineNum: "",
  193. type: "",
  194. typeStr:"",
  195. userType: "",
  196. userTypeStr:"",
  197. vehiclePlate: "",
  198. vehiclePlateColor: "",
  199. vehiclePlateColorStr:"",
  200. vin: "",
  201. wheelCount: "",
  202. isJH: "",
  203. isJHStr: "",
  204. outsideDimensions: "",
  205. loadStatus:""
  206. })
  207. const state = reactive({
  208. vehicleId: "",
  209. obuStatus: "",
  210. cardStatus: "",
  211. cardTypeName: "",
  212. backIndex:""
  213. })
  214. onLoad((option) => {
  215. state.backIndex=option.backIndex
  216. getCardId()
  217. })
  218. /**
  219. * 获取卡号
  220. */
  221. const getCardId = () => {
  222. //执行0015文件
  223. tools.showLoadingAlert("执行指令");
  224. // var arr=['00A40000023F00','00A40000021001','0020000006313233343536','00B201C400','00B202C400','00B203C400','00B204C400','00B205C400','00B206C400','00B207C400','00B208C400','00B209C400','00B20aC400','00B20bC400','00B20cC400','00B20dC400','00B20eC400','00B20fC400','00B210C400','00B211C400','00B212C400','00B213C400','00B214C400','00B215C400','00B216C400','00B217C400','00B218C400','00B219C400','00B21aC400','00B21bC400','00B21cC400','00B21dC400','00B21eC400','00B21fC400','00B220C400','00B221C400','00B222C400','00B223C400','00B224C400','00B225C400','00B226C400','00B227C400','00B228C400','00B229C400','00B22aC400','00B22bC400','00B22cC400','00B22dC400','00B22eC400','00B22fC400','00B230C400','00B231C400','00B232C400']
  225. // console.log("通行流水进来")
  226. // var arr = ['00A40000023F00','00A40000021001','0020000006313233343536','00B201C400','00B202C400',]
  227. // bluetoothUtil.transCmd(arr, '10', function(res) { //10:写卡 20:写OBU
  228. // console.log("通行流水出来",res)
  229. // })
  230. // return;
  231. let cmdArr = [cmd.HOME_DIRECTORY, cmd.APPLICATION_DIRECTORY, cmd.CMD_READBINARY, cmd.CMD_GETBALANCE];
  232. console.log(cmdArr);
  233. console.log(bluetoothUtil);
  234. bluetoothUtil.transCmd(cmdArr, '10', function(res) { //10:写卡 20:写OBU
  235. console.log("5201",res)
  236. let str = res[2].substring(res[2].length - 4, res[2].length); //判断是否为9000
  237. let str3 = res[3].substring(res[3].length - 4, res[3].length); //判断是否为9000
  238. if (str == "9000" || str3 == "9000") {
  239. if (res[2].length > 86 || res[3] >= 12) {
  240. console.log("res[2]", res[2].substring(84, 86), getVehiclePlateColor(parseInt(res[2]
  241. .substring(82, 84), 16)), res[2].substring(18, 19))
  242. card.cardNo = res[2].substring(20, 40);
  243. card.startTime = res[2].substring(40, 48);
  244. card.endTime = res[2].substring(48, 56);
  245. card.version = res[2].substring(18, 20);
  246. card.money = res[3].substring(0, 8);
  247. card.v_userType = parseInt(res[2].substring(80, 82), 16);
  248. console.log("card.v_userType", card.v_userType)
  249. decryptCardVehicleInformation(res[2].substring(56, 80), function (res) {
  250. card.vehiclePlate =res;
  251. });
  252. console.log("res[2].substring(18, 19)",res[2].substring(18, 20))
  253. if (res[2].substring(18, 19) >= 4) {
  254. //4x卡
  255. card.type = parseInt(res[2].substring(84, 86), 16);
  256. card.typeStr = getVehicleType(parseInt(res[2].substring(84, 86), 16));
  257. card.color = parseInt(res[2].substring(82, 84), 16)
  258. card.colorStr = getVehiclePlateColor(parseInt(res[2].substring(82, 84), 16))
  259. } else {
  260. //2x卡--获取车牌颜色
  261. card.type = "--";
  262. card.color =parseInt(res[2].substring(82, 84), 16)
  263. card.colorStr = getVehiclePlateColor(parseInt(res[2].substring(82, 84), 16))
  264. }
  265. state.vehicleId = card.vehiclePlate + "_" + parseInt(res[2].substring(82, 84), 16)
  266. // 读卡信息
  267. // getCardList()
  268. //执行0016文件
  269. let arr = [cmd.HOME_DIRECTORY, cmd.PERSONAL_INFORMATION]
  270. bluetoothUtil.transCmd(arr, '10', function(res) {
  271. let str2 = res[1].substring(res[1].length - 4, res[1].length);
  272. if (str2 == "9000") {
  273. if (res[1].length > 108) {
  274. console.log("res====",res)
  275. decryptCardVehicleInformation(res[1].substring(4, 44), function (res) {
  276. card.userName = res; //姓名
  277. card.userNameStr = card.userName[0] + '*'.repeat(card.userName.length - 1)
  278. });
  279. decryptCardVehicleInformation(res[1].substring(44, 108), function (res) {
  280. card.idNum = res; //身份证号码
  281. card.idNumStr=res.replace(/^\d{14}/,'**************')
  282. });
  283. //获取是否有优惠
  284. let cmdArr3 = [cmd.HOME_DIRECTORY, cmd.APPLICATION_DIRECTORY, cmd
  285. .CMD_00B08E0000
  286. ];
  287. bluetoothUtil.transCmd(cmdArr3, '10', function(res) {
  288. let str3 = res[2].substring(res[2].length - 4, res[2]
  289. .length);
  290. if (str3 == "9000") {
  291. if (res[2].length > 131) {
  292. let _str = parseInt(res[2].substring(129, 130),
  293. 16);
  294. card.favourable=_str
  295. switch (_str) {
  296. case 0:
  297. card.favourableStr = "否";
  298. break;
  299. case 1:
  300. card.favourableStr = "是";
  301. break;
  302. default:
  303. card.favourableStr = '未知' + "_" + _str;
  304. break;
  305. }
  306. //回调读取OBU指令
  307. getObuId()
  308. tools.hideLoadingAlert();
  309. } else {
  310. alertF("CMD_00B08E0000指令长度不符" + res[2]);
  311. }
  312. return;
  313. }
  314. alertF(cmd.PERSONAL_INFORMATION + "_" + str);
  315. })
  316. } else {
  317. alertF("PERSONAL_INFORMATION指令长度不符" + res[1]);
  318. }
  319. return;
  320. }
  321. alertF("PERSONAL_INFORMATION指令长度不符" + res[1]);
  322. })
  323. } else {
  324. alertF("CMD_READBINARY指令长度不符" + res[2]);
  325. }
  326. return;
  327. }
  328. alertF("CMD_READBINARY指令长度不符" + res[2]);
  329. })
  330. };
  331. /**
  332. * 获取OBU号
  333. */
  334. const getObuId = () => {
  335. tools.showLoadingAlert("执行指令");
  336. let cmdArr = [cmd.HOME_DIRECTORY, cmd.OBU_SYSTEM_FILE];
  337. bluetoothUtil.transCmd(cmdArr, '20', function(res) {
  338. let str = res[1].substring(res[1].length - 4, res[1].length);
  339. if (str == "9000") {
  340. if (res[1].length > 52) {
  341. obu.num = res[1].substring(20, 36);
  342. obu.startTime = res[1].substring(36, 44);
  343. obu.endTime = res[1].substring(44, 52);
  344. obu.version = res[1].substring(18, 20);
  345. obu.isJH = res[1].substring(53, 54)
  346. obu.isJHStr = res[1].substring(53, 54) == "1" ? "是" : res[1].substring(53, 54) == "0" ?
  347. "否" : "其他:" + res[1].substring(53, 54);
  348. obu.loadStatus=res[1].substring(52, 54)=='01'?'正常':'已拆卸',
  349. console.log("开始执行车辆信息识读");
  350. let rand = res[1].substring(18, 20) >= 50?'40':'00';
  351. var arr = [cmd.OBU_DF01, '00B400000A000000000000000045'+ rand];
  352. bluetoothUtil.transCmd(arr, '20', function(res) {
  353. console.log(res);
  354. console.log("开始执行车辆信息识读成功");
  355. let str2 = res[1].substring(res[1].length - 4, res[1].length);
  356. let obuVersion = res[1].substring(18, 20);
  357. let keyIndex = obuVersion > 50 ? '40' : '00';
  358. let reqType = '00';
  359. let proviceCode = '5201';
  360. if (str2 == "9000") {
  361. console.log("===========", obu.num, res[1].substring(0, res[1].length - 4))
  362. decryptObuVehicleInfo(obu.num, res[1].substring(0, res[1].length - 4),
  363. obuVersion, rand, reqType, proviceCode,
  364. function(res) {
  365. obu.approvedCount = res.approvedCount;
  366. obu.axleCount = res.axleCount;
  367. obu.axleDistance = res.axleDistance;
  368. obu.engineNum = res.engineNumber.replace(/\u0000/g, '');
  369. obu.type = res.collectionType;
  370. obu.typeStr = getVehicleType(res.collectionType);
  371. obu.userType = res.userType;
  372. if(res.userType == 0){
  373. obu.userTypeStr = "普通车" ;
  374. }else if(res.userType == 6){
  375. obu.userTypeStr = "公务车" ;
  376. }
  377. obu.vehiclePlate = res.vehiclePlate.replace(/\u0000/g, '');
  378. //获取车牌颜色
  379. obu.vehiclePlateColor = res.vehiclePlateColor;
  380. obu.vehiclePlateColorStr = getVehiclePlateColor(res.vehiclePlateColor);
  381. obu.vin = res.vin.replace(/\u0000/g, '');
  382. obu.wheelCount = res.wheelsCount;
  383. obu.outsideDimensions = res.carLong + "x" + res.carWidth + "x" + res.carHeight
  384. getObuList();
  385. tools.hideLoadingAlert();
  386. });
  387. //断开蓝牙
  388. bluetoothUtil.disconnectDevice();
  389. tools.showToastAlert("蓝牙已断开");
  390. console.log('蓝牙已断开=========')
  391. return;
  392. }
  393. alertF("OBU_00B400000A+rand+OBU_4F00指令长度不符" + res[1]);
  394. })
  395. } else {
  396. alertF("OBU_SYSTEM_FILE指令长度不符" + res[1]);
  397. }
  398. return;
  399. }
  400. alertF("OBU_SYSTEM_FILE指令长度不符" + res[1]);
  401. })
  402. };
  403. /**
  404. * 解密OBU车辆信息
  405. */
  406. const decryptObuVehicleInfo = (num, data,obuVersion, keyIndex, reqType, proviceCode, func) => {
  407. const options = {
  408. type: 2,
  409. data: {
  410. contractSN: num,
  411. cipherData: data,
  412. reqType: reqType,
  413. keyIndex: keyIndex,
  414. proviceCode: proviceCode
  415. },
  416. method: "POST",
  417. showLoading: true,
  418. };
  419. requestNew(obuFileDataDecrypt, options).then((res) => {
  420. console.log("obuFileDataDecrypt",res)
  421. const data =res
  422. func(data)
  423. });
  424. };
  425. //返回按钮
  426. const back = () => {
  427. uni.$emit("refreshOrder");
  428. if(state.backIndex=="1"){
  429. uni.switchTab({
  430. url: "/pages/index/index"
  431. })
  432. }else{
  433. uni.redirectTo({
  434. url: "/pages/order/order"
  435. })
  436. }
  437. }
  438. //提示对话框
  439. const alertF = (msg) => {
  440. //隐藏加载框
  441. tools.hideLoadingAlert();
  442. //提示对话框
  443. tools.showModalAlert(msg);
  444. }
  445. const getObuList = () => {
  446. var data = {
  447. obuId: obu.num,
  448. cardId:card.cardNo,
  449. };
  450. const options = {
  451. type: 2,
  452. data: data,
  453. method: "POST",
  454. showLoading: true,
  455. };
  456. requestNew(cardObuQuery, options).then((res) => {
  457. tools.hideLoadingAlert();
  458. let result = res;
  459. state.obuStatus = result.obuStatus?result.obuStatus:""
  460. state.cardStatus = result.cardStatus
  461. if (result.cardType == 1 && result.debitType == 1) {
  462. state.cardTypeName = "预存卡"
  463. card['cardTypeName']=3
  464. } else if (result.cardType == 2) {
  465. state.cardTypeName = "储值卡"
  466. card['cardTypeName']=2
  467. } else {
  468. state.cardTypeName = "记账卡"
  469. card['cardTypeName']=1
  470. }
  471. // 卡签提交得信息
  472. card['cardStatus']=result.cardStatus
  473. obu['obuStatus']=result.obuStatus?result.obuStatus:""
  474. cardObuMsgUp()
  475. })
  476. }
  477. // 签信息提交日志记录
  478. const cardObuMsgUp = () => {
  479. var data = {
  480. cardLogInfo: card,
  481. obuLogInfo:obu,
  482. };
  483. const options = {
  484. type: 2,
  485. data: data,
  486. method: "POST",
  487. showLoading: true,
  488. };
  489. requestNew(cardObuQueryinLog, options).then((res) => {
  490. tools.hideLoadingAlert();
  491. console.log("提交成功")
  492. })
  493. }
  494. </script>
  495. <style scoped>
  496. .wrapper {
  497. padding-bottom: 50rpx;
  498. background: #E9EDF0;
  499. overflow: hidden;
  500. }
  501. .info-card {
  502. margin: 30rpx;
  503. border-radius: 16rpx;
  504. padding-bottom: 40rpx;
  505. background-color: white;
  506. padding: 0 30rpx;
  507. box-sizing: border-box;
  508. }
  509. .info-card .title {
  510. padding: 30rpx 0;
  511. font-size: 36rpx;
  512. text-align: center;
  513. color: #01243A;
  514. }
  515. .info-card .cell {
  516. display: flex;
  517. flex-direction: row;
  518. padding: 18rpx 0rpx;
  519. font-size: 30rpx;
  520. border-bottom: 1rpx solid #E6E9EB;
  521. }
  522. .cell-left {
  523. flex: 1;
  524. text-align: left;
  525. color: #6C6C6C;
  526. }
  527. .cell-right {
  528. margin-left: 30rpx;
  529. text-align: right;
  530. color: #111111;
  531. overflow: hidden;
  532. }
  533. .btn {
  534. background: linear-gradient(to right,#01243A,#004576);
  535. opacity: 1;
  536. border-radius: 100rpx;
  537. color: #fff;
  538. font-size: 30rpx;
  539. height: 80rpx;
  540. line-height: 80rpx;
  541. box-shadow: 0rpx 4rpx 11rpx 1rpx rgba(223, 223, 223, 0.5);
  542. width: 670rpx;
  543. margin: 40rpx;
  544. text-align: center;
  545. }
  546. </style>