signContract.vue 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940
  1. <template>
  2. <view class="content">
  3. <!-- <view class="content1">
  4. <view style='width:70px'>付款方式</view>
  5. <u-radio-group v-model="dataDetails.advanceFreightService" placement="row">
  6. <u-radio :customStyle="radioCustomStyle" v-for="(item, index) in radiolist1" :key="index"
  7. :label="item.name" :name="item.name" @change="radioChange">
  8. </u-radio>
  9. </u-radio-group>
  10. </view> -->
  11. <view class="content2">
  12. <view class="flex">
  13. <view class="title">合同摘要</view>
  14. <view class="preview" @click="submit(1)">预览合同</view>
  15. </view>
  16. <view class='row-between'>
  17. <view class="gray">发货单位</view>
  18. <view class="">{{dataDetails.compName?dataDetails.compName:'个人货主'}}</view>
  19. </view>
  20. <view class='row-between'>
  21. <view class="gray">发货地</view>
  22. <view class="place">
  23. {{dataDetails.sendPrivate}}{{dataDetails.sendCity}}{{dataDetails.sendArea}}{{dataDetails.sendDetailedAddress}}
  24. </view>
  25. </view>
  26. <view class='row-between'>
  27. <view class="gray">卸货地</view>
  28. <view class=" place">
  29. {{dataDetails.unloadPrivate}}{{dataDetails.unloadCity}}{{dataDetails.unloadArea}}{{dataDetails.unloadDetailedAddress}}
  30. </view>
  31. </view>
  32. <view class='row-between'>
  33. <view class="gray">货名</view>
  34. <view class="">{{dataDetails.goodsName}}</view>
  35. </view>
  36. <view class='row-between'>
  37. <view class="gray">距离</view>
  38. <view class="">约{{dataDetails.distance}}公里</view>
  39. </view>
  40. <view class='row-between'>
  41. <!-- 后加 -->
  42. <view class="gray">服务费(元)</view>
  43. <view class="">{{dataDetails.serviceCharge}}</view>
  44. </view>
  45. <view class="title">
  46. 完善信息
  47. </view>
  48. <view class='row-between'>
  49. <view class="gray">运费(元/车)</view>
  50. <!-- <view class="">{{dataDetails.freight}}{{dataDetails.illingMethod==0?'元/吨':'元/车'}}</view> -->
  51. <!-- <view class="flex"><input type="text" placeholder="请输入运费" v-model="dataDetails.freight"
  52. class="text-align-right yf-input">{{dataDetails.freight}}元/车</view> -->
  53. <view class="flex">
  54. <u--input placeholder="请输入运费" border="none" type="number" v-model="dataDetails.freight1"
  55. inputAlign='right' clearable @input="preMoney"></u--input>
  56. <!-- <span> 元/车</span> -->
  57. </view>
  58. </view>
  59. <view class='row-between'>
  60. <view class="gray">车牌号</view>
  61. <view class="" :style="{'color':dataDetails.carrierInfo.carNo?'#000':':#BBBBBB'}" @click="carClick">
  62. {{dataDetails.carrierInfo.carNo?dataDetails.carrierInfo.carNo:'请选择车牌号'}}
  63. <!--< u--input placeholder="请输入车牌号" border="none" readOnly v-model="dataDetails.carrierInfo.carNo"
  64. inputAlign='right' clearable></u--input> -->
  65. </view>
  66. <!-- <view class="flex">
  67. <input class="" v-model='dataDetails.carrierInfo.carNo' @click.stop="handleShowKeyboard"
  68. :disabled="true" placeholder="输入车牌号" name="input" style="text-align: right;"></input>
  69. </view> -->
  70. </view>
  71. <view class='row-between'>
  72. <view class="gray">挂车号(选填)</view>
  73. <view class="flex">
  74. <view :style="{'color':dataDetails.trailerNumber?'#000':':#BBBBBB'}">{{dataDetails.trailerNumber?dataDetails.trailerNumber:'请输入挂车号'}}</view>
  75. <!-- <u--input placeholder="请输入挂车号" border="none" readOnly v-model="dataDetails.trailerNumber"
  76. inputAlign='right' clearable></u--input> -->
  77. </view>
  78. </view>
  79. <view class='row-between'>
  80. <view class="gray">装车净重(吨)</view>
  81. <view class="flex">
  82. <u--input placeholder="请输入装车净重" border="none" v-model="dataDetails.weight" inputAlign='right'
  83. clearable></u--input>
  84. </view>
  85. </view>
  86. <view class='row-between'>
  87. <view class="gray">运输开始日期</view>
  88. <view class="">
  89. <view @click="dateShow">{{dataDetails.tranStartDate?dataDetails.tranStartDate:'请选择运输开始日期'}}
  90. </view>
  91. <u-calendar :show="startShow" mode="single" @confirm="startDate" @close="startShow= false">
  92. </u-calendar>
  93. </view>
  94. </view>
  95. <view class='row-between'>
  96. <view class="gray">运输截止日期</view>
  97. <view class="">
  98. <!-- <u--input placeholder="请输入内容" border="none" v-model="dataDetails.value" inputAlign='right'
  99. clearable></u--input> -->
  100. <view class="" @click="endShow = true">
  101. {{dataDetails.tranEndDate?dataDetails.tranEndDate:'请选择运输截止日期'}}
  102. </view>
  103. <u-calendar :show="endShow" mode="single" @confirm="endDate" @close="endShow= false"></u-calendar>
  104. </view>
  105. </view>
  106. <view class='row-between'>
  107. <view class="gray">联络人姓名</view>
  108. <view class="">
  109. <u--input placeholder="请输入联络人姓名" border="none" v-model="dataDetails.driverName" inputAlign='right'
  110. clearable></u--input>
  111. </view>
  112. </view>
  113. <view class='row-between'>
  114. <view class="gray">联络人电话</view>
  115. <view class="">
  116. <u--input placeholder="请输入联络人电话" border="none" type="number" maxlength="11"
  117. v-model="dataDetails.driverPhone" inputAlign='right' clearable></u--input>
  118. </view>
  119. </view>
  120. <view class='row-between'>
  121. <view class="gray">装车后预付款</view>
  122. <view class="">
  123. <u--input placeholder="自动获取,不可编辑" v-if="dataDetails.freightAdvance == 1" border="none"
  124. v-model="dataDetails.advanceCharge" inputAlign='right' clearable disabled></u--input>
  125. <u--input placeholder="请输入装车后预付款" v-else border="none" v-model="dataDetails.advanceCharge"
  126. inputAlign='right' clearable></u--input>
  127. </view>
  128. </view>
  129. <view class='row-between'>
  130. <view style='width:200px;' class="gray">收款账户</view>
  131. <view style='word-wrap:break-word;word-break:normal;' class="" @click="collection">
  132. {{dataDetails.bankDeposit?dataDetails.bankDeposit:"请选择收款账户"}}
  133. (尾号{{dataDetails.bankCard?dataDetails.bankCard.substring(dataDetails.bankCard.length - 4):""}})
  134. </view>
  135. </view>
  136. </view>
  137. <view class="wrapper content3">
  138. <view class="qm-row">
  139. <view class="handTitle">手写签名</view>
  140. <image src="@/static/xiangpica@2x.png" mode="widthFix" @click="retDraw" class="retDraw-image"></image>
  141. <!-- <button @click="retDraw" class="delBtn">重写</button> -->
  142. </view>
  143. <view class="handCenter">
  144. <canvas class="handWriting" :disable-scroll="true" @touchstart="uploadScaleStart"
  145. @touchmove="uploadScaleMove" canvas-id="handWriting"></canvas>
  146. </view>
  147. <view class="handRight">
  148. </view>
  149. <view class="handBtn">
  150. <!-- <image @click="selectColorEvent('black','#1A1A1A')"
  151. :src="selectColor === 'black' ? '/static/other/color_black_selected.png' : '/static/other/color_black.png'"
  152. :class="[selectColor === 'black' ? 'color_select' : '', 'black-select']"></image>
  153. <image @click="selectColorEvent('red','#ca262a')"
  154. :src="selectColor === 'red' ? '/static/other/color_red_selected.png' : '/static/other/color_red.png'"
  155. :class="[selectColor === 'red' ? 'color_select' : '', 'black-select']"></image> -->
  156. <!-- <button @click="saveCanvasAsImg" class="saveBtn">保存</button> -->
  157. <view @click="$u.throttle(submit(), 5000)" class="saveBtn">提交</view>
  158. <!-- <button @click="previewCanvasImg" class="previewBtn">预览</button> -->
  159. <!-- <button @click="subCanvas" class="subBtn">完成</button> -->
  160. </view>
  161. </view>
  162. <u-picker :show="showCarList" :columns="carList" :closeOnClickOverlay='true' @close='selectTypeClose'
  163. @cancel='selectTypeClose' @confirm='confirmBtn'></u-picker>
  164. <master-keyboard ref="keyboard" keyboardtype="car" :show="keyShow" :randomNumber="true" :newCar="false"
  165. :defaultValue="carNumber" @keyboardClick="handleClick"></master-keyboard>
  166. <u-toast ref="uToast"></u-toast>
  167. <u-toast ref="uToast"></u-toast>
  168. </view>
  169. </template>
  170. <script>
  171. import {
  172. mapState
  173. } from 'vuex';
  174. var that;
  175. import uploadImage from '@/components/ossutil/uploadFile.js';
  176. export default {
  177. data() {
  178. return {
  179. showCarList: false,
  180. carList: [],
  181. carlistCopy: [],
  182. keyShow: false,
  183. carNumber: '',
  184. isScaleStart: false,
  185. radioCustomStyle: {
  186. margin: '0 0 0 10rpx'
  187. },
  188. canvasName: 'handWriting',
  189. ctx: "",
  190. startX: null,
  191. startY: null,
  192. canvasWidth: 0,
  193. canvasHeight: 0,
  194. selectColor: 'black',
  195. lineColor: '#1A1A1A', // 颜色
  196. lineSize: 5, // 笔记倍数
  197. value: true,
  198. dataDetails: {
  199. carrierInfo: {
  200. loadingAdvancePayment: ''
  201. },
  202. serviceCharge: '50'
  203. },
  204. radiolist1: [{
  205. name: '平台垫付运费',
  206. disabled: false
  207. },
  208. {
  209. name: '无需平台垫付运费',
  210. disabled: false
  211. },
  212. ],
  213. startShow: false,
  214. endShow: false,
  215. contractCheck: false, //判断合同是否提交
  216. proportion: "", //垫付比例
  217. };
  218. },
  219. computed: {
  220. ...mapState(['hasLogin', 'userInfo', 'firstAuthentication']),
  221. },
  222. onShow() {
  223. let payInfo = uni.getStorageSync("payInfo")
  224. if (payInfo) {
  225. this.dataDetails.bankCard = payInfo.bankCard
  226. this.dataDetails.bankDeposit = payInfo.bankDeposit
  227. this.dataDetails.bankDepositBranch = payInfo.bankDepositBranch
  228. this.dataDetails.payeeName = payInfo.payeeName
  229. } else {
  230. this.$request.baseRequest('get', '/driverPayeeInfo/getDriverPayee', {
  231. commonId: that.firstAuthentication.commonId
  232. }).then(res => {
  233. if (res.data) {
  234. this.dataDetails.bankCard = res.data.bankCard
  235. this.dataDetails.bankDeposit = res.data.bankDeposit
  236. this.dataDetails.bankDepositBranch = res.data.bankDepositBranch
  237. this.dataDetails.payeeName = res.data.payeeName
  238. }
  239. })
  240. }
  241. this.$request.baseRequest('get', '/commonUser/getSignatureAddress', {
  242. phone: this.userInfo.phone,
  243. identification: 1
  244. }).then(res => {
  245. if (res.data) {
  246. if (res.data.signImg) {
  247. // 获取远程图片,canvas无法直接绘制远程图片
  248. this.userInfo.signImg = res.data.signImg
  249. uni.getImageInfo({
  250. src: res.data.signImg,
  251. success(res) {
  252. var ctx = uni.createCanvasContext('handWriting')
  253. ctx.drawImage(res.path, 0, 0, 330, 244)
  254. ctx.save()
  255. ctx.draw()
  256. }
  257. })
  258. }
  259. }
  260. })
  261. console.log(this.dataDetails)
  262. if (this.dataDetails.carNumber) {
  263. this.$set(this.dataDetails.carrierInfo, 'carNo', this.dataDetails.carNumber)
  264. }
  265. this.preMoney()
  266. // this.$set(this.dataDetails,'advanceCharge',this.dataDetails.advanceCharge)
  267. // this.$set(this.dataDetails.carrierInfo,'carNo',this.dataDetails.carNo)
  268. console.log(this.dataDetails)
  269. },
  270. onLoad(options) {
  271. this.carList = []
  272. that = this
  273. // this.dataDetails = JSON.parse(options.obj)
  274. this.dataDetails = JSON.parse(options.obj)
  275. if(this.dataDetails.billingMethod==1){
  276. this.dataDetails.freight1=this.dataDetails.freight
  277. }else{
  278. this.dataDetails.freight1=''
  279. }
  280. // console.log(this.dataDetails.carNo,this.dataDetails.carrierInfo)
  281. // this.dataDetails.advanceFreightService = '平台垫付运费'
  282. this.dataDetails = JSON.parse(decodeURIComponent(options.obj))
  283. if (this.dataDetails.hyCarrierInfo) {
  284. this.dataDetails.weight = this.dataDetails.hyCarrierInfo.loadingWeight
  285. }
  286. if (this.dataDetails.freightAdvance == 1) {
  287. this.proportion = this.dataDetails.driverAdvancePayment >= this.dataDetails.ownerAdvancePayment ? this
  288. .dataDetails.ownerAdvancePayment : this.dataDetails.driverAdvancePayment
  289. }
  290. // console.log(this.dataDetails)
  291. this.dataDetails.carrierInfo = {}
  292. this.ctx = uni.createCanvasContext("handWriting");
  293. this.$nextTick(() => {
  294. uni.createSelectorQuery().select('.handCenter').boundingClientRect(rect => {
  295. this.canvasWidth = rect.width;
  296. this.canvasHeight = rect.height;
  297. /* 将canvas背景设置为 白底,不设置 导出的canvas的背景为透明 */
  298. this.setCanvasBg('#fff');
  299. })
  300. .exec();
  301. });
  302. uni.showLoading({
  303. title: '加载中'
  304. })
  305. this.$request.baseRequest('get', '/driverCarInfo/selectDriverCar', {
  306. // driverId: that.userInfo.driverId,
  307. commonId: this.userInfo.id
  308. }).then(res => {
  309. if (res.code == '200') {
  310. uni.hideLoading()
  311. if (res.data.length > 0) {
  312. let _list = []
  313. for (let i = 0; i < res.data.length; i++) {
  314. if (res.data[i].status == '已通过') {
  315. _list.push(res.data[i].carNumber)
  316. }
  317. }
  318. that.carlistCopy = res.data
  319. that.carList = [_list]
  320. }
  321. } else {
  322. uni.$u.toast(res.message);
  323. }
  324. })
  325. .catch(res => {
  326. uni.$u.toast(res.message);
  327. });
  328. },
  329. methods: {
  330. preMoney() {
  331. if (this.dataDetails.freightAdvance == 1) {
  332. this.dataDetails.advanceCharge = this.dataDetails.freight1 * this.proportion
  333. }
  334. },
  335. collection() {
  336. uni.$u.route('/pages/order/bankCard');
  337. },
  338. confirmBtn(e) {
  339. this.dataDetails.carrierInfo.carNo = e.value[0]
  340. for (let i = 0; i < this.carlistCopy.length; i++) {
  341. if (e.value[0] == this.carlistCopy[i].carNumber) {
  342. this.dataDetails.trailerNumber = this.carlistCopy[i].guaCarNumber
  343. }
  344. }
  345. this.showCarList = false
  346. },
  347. selectTypeClose() {
  348. this.showCarList = false
  349. },
  350. carClick() {
  351. this.showCarList = true
  352. },
  353. //车牌号弹出键盘
  354. handleShowKeyboard() {
  355. if (!this.dataDetails.carrierInfo.carNo) {
  356. this.carNumber = ''
  357. } else {
  358. this.carNumber = this.dataDetails.carrierInfo.carNo
  359. }
  360. if (this.$refs.keyboard.open) {
  361. this.$refs.keyboard.open(false) //true 键盘显示 false 键盘隐藏
  362. } else {
  363. this.$refs.keyboard[0].open(false)
  364. }
  365. if (this.$refs.keyboard.open) {
  366. this.$refs.keyboard.open(true) //true 键盘显示 false 键盘隐藏
  367. } else {
  368. this.$refs.keyboard[0].open(true)
  369. }
  370. },
  371. //车牌号弹出键盘
  372. handleClick(e) {
  373. this.carNumber = e.value
  374. this.dataDetails.carrierInfo.carNo = e.value //键盘输入值
  375. },
  376. dateShow() {
  377. this.startShow = true
  378. },
  379. removeStart() {
  380. this.startShow = false
  381. },
  382. removeEnd() {
  383. this.endShow = false
  384. },
  385. startDate(e) {
  386. this.startShow = false
  387. this.dataDetails.tranStartDate = e[0]
  388. },
  389. endDate(e) {
  390. this.dataDetails.tranEndDate = e[0]
  391. this.endShow = false
  392. },
  393. submit(num) {
  394. this.dataDetails.freight=this.dataDetails.freight1
  395. let _obj = {}
  396. if (num == 1) { //预览合同
  397. _obj.submitFlag = 1
  398. this.contractCheck = false
  399. } else { //提交合同
  400. this.contractCheck = true
  401. _obj.submitFlag = 2
  402. }
  403. if (!that.isScaleStart) {
  404. if (!this.userInfo.signImg) {
  405. that.$refs.uToast.show({
  406. type: 'error',
  407. message: "手写签名不能为空!",
  408. })
  409. return
  410. }
  411. }
  412. if (uni.$u.test.isEmpty(that.dataDetails.carrierInfo.carNo)) {
  413. that.$refs.uToast.show({
  414. type: 'error',
  415. message: "车牌号不能为空!",
  416. })
  417. return
  418. }
  419. if (uni.$u.test.isEmpty(that.dataDetails.weight)) {
  420. that.$refs.uToast.show({
  421. type: 'error',
  422. message: "装车净重不能为空!",
  423. })
  424. return
  425. }
  426. if (uni.$u.test.isEmpty(that.dataDetails.freight)) {
  427. that.$refs.uToast.show({
  428. type: 'error',
  429. message: "运费不能为空!",
  430. })
  431. return
  432. }
  433. if (uni.$u.test.isEmpty(that.dataDetails.tranStartDate)) {
  434. that.$refs.uToast.show({
  435. type: 'error',
  436. message: "运输起始日期不能为空!",
  437. })
  438. return
  439. }
  440. if (uni.$u.test.isEmpty(that.dataDetails.tranEndDate)) {
  441. that.$refs.uToast.show({
  442. type: 'error',
  443. message: "运输截止日期不能为空!",
  444. })
  445. return
  446. }
  447. if (uni.$u.test.isEmpty(that.dataDetails.driverName)) {
  448. that.$refs.uToast.show({
  449. type: 'error',
  450. message: "联络人姓名不能为空!",
  451. })
  452. return
  453. }
  454. if (uni.$u.test.isEmpty(that.dataDetails.driverPhone)) {
  455. that.$refs.uToast.show({
  456. type: 'error',
  457. message: "联络人电话不能为空!",
  458. })
  459. return
  460. }
  461. if (uni.$u.test.isEmpty(that.dataDetails.advanceCharge) && that.dataDetails.advanceCharge != 0) {
  462. that.$refs.uToast.show({
  463. type: 'error',
  464. message: "装车后预付款不能为空!",
  465. })
  466. return
  467. }
  468. if (uni.$u.test.isEmpty(that.dataDetails.bankDeposit)) {
  469. that.$refs.uToast.show({
  470. type: 'error',
  471. message: "收款账号不能为空!",
  472. })
  473. return
  474. }
  475. _obj.trailerNumber = that.dataDetails.trailerNumber
  476. _obj.tranStartDate = that.dataDetails.tranStartDate
  477. _obj.tranEndDate = that.dataDetails.tranEndDate
  478. _obj.contactPersonName = that.dataDetails.driverName
  479. _obj.contactPersonPhone = that.dataDetails.driverPhone
  480. _obj.freightCars = that.dataDetails.freight
  481. // _obj.advanceCharge = that.dataDetails.advanceCharge
  482. _obj.id = that.dataDetails.id
  483. _obj.carNumber = that.dataDetails.carrierInfo.carNo
  484. _obj.weight = that.dataDetails.weight
  485. _obj.advanceCharge = that.dataDetails.advanceCharge
  486. _obj.bankCard = that.dataDetails.bankCard
  487. _obj.bankDeposit = that.dataDetails.bankDeposit
  488. _obj.bankDepositBranch = that.dataDetails.bankDepositBranch
  489. _obj.payeeName = that.dataDetails.payeeName
  490. _obj.typeFlag = 2
  491. uni.canvasToTempFilePath({
  492. canvasId: 'handWriting',
  493. fileType: 'png',
  494. quality: 1, //图片质量
  495. success(res) {
  496. uploadImage('image', res.tempFilePath, 'appData/',
  497. result => {
  498. // 上传成功
  499. that.dataDetails.cargoOwnerAutograph = result
  500. _obj.driverAutograph = result
  501. uni.showLoading({
  502. title: '加载中',
  503. mask: true
  504. })
  505. that.$request.baseRequest('get', '/orderInfo/setPdf', _obj).then(
  506. res => {
  507. if (res.code == 200) {
  508. uni.hideLoading()
  509. that.contractSrc = res.data
  510. uni.downloadFile({
  511. url: res.data,
  512. success: function(res) {
  513. var filePath = res.tempFilePath;
  514. uni.openDocument({
  515. filePath: filePath,
  516. showMenu: true,
  517. success: function(res) {
  518. console.log('打开文档成功');
  519. }
  520. });
  521. }
  522. });
  523. if (that.contractCheck) { //提交
  524. that.$refs.uToast.show({
  525. type: 'success',
  526. message: "提交成功",
  527. complete() {
  528. uni.removeStorageSync(
  529. "payInfo") //如果要有银行卡缓存就删除
  530. uni.$u.route(
  531. '/pages/order/confirmLoading', {
  532. obj: JSON.stringify(that
  533. .dataDetails),
  534. });
  535. // that.upCallback({
  536. // size: 10,
  537. // num: 1
  538. // })
  539. }
  540. })
  541. }
  542. } else {
  543. uni.$u.toast(res.message);
  544. uni.hideLoading()
  545. }
  546. })
  547. .catch(res => {
  548. uni.$u.toast(res.message);
  549. });
  550. }
  551. )
  552. }
  553. });
  554. },
  555. // change(e){
  556. // if(this.value){
  557. // this.$set(this.dataDetails,'advanceFreightService',1)
  558. // }else{
  559. // this.$set(this.dataDetails,'advanceFreightService',0)
  560. // }
  561. // },
  562. // 笔迹开始
  563. uploadScaleStart(e) {
  564. this.isScaleStart = true
  565. this.startX = e.changedTouches[0].x
  566. this.startY = e.changedTouches[0].y
  567. //设置画笔参数
  568. //画笔颜色
  569. this.ctx.setStrokeStyle(this.lineColor)
  570. //设置线条粗细
  571. this.ctx.setLineWidth(this.lineSize)
  572. //设置线条的结束端点样式
  573. this.ctx.setLineCap("round") //'butt'、'round'、'square'
  574. //开始画笔
  575. this.ctx.beginPath()
  576. },
  577. // 笔迹移动
  578. uploadScaleMove(e) {
  579. //取点
  580. let temX = e.changedTouches[0].x
  581. let temY = e.changedTouches[0].y
  582. //画线条
  583. this.ctx.moveTo(this.startX, this.startY)
  584. this.ctx.lineTo(temX, temY)
  585. this.ctx.stroke()
  586. this.startX = temX
  587. this.startY = temY
  588. this.ctx.draw(true)
  589. },
  590. /**
  591. * 重写
  592. */
  593. retDraw() {
  594. this.ctx.clearRect(0, 0, 700, 730);
  595. this.ctx.draw();
  596. //设置canvas背景
  597. this.setCanvasBg('#fff');
  598. },
  599. /**
  600. * @param {Object} str
  601. * @param {Object} color
  602. * 选择颜色
  603. */
  604. selectColorEvent(str, color) {
  605. this.selectColor = str;
  606. this.lineColor = color;
  607. },
  608. //完成
  609. subCanvas() {
  610. uni.canvasToTempFilePath({
  611. canvasId: 'handWriting',
  612. fileType: 'png',
  613. quality: 1, //图片质量
  614. success(res) {
  615. // console.log(res.tempFilePath, 'canvas生成图片地址');
  616. uni.showToast({
  617. title: '以保存'
  618. });
  619. //保存到系统相册
  620. uni.saveImageToPhotosAlbum({
  621. filePath: res.tempFilePath,
  622. success(res) {
  623. uni.showToast({
  624. title: '已成功保存到相册',
  625. duration: 2000
  626. });
  627. }
  628. });
  629. }
  630. });
  631. },
  632. //保存到相册
  633. saveCanvasAsImg() {
  634. uni.canvasToTempFilePath({
  635. canvasId: 'handWriting',
  636. fileType: 'png',
  637. quality: 1, //图片质量
  638. success(res) {
  639. console.log(res.tempFilePath, 'canvas生成图片地址');
  640. uni.saveImageToPhotosAlbum({
  641. filePath: res.tempFilePath,
  642. success(res) {
  643. uni.showToast({
  644. title: '已保存到相册',
  645. duration: 2000
  646. });
  647. }
  648. });
  649. }
  650. });
  651. },
  652. //预览
  653. previewCanvasImg() {
  654. uni.canvasToTempFilePath({
  655. canvasId: 'handWriting',
  656. fileType: 'jpg',
  657. quality: 1, //图片质量
  658. success(res) {
  659. uni.previewImage({
  660. urls: [res.tempFilePath] //预览图片 数组
  661. });
  662. }
  663. });
  664. },
  665. //设置canvas背景色 不设置 导出的canvas的背景为透明
  666. //@params:字符串 color
  667. setCanvasBg(color) {
  668. /* 将canvas背景设置为 白底,不设置 导出的canvas的背景为透明 */
  669. //rect() 参数说明 矩形路径左上角的横坐标,左上角的纵坐标, 矩形路径的宽度, 矩形路径的高度
  670. //这里是 canvasHeight - 4 是因为下边盖住边框了,所以手动减了写
  671. this.ctx.rect(0, 0, this.canvasWidth, this.canvasHeight - 4);
  672. // ctx.setFillStyle('red')
  673. this.ctx.setFillStyle(color);
  674. this.ctx.fill(); //设置填充
  675. this.ctx.draw(); //开画
  676. }
  677. }
  678. };
  679. </script>
  680. <style lang="scss" scoped>
  681. page {
  682. background: #fbfbfb;
  683. height: auto;
  684. }
  685. .content1 {
  686. background: white;
  687. border-radius: 20rpx;
  688. margin: 20rpx;
  689. padding: 30rpx 20rpx;
  690. display: flex;
  691. justify-content: space-between;
  692. .right {
  693. display: flex;
  694. }
  695. }
  696. .content2 {
  697. background: white;
  698. border-radius: 20rpx;
  699. margin: 20rpx;
  700. padding: 30rpx 20rpx;
  701. .title {
  702. font-size: 36rpx;
  703. font-weight: 700;
  704. margin-bottom: 20rpx;
  705. width: 50%;
  706. }
  707. .preview {
  708. width: 50%;
  709. text-align: right;
  710. color: #2772FB;
  711. font-size: 26rpx;
  712. }
  713. .row-between {
  714. margin-bottom: 20rpx;
  715. }
  716. .left-text {
  717. margin-right: 20rpx;
  718. }
  719. .yf-input {
  720. padding-right: 10rpx;
  721. }
  722. }
  723. .content3 {
  724. background: white;
  725. border-radius: 20rpx;
  726. margin: 20rpx;
  727. padding: 30rpx 20rpx;
  728. }
  729. .place {
  730. width: 80%;
  731. text-align: right;
  732. }
  733. .handCenter {
  734. border: 4rpx dashed #e9e9e9;
  735. overflow: hidden;
  736. box-sizing: border-box;
  737. height: 500rpx;
  738. }
  739. .handWriting {
  740. background: #F9F9FB;
  741. width: 100%;
  742. height: 100%;
  743. }
  744. .handRight {
  745. display: inline-flex;
  746. align-items: center;
  747. }
  748. .handCenter {
  749. border: 4rpx dashed #e9e9e9;
  750. flex: 5;
  751. overflow: hidden;
  752. box-sizing: border-box;
  753. }
  754. .handTitle {
  755. font-size: 36rpx;
  756. color: #666;
  757. font-weight: 700;
  758. color: #333333;
  759. margin-bottom: 20rpx;
  760. }
  761. .retDraw-image {
  762. width: 50rpx;
  763. }
  764. .qm-row {
  765. display: flex;
  766. justify-content: space-between;
  767. }
  768. .saveBtn {
  769. width: 80%;
  770. background: #2772FB;
  771. color: white;
  772. text-align: center;
  773. border-radius: 50rpx;
  774. padding: 20rpx;
  775. }
  776. .handBtn {
  777. display: flex;
  778. justify-content: center;
  779. }
  780. /*
  781. .wrapper {
  782. width: 100%;
  783. height: 95vh;
  784. margin: 30rpx 0;
  785. overflow: hidden;
  786. display: flex;
  787. align-content: center;
  788. flex-direction: row;
  789. justify-content: center;
  790. font-size: 28rpx;
  791. }
  792. .handBtn button {
  793. font-size: 28rpx;
  794. }
  795. .handBtn {
  796. height: 95vh;
  797. display: inline-flex;
  798. flex-direction: column;
  799. justify-content: space-between;
  800. align-content: space-between;
  801. flex: 1;
  802. }
  803. .delBtn {
  804. position: absolute;
  805. top: 250rpx;
  806. left: 0rpx;
  807. transform: rotate(90deg);
  808. color: #666;
  809. }
  810. .delBtn image {
  811. position: absolute;
  812. top: 13rpx;
  813. left: 25rpx;
  814. }
  815. .subBtn {
  816. position: absolute;
  817. bottom: 52rpx;
  818. left: -3rpx;
  819. display: inline-flex;
  820. transform: rotate(90deg);
  821. background: #008ef6;
  822. color: #fff;
  823. margin-bottom: 30rpx;
  824. text-align: center;
  825. justify-content: center;
  826. }
  827. .saveBtn {
  828. position: absolute;
  829. top: 375rpx;
  830. left: 0rpx;
  831. transform: rotate(90deg);
  832. color: #666;
  833. }
  834. .previewBtn {
  835. position: absolute;
  836. top: 500rpx;
  837. left: 0rpx;
  838. transform: rotate(90deg);
  839. color: #666;
  840. }
  841. .uploadBtn {
  842. position: absolute;
  843. top: 625rpx;
  844. left: 0rpx;
  845. transform: rotate(90deg);
  846. color: #666;
  847. }
  848. .black-select {
  849. width: 60rpx;
  850. height: 60rpx;
  851. position: absolute;
  852. top: 30rpx;
  853. left: 25rpx;
  854. }
  855. .black-select.color_select {
  856. width: 90rpx;
  857. height: 90rpx;
  858. top: 100rpx;
  859. left: 10rpx;
  860. }
  861. .red-select {
  862. width: 60rpx;
  863. height: 60rpx;
  864. position: absolute;
  865. top: 140rpx;
  866. left: 25rpx;
  867. }
  868. .red-select.color_select {
  869. width: 90rpx;
  870. height: 90rpx;
  871. top: 120rpx;
  872. left: 10rpx;
  873. } */
  874. // /deep/.uni-input-input:disabled {
  875. // background:#fff;
  876. // }
  877. </style>