detail.js 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603
  1. import common from '../../utils/util';
  2. import server from '../../utils/main';
  3. const app = getApp();
  4. var times = 1;
  5. var pageIndex = 0;
  6. var QuestionItem = [];
  7. var tempAnswerList=[];
  8. var arrAnswerID=[];
  9. var isAndroid = false;
  10. const waitTime = ["", "10秒钟", "15秒钟", "20秒钟", "25秒钟"];
  11. Page({
  12. data: {
  13. version: app.globalData.version,
  14. IsShowMenu: false,
  15. filter: 'horizontal',
  16. //filter: 'vertical',
  17. PageNumber: 1,
  18. PageCount: 60,
  19. IsFinished: false,
  20. arrPage: [],
  21. ShowLoading: false,
  22. IsDistabled: "",
  23. NameClass:"",
  24. AddDisabled: "",
  25. SubDisabled: "btnAddSubDisabled",
  26. HelpHidden7:true,
  27. ShowAndroidNotice:false,
  28. },
  29. onLoad: function (options) {
  30. var that = this;
  31. var id = options.id;
  32. isAndroid = false;
  33. if (app.globalData.systemInfo.system && app.globalData.systemInfo.system.indexOf("Android") >= 0)
  34. isAndroid = true;
  35. this.setData({
  36. Containnerheight: server.getWindowHeight(),
  37. ID: id,
  38. ShowAndroidNotice:isAndroid,
  39. });
  40. var systemInfo = wx.getSystemInfoSync();
  41. if (systemInfo.system && systemInfo.system.indexOf("Android") >= 0) {
  42. times = 2;
  43. }
  44. this.getDetail(id);
  45. common.getStorageValue(this, "HelpHidden3", false, function () {
  46. that.showHelp();
  47. });
  48. },
  49. onUnload:function(){
  50. wx.hideLoading();
  51. },
  52. getDetail: function (id) {
  53. var item;
  54. var data = wx.getStorageSync('QuestionTypeList');
  55. for (var i = 0; i < data.length; i++) {
  56. for (var k = 0; k < data[i].List.length; k++) {
  57. if (id == data[i].List[k].ID) {
  58. item = data[i].List[k];
  59. item.Example[0] = item.Example[0].replace("+", " + ").replace("-", " - ").replace("×", " × ").replace("÷", " ÷ ");
  60. item.Example[1] = item.Example[1].replace("+", " + ").replace("-", " - ").replace("×", " × ").replace("÷", " ÷ ");
  61. item.IconName = app.globalData.fileUrl+item.IconName;
  62. if (item.Name.length>12)
  63. item.NameClass="text2";
  64. break;
  65. }
  66. }
  67. }
  68. this.setData({
  69. QuestionTypeItem: item,
  70. });
  71. //有竖式则缺省竖式
  72. if (item.QuestionNumber3 > 0) {
  73. this.menuClick({ currentTarget: { dataset: { id: "vertical" } } })
  74. }
  75. },
  76. gotoAnswer: function (e) {
  77. wx.navigateTo({
  78. url: '../main/answer',
  79. });
  80. this.closeHelp2();
  81. },
  82. getFinish: function () {
  83. this.setData({
  84. ShowLoading: true,
  85. BtnText: "全部保存到相册",
  86. });
  87. wx.hideLoading();
  88. arrAnswerID = [];
  89. tempAnswerList=[];
  90. this.getAnswerID();
  91. this.getList(this.data.ID);
  92. this.closeHelp();
  93. },
  94. //重新生成试卷
  95. ResetFinish:function(){
  96. var that=this;
  97. wx.showLoading({
  98. title:"正在重置",
  99. complete:function(){
  100. var list = that.data.arrPage;
  101. for (var i = 0; i < list.length; i++) {
  102. wx.removeSavedFile({
  103. filePath: list[i].TempImagePath
  104. });
  105. }
  106. that.setData({
  107. arrPage: [],
  108. PageNumber: 1,
  109. });
  110. var tempList = wx.getStorageSync("AnswerList");
  111. for (var i = 0; i < list.length; i++) {
  112. tempList.shift();
  113. }
  114. wx.setStorageSync("AnswerList", tempList);
  115. wx.hideLoading();
  116. that.getFinish();
  117. }
  118. });
  119. },
  120. getList: function (id) {
  121. var that = this;
  122. var pageNum = that.data.PageNumber;
  123. var QuestionTypeCategory = 3;
  124. if (that.data.filter == "horizontal")
  125. QuestionTypeCategory = 2;
  126. pageIndex = 0;
  127. server.getData('GetQuestionTypesPrint?ID=' + id + '&QuestionTypeCategory=' + QuestionTypeCategory + '&PageNum=' + pageNum, function (data) {
  128. //console.log("UserInfo:" + data);
  129. if (data) {
  130. that.setData({
  131. IsFinished: true,
  132. arrPage: [],
  133. IsDistabled: "",
  134. WaitTime: waitTime[that.data.PageNumber],
  135. });
  136. QuestionItem = data;
  137. QuestionItem.IconName = that.data.QuestionTypeItem.IconName;
  138. if (isAndroid) {
  139. console.log("android");
  140. var ctx = wx.createCanvasContext("Canvas", that);
  141. ctx.fillRect(0, 0, 1050, 1485);
  142. ctx.draw(true, function (n) {
  143. wx.canvasToTempFilePath({
  144. x: 0,
  145. y: 0,
  146. width: 2100,
  147. height: 2970,
  148. canvasId: 'Canvas',
  149. success: function (res2) {
  150. that.saveImage();
  151. }
  152. })
  153. });
  154. }
  155. else {
  156. that.saveImage();
  157. }
  158. }
  159. });
  160. },
  161. getAnswerID: function () {
  162. var list = wx.getStorageSync("AnswerList");
  163. var id=1;
  164. if (list && list.length > 0) {
  165. list.sort(function (a, b) {
  166. return b.AnswerID - a.AnswerID;
  167. });
  168. id = list[0].AnswerID + 1;
  169. }
  170. for (var i = 0; i < this.data.PageNumber;i++)
  171. arrAnswerID.push(id+i);
  172. },
  173. saveImage: function () {
  174. var that = this;
  175. var item = QuestionItem;
  176. item.AnswerID = arrAnswerID.shift();
  177. var ctx = wx.createCanvasContext("Canvas", that);
  178. ctx.setTextAlign('left');
  179. ctx.setTextBaseline('top');
  180. ctx.setFontSize(12);
  181. ctx.setFillStyle('white');
  182. ctx.fillRect(0, 0, 2100, 2970);
  183. ctx.fillStyle = "#000000";
  184. var xStart = 60;
  185. var yStart = 247;
  186. var height = 150;
  187. if (item.QuestionTypeCategory == 2)
  188. height = 59;
  189. if (item.PageCount == 18)
  190. height = 210;
  191. else if (item.PageCount == 15)
  192. height = 250;
  193. //括号
  194. var index = 0;
  195. for (var i = 0; i < 3; i++) {
  196. for (var j = 0; j < item.PageCount / 3; j++) {
  197. index++;
  198. ctx.fillText("(", xStart + i * 310, yStart + j * height);
  199. ctx.fillText(")", xStart + i * 310 + 22, yStart + j * height);
  200. }
  201. }
  202. //编号
  203. index = 0;
  204. ctx.setTextAlign('center');
  205. var numberLeft = 12;
  206. if (isAndroid)
  207. numberLeft = 14;
  208. for (var i = 0; i < 3; i++) {
  209. for (var j = 0; j < item.PageCount / 3; j++) {
  210. index++;
  211. ctx.fillText(index, xStart + i * 310 + numberLeft, yStart + j * height);
  212. }
  213. }
  214. //算式
  215. index = that.data.arrPage.length * item.PageCount;
  216. ctx.setFontSize(24);
  217. for (var i = 0; i < 3; i++) {
  218. for (var j = 0; j < item.PageCount / 3; j++) {
  219. index++;
  220. //横式
  221. if (item.QuestionTypeCategory == 2) {
  222. var A = item.QuestionList[index - 1].A.toString();
  223. if (item.QuestionList[index - 1].HiddenColumn == "A")
  224. A = "____";
  225. var OperateAB = item.QuestionList[index - 1].OperateAB.toString();
  226. //console.log(OperateAB);
  227. var B = item.QuestionList[index - 1].B.toString();
  228. if (item.QuestionList[index - 1].HiddenColumn == "B")
  229. B = "____";
  230. var equation = A + " " + OperateAB + " " + B;
  231. if (item.QuestionList[index - 1].C) {
  232. var OperateBC = item.QuestionList[index - 1].OperateBC.toString();
  233. var C = item.QuestionList[index - 1].C.toString();
  234. equation += " " + OperateBC + " " + C;
  235. if (item.QuestionList[index - 1].D) {
  236. var OperateCD = item.QuestionList[index - 1].OperateCD.toString();
  237. var D = item.QuestionList[index - 1].D.toString();
  238. equation += " " + OperateCD + " " + D;
  239. }
  240. }
  241. equation += " = ";
  242. var R = item.QuestionList[index - 1].R.toString();
  243. if (item.QuestionList[index - 1].HiddenColumn == "R")
  244. R = "";
  245. equation += R;
  246. var num = xStart + i * 310 + 31;
  247. for (var n = 0; n < equation.length; n++) {
  248. var len = getLength(equation[n]);
  249. num += len;
  250. if (equation[n] == ".") {
  251. ctx.fillText(equation[n], num + 3, yStart + j * 59-5);
  252. } else {
  253. var h = -8;
  254. if (equation[n] == "_")
  255. h = 0;
  256. ctx.fillText(equation[n], num, yStart + j * 59 + h);
  257. }
  258. }
  259. }
  260. //竖式
  261. else if (item.QuestionTypeCategory == 3) {
  262. var num1 = item.QuestionList[index - 1];
  263. var isAnswer = false;
  264. var width = 250;
  265. if (num1.OperateAB == "÷")
  266. width = 240;
  267. for (var n = 0; n < num1.Vertical.length; n++) {
  268. var num = xStart + i * 310 + width;
  269. var num2=0;
  270. for (var m = num1.Vertical[n].Array.length - 1; m >= 0; m--) {
  271. var str = "";
  272. if (num1.Vertical[n].Type == "line") {
  273. if (num1.OperateAB != "÷") {
  274. //var lineLength = num1.Vertical[n].Array.length * 30 + 20;
  275. var lineLength = 6 * 30 + 20;
  276. var lineTop = 4;
  277. //console.log(yStart + j * height + n * 30 + lineTop);
  278. ctx.moveTo(num, yStart + j * height + n * 30 + lineTop);
  279. ctx.lineTo(num - lineLength, yStart + j * height + n * 30 + lineTop);
  280. ctx.stroke();
  281. isAnswer = true;
  282. break;
  283. }
  284. }
  285. else {
  286. str = num1.Vertical[n].Array[m];
  287. if (num1.OperateAB == "÷" && str == "√") {
  288. isAnswer = true;
  289. var lineLength = num1.A.toString().length;
  290. var lineWidth = Math.floor(57 * (1 + num1.A.toString().length) / 2);
  291. ctx.drawImage("../../images/formula_division_size0" + lineLength + ".png", num - (num1.Vertical[n].Array.length - m) * 30 - 8, yStart + j * height + n * 30-10, lineWidth, 39);
  292. //break;
  293. }
  294. else if (num1.OperateAB == "÷" && n == 0) {
  295. }
  296. else if (num1.OperateAB == "÷" && n == 1) {
  297. ctx.fillText(str, num - (num1.Vertical[n].Array.length - m) * 10, yStart + j * height + n * 30);
  298. }
  299. else {
  300. if (str == ".") {
  301. ctx.fillText(str, num - (num1.Vertical[n].Array.length - m) * 30 + 15, yStart + j * height + n * 30);
  302. num2 = 30;
  303. }
  304. else if (str == "+" || str == "-" || str == "−" || str == "×" || str == "÷") {
  305. var lineLength = 6 * 30 ;
  306. ctx.fillText(str, num - lineLength, yStart + j * height + n * 30);
  307. num2 = 30;
  308. }
  309. else
  310. ctx.fillText(str, num - (num1.Vertical[n].Array.length - m) * 30+num2, yStart + j * height + n * 30);
  311. }
  312. }
  313. }
  314. if (isAnswer)
  315. break;
  316. }
  317. }
  318. }
  319. }
  320. ctx.setTextAlign('left');
  321. ctx.setFontSize(32);
  322. ctx.fillText(item.Name, 60, 45);
  323. ctx.setFontSize(12);
  324. ctx.fillText(item.CagegoryName, 60, 90);
  325. ctx.fillText("共" + item.PageCount + "道题", 60, 125);
  326. ctx.fillText("第 1 / 1 页", 60, 147);
  327. ctx.fillText("答案检索号", 768, 60);
  328. ctx.setTextAlign('right');
  329. ctx.fillText("出题时间 " + item.CreateTime, 875, 94);
  330. ctx.fillText("微信扫一扫 计时看答案", 875, 111);
  331. ctx.fillText("《数学计算题》选题 打印 扫码 批改", 875, 137);
  332. ctx.setFontSize(32);
  333. ctx.fillText(item.AnswerID, 872, 50);
  334. ctx.drawImage("../../images/answer.png", 890, 54, 100, 100);
  335. ctx.draw(true, function (n) {
  336. var w = 1050,
  337. h = 1485;
  338. wx.canvasToTempFilePath({
  339. x: 0,
  340. y: 0,
  341. width: w * times,
  342. height: h * times,
  343. destWidth: w*times,
  344. destHeight: h*times,
  345. canvasId: 'Canvas',
  346. success: function (res2) {
  347. console.log(res2.tempFilePath);
  348. that.data.arrPage.push(res2.tempFilePath);
  349. item.TempImagePath=res2.tempFilePath;
  350. tempAnswerList.push(JSON.parse(JSON.stringify(item)));
  351. that.setData({
  352. arrPage: that.data.arrPage,
  353. });
  354. if (that.data.arrPage.length < that.data.PageNumber) {
  355. pageIndex++;
  356. that.saveImage();
  357. }
  358. else {
  359. //生成图片完成
  360. setTimeout(function(){
  361. that.setData({
  362. ShowLoading: false,
  363. });
  364. wx.pageScrollTo({
  365. scrollTop: 0,
  366. duration: 300
  367. });
  368. // wx.previewImage({
  369. // current: that.data.arrPage[0], // 当前显示图片的http链接
  370. // urls: that.data.arrPage // 需要预览的图片http链接列表
  371. // });
  372. //存列表
  373. var tempList = wx.getStorageSync("AnswerList");
  374. if (!tempList)
  375. tempList = [];
  376. for (var x = 0; x < tempAnswerList.length; x++) {
  377. var tempItem = tempAnswerList[x];
  378. var id = x * tempItem.PageCount;
  379. var arr = [];
  380. for (var y = 0; y < tempItem.QuestionList.length; y++) {
  381. if (y >= id && y < id + tempItem.PageCount) {
  382. arr.push(tempItem.QuestionList[y]);
  383. }
  384. }
  385. tempItem.QuestionList = arr;
  386. tempList.unshift(tempItem);
  387. }
  388. wx.setStorageSync("AnswerList", tempList);
  389. common.getStorageValue(that, "HelpHidden7", false, function () {
  390. that.showHelp2();
  391. });
  392. },3000);
  393. }
  394. }
  395. })
  396. });
  397. function getLength(str) {
  398. switch (str) {
  399. case "0":
  400. case "1":
  401. case "2":
  402. case "3":
  403. case "4":
  404. case "5":
  405. case "6":
  406. case "7":
  407. case "8":
  408. case "9":
  409. return 15;
  410. case ".":
  411. return 8;
  412. default:
  413. return 12;
  414. }
  415. }
  416. },
  417. //保存图片文件
  418. saveImageFile: function () {
  419. if (this.data.IsDistabled == "") {
  420. wx.showLoading({ title: "保存中..." });
  421. var that = this;
  422. var count = 0;
  423. for (var i = 0; i < that.data.arrPage.length; i++) {
  424. wx.saveImageToPhotosAlbum({
  425. filePath: that.data.arrPage[i],
  426. success(res3) {
  427. console.log("save:" + res3.savedFilePath);
  428. count++
  429. if (count == that.data.arrPage.length) {
  430. wx.hideLoading();
  431. wx.showModal({
  432. title: "保存完成",
  433. showCancel: false,
  434. content: "请打开手机相册查看图片!",
  435. });
  436. that.setData({
  437. IsDistabled: "Distabled",
  438. BtnText: "已保存",
  439. });
  440. wx.pageScrollTo({
  441. scrollTop: 400,
  442. duration: 300
  443. });
  444. }
  445. },
  446. fail(err3) {
  447. console.log(err3);
  448. wx.openSetting();
  449. },
  450. complete(){
  451. wx.hideLoading();
  452. }
  453. })
  454. }
  455. }
  456. },
  457. changePageNumber: function (e) {
  458. var id = Number(e.currentTarget.dataset.id);
  459. this.data.PageNumber += id;
  460. var addDisabled="",subDisabled="";
  461. if (this.data.PageNumber <= 1){
  462. this.data.PageNumber = 1;
  463. subDisabled ="btnAddSubDisabled";
  464. }
  465. else if (this.data.PageNumber >= 4){
  466. this.data.PageNumber = 4;
  467. addDisabled = "btnAddSubDisabled";
  468. }
  469. this.setData({
  470. PageNumber: this.data.PageNumber,
  471. AddDisabled: addDisabled,
  472. SubDisabled: subDisabled,
  473. });
  474. },
  475. showImage: function (e) {
  476. var that = this;
  477. var id = e.currentTarget.dataset.id;
  478. wx.previewImage({
  479. current: that.data.arrPage[id], // 当前显示图片的http链接
  480. urls: that.data.arrPage // 需要预览的图片http链接列表
  481. });
  482. },
  483. closeLoading: function () {
  484. var that = this;
  485. that.setData({
  486. ShowLoading: false,
  487. IsFinished: false,
  488. });
  489. },
  490. menuClick: function (e) {
  491. this.data.filter = e.currentTarget.dataset.id;
  492. if (this.data.filter == "horizontal") {
  493. this.data.PageCount = this.data.QuestionTypeItem.QuestionNumber2;
  494. } else if (this.data.filter == "vertical") {
  495. this.data.PageCount = this.data.QuestionTypeItem.QuestionNumber3;
  496. }
  497. this.setData({
  498. filter: this.data.filter,
  499. IsShowMenu: false,
  500. PageCount: this.data.PageCount,
  501. });
  502. },
  503. closeMenu: function () {
  504. this.setData({
  505. IsShowMenu: false,
  506. });
  507. },
  508. openMenu: function () {
  509. this.setData({
  510. IsShowMenu: true,
  511. });
  512. },
  513. showHelp: function () {
  514. if (!this.data.HelpHidden3) {
  515. this.audioCtx = wx.createAudioContext('myAudio');
  516. var str = "嘿嘿,找到我了吗?我在车间的窗户里制作例题呢。如果这是你要的题型,去点“出题”按钮就对了。还要告诉你,一张卷子就是一张图片,题目数量请看提示。";
  517. server.playAudio(this.audioCtx, str);
  518. }
  519. },
  520. closeHelp: function () {
  521. this.setData({
  522. HelpHidden3: true,
  523. });
  524. wx.setStorageSync("HelpHidden3", true);
  525. this.audioCtx = wx.createAudioContext('myAudio');
  526. this.audioCtx.pause();
  527. },
  528. showHelp2: function () {
  529. if (!this.data.HelpHidden7) {
  530. this.audioCtx = wx.createAudioContext('myAudio');
  531. var str = "卷子出炉咯,棒棒哒!快去手机相册打印吧。我会等在首页上的答案资料室为你继续带路的。";
  532. server.playAudio(this.audioCtx, str);
  533. }
  534. },
  535. closeHelp2: function () {
  536. this.setData({
  537. HelpHidden7: true,
  538. });
  539. wx.setStorageSync("HelpHidden7", true);
  540. this.audioCtx = wx.createAudioContext('myAudio');
  541. this.audioCtx.pause();
  542. },
  543. onShareAppMessage: function () {
  544. return {
  545. title: app.globalData.ShareTitle,
  546. path: 'pages/index/index?UserID=' + app.globalData.userInfo.UserID,
  547. imageUrl: app.globalData.ShareImageUrl,
  548. }
  549. },
  550. })