var __slice = Array.prototype.slice; var msg_upload_file_size_limit_10M = "Upload file size can not be larger than 10MB."; var msg_error_try = "An error happened. Please try again in a moment."; var msg_using_default_image = 'Do you want to use default image?'; var sketch_max_width = 1024; var VERSION_NEW_SKETCH = 16.17; var VERSION_NEW_SKETCH_MOVE_FUNC = 9999.18; var image_quality = 1; // web app new var VERSION_NEW_WEB_APP = 40; var currentVersion = VERSION_NEW_WEB_APP; var CONST_DEFAULT_SIZE = 10; var CONST_DASH_LINE = {1:[2], 3:[6], 5:[10], 10:[20], 15:[30], 20:[40]}; var BASE64_IMG_QUESTION_12 = ''; var BASE64_IMG_QUESTION_24 = ''; var BASE64_IMG_QUESTION_36 = ''; var imgQuestion12 = undefined; var imgQuestion24 = undefined; var imgQuestion36 = undefined; var BASE64_IMG_PAINT_12 = ''; var BASE64_IMG_PAINT_24 = ''; var BASE64_IMG_PAINT_36 = ''; var imgPaint12 = undefined; var imgPaint24 = undefined; var imgPaint36 = undefined; var BASE64_IMG_DENT_12 = ''; var BASE64_IMG_DENT_24 = ''; var BASE64_IMG_DENT_36 = ''; var imgDent12 = undefined; var imgDent24 = undefined; var imgDent36 = undefined; var BASE64_IMG_SCRATCH_12 = ''; var BASE64_IMG_SCRATCH_24 = ''; var BASE64_IMG_SCRATCH_36 = ''; var imgScratch12 = undefined; var imgScratch24 = undefined; var imgScratch36 = undefined; var CONST_ZOOM_MIN = 0.25; var CONST_ZOOM_MAX = 4.0; var CONST_ZOOM_STEP = 0.25; var CONST_MOVE_STEP = 1; var CONST_SCROLL_STEP = 5; var updateLayerCombo = function(actions){ if(!actions || actions.length == 0){ return; } var layerCombo = $('.sub_menu_move_tool .selectLayer').empty(); $.each(actions, function(index) { var option = $(''); var text = ''; switch(this.tool){ case 'marker': text = 'Pencil'; break; case 'draw_arrow': text = 'Arrow'; break; case 'draw_mark': text = 'Check'; break; case 'draw_x': text = 'X'; break; case 'text': text = this.text; break; case 'shape_square': text = 'Rectangle'; break; case 'shape_square_circle': text = 'Rounded Rectangle'; break; case 'shape_triangle': text = 'Triangle'; break; case 'shape_circle': text = 'Circle'; break; default: text = this.tool; } option.text(text); layerCombo.append(option); }); layerCombo.val(actions.length - 1); } var isVersion = function(version){ var versionValue = parseFloat('' + version); if(currentVersion >= versionValue){ return true; }else{ return false; } } function drawRoundRect (cxt, x, y, width, height, radius) { cxt.beginPath(); cxt.arc(x + radius, y + radius, radius, Math.PI, Math.PI * 1.5); cxt.lineTo(width - radius + x, y); cxt.arc(width - radius + x, y + radius, radius, Math.PI * 1.5, Math.PI * 2); cxt.lineTo(x + width, y + height - radius); cxt.arc(width - radius + x, y + height - radius, radius, 0, Math.PI * 0.5); cxt.lineTo(width - radius + x, y+ height); cxt.arc(x + radius, y + height - radius, radius, Math.PI *0.5, Math.PI); cxt.closePath(); } function drawEllipse(ctx, x, y, w, h) { var kappa = .5522848, ox = (w / 2) * kappa, // control point offset horizontal oy = (h / 2) * kappa, // control point offset vertical xe = x + w, // x-end ye = y + h, // y-end xm = x + w / 2, // x-middle ym = y + h / 2; // y-middle ctx.beginPath(); ctx.moveTo(x, ym); ctx.bezierCurveTo(x, ym - oy, xm - ox, y, xm, y); ctx.bezierCurveTo(xm + ox, y, xe, ym - oy, xe, ym); ctx.bezierCurveTo(xe, ym + oy, xm + ox, ye, xm, ye); ctx.bezierCurveTo(xm - ox, ye, x, ym + oy, x, ym); //ctx.closePath(); // not used correctly, see comments (use to close off open path) ctx.stroke(); } function rotation(x, y, alpha){ /* x' = cos(alpha)*x - sin(alpha)*y y' = sin(alpha)*x + cos(alpha)*y */ var x1 = (Math.cos(alpha) * x) - (Math.sin(alpha) * y); var y1 = (Math.sin(alpha) * x) + (Math.cos(alpha) * y); return {x:x1, y:y1}; } function move(action, width, height){ if(!action){ return; } var event, eventOrg, _i, _len, _ref, _refOrg; _ref = action.events; if(!action.eventsOrg){ action.eventsOrg = []; for (_i = 0, _len = _ref.length; _i < _len; _i++) { action.eventsOrg.push({x:_ref[_i].x, y:_ref[_i].y}); } } _refOrg = action.eventsOrg; for (_i = 0, _len = _ref.length; _i < _len; _i++) { event = _ref[_i]; eventOrg = _refOrg[_i]; event.x = eventOrg.x + width; event.y = eventOrg.y + height; } } function drawArrow(ctx, x, y, x2, y2) { var tx1 = -10; var ty1 = 0; var tx2 = 10; var ty2 = 5; var tx3 = 5; var ty3 = 0; var tx4 = 10; var ty4 = -5; var alpha = -Math.atan2((y2-y),-(x2-x)); var point = rotation(tx1, ty1, alpha); tx1 = point.x + x2; ty1 = point.y + y2; point = rotation(tx2, ty2, alpha); tx2 = point.x + x2; ty2 = point.y + y2; point = rotation(tx3, ty3, alpha); tx3 = point.x + x2; ty3 = point.y + y2; point = rotation(tx4, ty4, alpha); tx4 = point.x + x2; ty4 = point.y + y2; ctx.moveTo(x, y); ctx.lineTo(x2, y2); ctx.stroke(); var lineJoin = ctx.lineJoin; ctx.lineJoin = 'miter'; ctx.beginPath(); ctx.moveTo(tx1, ty1); ctx.lineTo(tx2, ty2); ctx.lineTo(tx3, ty3); ctx.lineTo(tx4, ty4); ctx.lineTo(tx1, ty1); ctx.lineTo(tx2, ty2); ctx.fill(); ctx.stroke(); ctx.lineJoin=lineJoin; } function drawCheckMark(ctx, x, y, w, h) { var y1 = y + 2*h/3; var x1 = x; var y2 = y+h; var x2 = x + w/3; var y3 = y; var x3 = x + w; var lineJoin = ctx.lineJoin; ctx.lineJoin = 'miter'; ctx.moveTo(x1, y1); ctx.lineTo(x2, y2); ctx.lineTo(x3, y3); ctx.stroke(); ctx.lineJoin = lineJoin; } function drawXMark(ctx, x, y, w, h) { ctx.moveTo(x, y); ctx.lineTo(x + w, y + h); ctx.moveTo(x, y + h); ctx.lineTo(x + w, y); ctx.stroke(); } function drawPBMark(ctx, x, y, w, h) { /*var img = new Image(); img.src = '/img/icon/paintbrush_' + w + '.png'; ctx.drawImage(img, x-w/2, y-h/2, w, h);*/ switch(w){ case 12: if(imgPaint12 == undefined){ imgPaint12 = new Image(); imgPaint12.onload = function() { ctx.drawImage(imgPaint12, x-w/2, y-h/2, w, h); }; imgPaint12.src = BASE64_IMG_PAINT_12; }else{ ctx.drawImage(imgPaint12, x-w/2, y-h/2, w, h); } break; case 24: if(imgPaint24 == undefined){ imgPaint24 = new Image(); imgPaint24.onload = function() { ctx.drawImage(imgPaint24, x-w/2, y-h/2, w, h); }; imgPaint24.src = BASE64_IMG_PAINT_24; }else{ ctx.drawImage(imgPaint24, x-w/2, y-h/2, w, h); } break; case 36: default: //36 if(imgPaint36 == undefined){ imgPaint36 = new Image(); imgPaint36.onload = function() { ctx.drawImage(imgPaint36, x-w/2, y-h/2, w, h); }; imgPaint36.src = BASE64_IMG_PAINT_36; }else{ ctx.drawImage(imgPaint36, x-w/2, y-h/2, w, h); } } } function drawDentMark(ctx, x, y, w, h) { /*var img = new Image(); img.src = '/img/icon/dent_mark_' + w + '.png'; ctx.drawImage(img, x-w/2, y-h/2, w, h);*/ switch(w){ case 12: if(imgDent12 == undefined){ imgDent12 = new Image(); imgDent12.onload = function() { ctx.drawImage(imgDent12, x-w/2, y-h/2, w, h); }; imgDent12.src = BASE64_IMG_DENT_12; }else{ ctx.drawImage(imgDent12, x-w/2, y-h/2, w, h); } break; case 24: if(imgDent24 == undefined){ imgDent24 = new Image(); imgDent24.onload = function() { ctx.drawImage(imgDent24, x-w/2, y-h/2, w, h); }; imgDent24.src = BASE64_IMG_DENT_24; }else{ ctx.drawImage(imgDent24, x-w/2, y-h/2, w, h); } break; case 36: default: //36 if(imgDent36 == undefined){ imgDent36 = new Image(); imgDent36.onload = function() { ctx.drawImage(imgDent36, x-w/2, y-h/2, w, h); }; imgDent36.src = BASE64_IMG_DENT_36; }else{ ctx.drawImage(imgDent36, x-w/2, y-h/2, w, h); } } } function drawScratchMark(ctx, x, y, w, h) { /*var img = new Image(); img.src = '/img/icon/scratch_marks_' + w + '.png'; ctx.drawImage(img, x-w/2, y-h/2, w, h);*/ switch(w){ case 12: if(imgScratch12 == undefined){ imgScratch12 = new Image(); imgScratch12.onload = function() { ctx.drawImage(imgScratch12, x-w/2, y-h/2, w, h); }; imgScratch12.src = BASE64_IMG_SCRATCH_12; }else{ ctx.drawImage(imgScratch12, x-w/2, y-h/2, w, h); } break; case 24: if(imgScratch24 == undefined){ imgScratch24 = new Image(); imgScratch24.onload = function() { ctx.drawImage(imgScratch24, x-w/2, y-h/2, w, h); }; imgScratch24.src = BASE64_IMG_SCRATCH_24; }else{ ctx.drawImage(imgScratch24, x-w/2, y-h/2, w, h); } break; case 36: default: //36 if(imgScratch36 == undefined){ imgScratch36 = new Image(); imgScratch36.onload = function() { ctx.drawImage(imgScratch36, x-w/2, y-h/2, w, h); }; imgScratch36.src = BASE64_IMG_SCRATCH_36; }else{ ctx.drawImage(imgScratch36, x-w/2, y-h/2, w, h); } } } function drawQuestionMark(ctx, x, y, w, h) { /*var img = new Image(); img.src = '/img/icon/question_mark_' + w + '.png'; ctx.drawImage(img, x-w/2, y-h/2, w, h);*/ switch(w){ case 12: if(imgQuestion12 == undefined){ imgQuestion12 = new Image(); imgQuestion12.onload = function() { ctx.drawImage(imgQuestion12, x-w/2, y-h/2, w, h); }; imgQuestion12.src = BASE64_IMG_QUESTION_12; }else{ ctx.drawImage(imgQuestion12, x-w/2, y-h/2, w, h); } break; case 24: if(imgQuestion24 == undefined){ imgQuestion24 = new Image(); imgQuestion24.onload = function() { ctx.drawImage(imgQuestion24, x-w/2, y-h/2, w, h); }; imgQuestion24.src = BASE64_IMG_QUESTION_24; }else{ ctx.drawImage(imgQuestion24, x-w/2, y-h/2, w, h); } break; case 36: default: //36 if(imgQuestion36 == undefined){ imgQuestion36 = new Image(); imgQuestion36.onload = function() { ctx.drawImage(imgQuestion36, x-w/2, y-h/2, w, h); }; imgQuestion36.src = BASE64_IMG_QUESTION_36; }else{ ctx.drawImage(imgQuestion36, x-w/2, y-h/2, w, h); } } } function zoomValue(value, zoom){ if(zoom != 1){ return value/zoom; }else{ return value; } } function cnvZoomEventJson(ev, sketch){ /* ev = {x:..., y:..., ......} */ ev.x = zoomValue(ev.x, sketch.zoomInfo.zoom); ev.y = zoomValue(ev.y, sketch.zoomInfo.zoom); return ev; } (function($) { if(isVersion(VERSION_NEW_SKETCH)){ $('.VERSION_OLD_SKETCH').remove(); }else{ $('.VERSION_NEW_SKETCH').remove(); } var Sketch; $.fn.sketch = function() { var args, key, sketch; key = arguments[0], args = 2 <= arguments.length ? __slice.call(arguments, 1) : []; if (this.length > 1) { $.error('Sketch.js can only be called on one element at a time.'); } sketch = this.data('sketch'); if (typeof key === 'string' && sketch) { if (sketch[key]) { if (typeof sketch[key] === 'function') { return sketch[key].apply(sketch, args); } else if (args.length === 0) { return sketch[key]; } else if (args.length === 1) { return sketch[key] = args[0]; } } else { return $.error('Sketch.js did not recognize the given command.'); } } else if (sketch) { return sketch; } else { this.data('sketch', new Sketch(this.get(0), key)); return this; } }; Sketch = (function() { function Sketch(el, opts) { this.el = el; this.canvas = $(el); this.scale = 1; this.context = el.getContext('2d'); this.options = $.extend({ toolLinks: true, defaultTool: 'marker', defaultKind: 'pencil', defaultColor: '#000', defaultSize: CONST_DEFAULT_SIZE, defaultMarkSize: 'markS', defaultXSize: 'xS', defaultPBSize: 'pbS', defaultDentSize: 'dentS', defaultScratchSize: 'scratchS', defaultQuestionSize: 'questionS', defaultFortSize: 'fontS' }, opts); this.painting = false; this.kind = this.options.defaultKind; this.color = this.options.defaultColor; this.size = this.options.defaultSize; this.markSize = this.options.defaultMarkSize; this.xSize = this.options.defaultXSize; this.pbSize = this.options.defaultPBSize; this.dentSize = this.options.defaultDentSize; this.scratchSize = this.options.defaultScratchSize; this.questionSize = this.options.defaultQuestionSize; this.fortSize = this.options.defaultFortSize; this.tool = this.options.defaultTool; this.actions = []; this.redoActions = []; this.action = []; this.backgroundimgs = []; this.hasBGImage = false; var canvasW; var canvasH; var zoom = 1; try{ canvasW = parseInt(this.canvas.css('--colorsSketchWidth')); canvasH = parseInt(this.canvas.css('--colorsSketchHeight')); if(isNaN(canvasW) || isNaN(canvasH)){ canvasW = this.canvas.width(); canvasH = this.canvas.height(); }else{ zoom = this.canvas.width() / canvasW; } }catch(e){ canvasW = this.canvas.width(); canvasH = this.canvas.height(); } this.zoomInfo = { width: canvasW, height: canvasH, zoom: zoom } //this.el.width = this.canvas.width(); if(this.canvas.attr("data-img") != undefined && this.canvas.attr("data-img") != ''){ var img = new Image(); var cxt = this.context; var scaleWidth = 1; var scaleHeigh = 1; var drawWidth = this.canvas.width() - 2; var drawHeight = this.canvas.height() - 2; var canvas = this.canvas; var me = this; img.onload = function() { me.hasBGImage = true; var heightTemp = drawHeight; if(img.width > drawWidth){ scaleWidth = drawWidth/img.width; heightTemp = img.height * scaleWidth; if(heightTemp > drawHeight){ heightTemp = drawHeight; scaleHeigh = drawHeight/img.height; drawWidth = img.width * scaleHeigh; me.scale = scaleHeigh; }else{ drawHeight = heightTemp; me.scale = scaleWidth; } }else if(img.width <= drawWidth){ drawWidth = img.width; if(img.height <= drawHeight){ drawHeight = img.height; }else{ scaleHeigh = drawHeight/img.height; drawWidth = img.width * scaleHeigh; me.scale = scaleHeigh; } } canvas.width(drawWidth); canvas.height(drawHeight); me.zoomInfo = { width: drawWidth, height: drawHeight, zoom: 1 } cxt.canvas.width = img.width; cxt.canvas.height = img.height; cxt.drawImage(img, 0, 0, img.width, img.height); }; img.src=this.canvas.attr("data-img"); $('#canvasPar').addClass('zoom'); this.backgroundimgs.push(img); } this.canvas.on('click mousedown mouseup mousemove mouseleave mouseout touchstart touchmove touchend touchcancel', this.onEvent); if (this.options.toolLinks) { $('body').on('keyup', ".sub_menu_text_tool input.textString", function(e){ var $canvas, sketch; $canvas = $('#colors_sketch'); sketch = $canvas.data('sketch'); if(sketch.actions.length == 0){ return; } if(sketch.tool == 'draw_move'){ var moveAction; if(sketch.moveAction){ moveAction = sketch.moveAction; }else{ moveAction = sketch.actions[sketch.actions.length - 1]; } moveAction['text'] = $(this).val(); sketch.redraw(); } }); $('body').on('change', ".sub_menu_move_tool .selectLayer", function(e){ var $canvas, sketch; $canvas = $('#colors_sketch'); sketch = $canvas.data('sketch'); var actionId = $(this).val(); var action; if(actionId == ''){ action = sketch.actions[sketch.actions.length - 1]; }else{ action = sketch.actions[actionId]; } sketch.moveAction = action; $('.sub_draw_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); switch(action.tool){ case 'shape_square': // Rectangle; case 'shape_square_circle': // Rounded Rectangle case 'shape_triangle': // Triangle case 'shape_circle': // Circle case 'marker': // Pencil case 'draw_arrow': // Arrow $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $("a[data-color=\"" + action.color + "\"]").click(); $("a[data-size=\"" + action.size + "\"]").click(); break; case 'draw_mark': // Check $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $("a[data-marksize=\"" + action.markSize + "\"]").click(); break; case 'draw_x': // X $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $("a[data-xsize=\"" + action.xSize + "\"]").click(); break; case 'draw_pb': // pb $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $("a[data-pbsize=\"" + action.pbSize + "\"]").click(); break; case 'draw_dent': // dent $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $("a[data-dentsize=\"" + action.dentSize + "\"]").click(); break; case 'draw_scratch': // scratch $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $("a[data-scratchsize=\"" + action.scratchSize + "\"]").click(); break; case 'draw_question': // scratch $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $("a[data-questionsize=\"" + action.questionSize + "\"]").click(); break; case 'text': // text; $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $("a[data-color=\"" + action.color + "\"]").click(); $("a[data-size=\"" + action.size + "\"]").click(); $(".sub_menu_text_tool input.textString").val(action.text); break; default: } }); $('body').on('click', "a[href=\"#" + (this.canvas.attr('id')) + "\"]", function(e) { var $canvas, $this, key, sketch, _i, _len, _ref; $this = $(this); $canvas = $($this.attr('href')); sketch = $canvas.data('sketch'); _ref = ['pencil', 'color', 'size', 'tool', 'shape', 'draw', 'fontSize', 'markSize', 'xSize', 'pbSize', 'dentSize', 'scratchSize', 'questionSize']; for (_i = 0, _len = _ref.length; _i < _len; _i++) { key = _ref[_i]; var dataValue = $this.attr("data-" + key); if (dataValue) { if(key == 'pencil'){ if(dataValue == 'draw'){ $('.sub_pencil_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); continue } $('.pencilSelected').removeClass('pencilSelected'); $this.addClass('pencilSelected'); sketch.kind = dataValue; }else if(key == 'color'){ $('.colorSelected').removeClass('colorSelected'); $this.addClass('colorSelected'); var css = $(this).css('background-color'); $('.toolColor').css('background-color', css); }else if(key == 'size'){ $('.sizeSelected').removeClass('sizeSelected'); $this.addClass('sizeSelected'); }else if(key == 'fontSize'){ $('.fontSizeSelected').removeClass('fontSizeSelected'); $this.addClass('fontSizeSelected'); sketch.fontSize = dataValue; }else if(key == 'markSize'){ $('.markSizeSelected').removeClass('markSizeSelected'); $this.addClass('markSizeSelected'); sketch.markSize = dataValue; }else if(key == 'xSize'){ $('.xSizeSelected').removeClass('xSizeSelected'); $this.addClass('xSizeSelected'); sketch.xSize = dataValue; }else if(key == 'pbSize'){ $('.pbSizeSelected').removeClass('pbSizeSelected'); $this.addClass('pbSizeSelected'); sketch.pbSize = dataValue; }else if(key == 'dentSize'){ $('.dentSizeSelected').removeClass('dentSizeSelected'); $this.addClass('dentSizeSelected'); sketch.dentSize = dataValue; }else if(key == 'scratchSize'){ $('.scratchSizeSelected').removeClass('scratchSizeSelected'); $this.addClass('scratchSizeSelected'); sketch.scratchSize = dataValue; }else if(key == 'questionSize'){ $('.questionSizeSelected').removeClass('questionSizeSelected'); $this.addClass('questionSizeSelected'); sketch.questionSize = dataValue; }else if(key == 'shape'){ $('.shapeSelected').removeClass('shapeSelected'); $this.addClass('shapeSelected'); $('.sub_shape_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); var css = $(this).css('background-image'); $('.toolShape').css('background-image', css).css('background-color', 'white'); sketch.tool = 'shape_' + dataValue; }else if(key == 'draw'){ $('.drawSelected').removeClass('drawSelected'); $this.addClass('drawSelected'); $('.sub_draw_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); var css = $(this).css('background-image'); $('.toolDraw').css('background-image', css).css('background-color', 'white'); sketch.tool = 'draw_' + dataValue; if(dataValue == 'mark'){ $('a.toolColor').addClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('a.toolThickness').addClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('.sub_pencil_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); }else if(dataValue == 'x'){ $('a.toolColor').addClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('a.toolThickness').addClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('.sub_pencil_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); }else if(dataValue == 'move'){ $('a.toolColor').removeClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('a.toolThickness').removeClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('.sub_pencil_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); updateLayerCombo(sketch.actions); $(".sub_menu_move_tool .selectLayer").trigger('change'); }else if(dataValue == 'pb'){ $('a.toolColor').addClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('a.toolThickness').addClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('.sub_pencil_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); }else if(dataValue == 'dent'){ $('a.toolColor').addClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('a.toolThickness').addClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('.sub_pencil_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); }else if(dataValue == 'scratch'){ $('a.toolColor').addClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('a.toolThickness').addClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('.sub_pencil_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); }else if(dataValue == 'question'){ $('a.toolColor').addClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('a.toolThickness').addClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('.sub_pencil_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); }else{ $('a.toolColor').removeClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('a.toolThickness').removeClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('.sub_pencil_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); } } sketch.set(key, dataValue); if(sketch.tool == 'draw_move'){ var moveAction; if(sketch.moveAction){ moveAction = sketch.moveAction; }else{ moveAction = sketch.actions[sketch.actions.length - 1]; } moveAction[key] = dataValue; sketch.redraw(); } } } if ($(this).attr('data-download')) { sketch.download($(this).attr('data-download')); } if ($(this).attr('save-download')) { sketch.save($(this).attr('save-download')); } if ($(this).attr('sketch-clear')) { sketch.clear(); $('.toolPencil').click(); $('.color_000').click(); $('.size_' + CONST_DEFAULT_SIZE).click(); } if ($(this).attr('sketch-undo')) { sketch.undo(); } if ($(this).attr('sketch-redo')) { sketch.redo(); } if ($(this).attr('sketch-cancel')) { sketch.cancel(); } if ($(this).attr('sketch-tool-draw')) { $('.toolSelected').removeClass('toolSelected'); $(this).addClass('toolSelected'); $('a.toolColor').addClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('a.toolThickness').addClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('.sub_pencil_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_shape_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_draw_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); dataValue = $('.sub_draw_session .drawSelected').attr('data-draw'); if(dataValue == 'mark'){ $('.sub_mark_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); }else if(dataValue == 'x'){ $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); }else if(dataValue == 'move'){ $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('a.toolColor').removeClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('a.toolThickness').removeClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); updateLayerCombo(sketch.actions); }else if(dataValue == 'pb'){ $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); updateLayerCombo(sketch.actions); }else if(dataValue == 'dent'){ $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); updateLayerCombo(sketch.actions); }else if(dataValue == 'scratch'){ $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); updateLayerCombo(sketch.actions); }else if(dataValue == 'question'){ $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); updateLayerCombo(sketch.actions); }else{ $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('a.toolColor').removeClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('a.toolThickness').removeClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); } sketch.tool = 'draw_' + dataValue; } if ($(this).attr('sketch-tool-text')) { $('.toolSelected').removeClass('toolSelected'); $(this).addClass('toolSelected'); $('a.toolColor').removeClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('a.toolThickness').removeClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('.sub_pencil_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_shape_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_draw_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); sketch.tool = 'text'; } if ($(this).attr('sketch-tool-pencil')) { $('.toolSelected').removeClass('toolSelected'); $(this).addClass('toolSelected'); $('a.toolColor').removeClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('a.toolThickness').removeClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('.sub_pencil_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_shape_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_draw_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); dataValue = $('.sub_draw_session .drawSelected').attr('data-pencil'); sketch.tool = 'marker'; } if ($(this).attr('sketch-tool-shape')) { $('.toolSelected').removeClass('toolSelected'); $(this).addClass('toolSelected'); $('a.toolColor').removeClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('a.toolThickness').removeClass(CONST_CSS_CLASS_HIDE_SESSION_IMP); $('.sub_pencil_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_draw_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_shape_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); dataValue = $('.sub_shape_session .shapeSelected').attr('data-shape'); sketch.tool = 'shape_' + dataValue; } if ($(this).attr('sketch-tool-color')) { $('.sub_pencil_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_shape_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_draw_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); } if ($(this).attr('sketch-tool_thickness')) { $('.sub_pencil_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_shape_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').removeClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_draw_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); } if ($(this).attr('sketch-hand')) { sketch.hand($(this)); } if ($(this).attr('sketch-zoom-in')) { sketch.zoomIn(); } if ($(this).attr('sketch-zoom-out')) { sketch.zoomOut(); } return false; }); } } Sketch.prototype.download = function(format) { var mime; format || (format = "png"); if (format === "jpg") { format = "jpeg"; } mime = "image/" + format; return window.open(this.el.toDataURL(mime, image_quality)); }; Sketch.prototype.clear = function() { this.actions = []; this.redoActions = []; this.backgroundimgs = []; var ignoreOrgImage = false; if(this.canvas.attr("data-ctrl-kind") != undefined && this.canvas.attr("data-ctrl-kind") == 'signature'){ ignoreOrgImage = true; } if(this.canvas.attr("data-img-type") != undefined && this.canvas.attr("data-img-type").startsWith('inputSketch')){ if(this.canvas.attr("data-img-org") != undefined && this.canvas.attr("data-img-org") != ''){ var parentObj = this; $.alerts.okButton = 'Yes'; $.alerts.cancelButton = 'No'; jConfirm(msg_using_default_image,'',function(result, data){ $.alerts.okButton = CUSTOM_OK_BUTTON_LABEL; $.alerts.cancelButton = ' Cancel '; if(!result) { ignoreOrgImage = true; } if(!ignoreOrgImage && parentObj.canvas.attr("data-img-org") != undefined && parentObj.canvas.attr("data-img-org") != ''){ var img = new Image(); var cxt = parentObj.context; img.onload = function() { cxt.drawImage(img, 0, 0, cxt.canvas.width, cxt.canvas.height); }; img.src=parentObj.canvas.attr("data-img-org"); parentObj.backgroundimgs.push(img); }else{ parentObj.hasBGImage = false; } return parentObj.redraw(); }); return true; } } if(!ignoreOrgImage && this.canvas.attr("data-img-org") != undefined && this.canvas.attr("data-img-org") != ''){ var img = new Image(); var cxt = this.context; img.onload = function() { cxt.drawImage(img, 0, 0, cxt.canvas.width, cxt.canvas.height); }; img.src=this.canvas.attr("data-img-org"); this.backgroundimgs.push(img); }else{ this.hasBGImage = false; } return this.redraw(); }; Sketch.prototype.undo = function() { if(this.actions.length <= 0){ return; } this.redoActions.push(this.actions.pop()); return this.redraw(); }; Sketch.prototype.redo = function() { if(this.redoActions.length <= 0){ return; } this.actions.push(this.redoActions.pop()); return this.redraw(); }; Sketch.prototype.cancel = function() { return parent.jQuery.fancybox.close(); }; Sketch.prototype.save = function(format, blobkey) { var mime; format || (format = "png"); if (format === "jpg") { format = "jpeg"; } mime = "image/" + format; // CO-2573 var type = this.canvas.attr("data-img-type"); if(type == undefined){ type = ''; } //return window.open(this.el.toDataURL(mime, image_quality)); var boundary = "---------------------------7da24f2e50046"; var $data = '--' + boundary + '\r\n' // Parameter name is "file" and local filename is "temp.txt" + 'Content-Disposition: form-data; name="resourcesButtonFile";' + 'filename="signature." + format + \r\n' // Add the file's mime-type + 'Content-type: " + mime + "\r\n\r\n' // Add your data: + this.el.toDataURL(mime, image_quality) + '\r\n' + '--' + boundary + '--'; name: 'resourcesButtonFile', $.ajax({ url: '/dataview/imageLabel' + '?resourcesData=1' + '&label=1' + '&blobkey=' + blobkey + '&max_size=15' + '&base64encode=true' + '&type=' + type, contentType: 'multipart/form-data; charset=UTF-8; boundary=' + boundary, processData: false, type: 'POST', data: $data, cache: false, dataType: 'json', complete: function() { //waitForDataLoading(false); }, success: function(response, status) { if(response.Error != undefined){ alert(msg_upload_file_size_limit_10M); }else{ $('.hintLink').val(response.HintLink); $('input.file').val('signature.jpg'); $('input.blobKey').val(response.BlobKey); try { // Setting global variable of parent window parent.glbHashObject['flgHasClickButtonDoneOfSignature'] = true; } catch (e) {} parent.jQuery.fancybox.close(); } }, error: function(request, status, error) { alert(msg_error_try); } }); }; Sketch.prototype.set = function(key, value) { this[key] = value; return this.canvas.trigger("sketch.change" + key, value); }; Sketch.prototype.startPainting = function() { this.painting = true; return this.action = { tool: this.tool, color: this.color, size: this.size, markSize: this.markSize, xSize: this.xSize, pbSize: this.pbSize, dentSize: this.dentSize, scratchSize: this.scratchSize, questionSize: this.questionSize, fontSize: this.fontSize, events: [] }; }; Sketch.prototype.stopPainting = function() { if (this.action) { this.actions.push(this.action); this.redoActions = []; } this.painting = false; this.action = null; return this.redraw(); }; Sketch.prototype.onEvent = function(e) { if (e.originalEvent && e.originalEvent.targetTouches) { if (e.originalEvent.targetTouches[0] && e.originalEvent.targetTouches[0].pageX){ e.pageX = e.originalEvent.targetTouches[0].pageX; } if (e.originalEvent.targetTouches[0] && e.originalEvent.targetTouches[0].pageY){ e.pageY = e.originalEvent.targetTouches[0].pageY; } /*e.pageX = e.originalEvent.targetTouches[0].pageX; e.pageY = e.originalEvent.targetTouches[0].pageY;*/ } $.sketch.tools[$(this).data('sketch').tool].onEvent.call($(this).data('sketch'), e); e.preventDefault(); return false; }; Sketch.prototype.redraw = function() { var sketch; //this.el.width = this.canvas.width(); this.context = this.el.getContext('2d'); var cxt = this.context; var drawWidth = this.canvas.width(); var drawHeight = this.canvas.height(); cxt.fillStyle = "white"; cxt.fillRect(0, 0, cxt.canvas.width, cxt.canvas.height); $.each(this.backgroundimgs, function() { cxt.drawImage(this, 0, 0, cxt.canvas.width, cxt.canvas.height); }); sketch = this; $.each(this.actions, function() { if (this.tool) { return $.sketch.tools[this.tool].draw.call(sketch, this); } }); if (this.painting && this.action) { return $.sketch.tools[this.action.tool].draw.call(sketch, this.action); } }; Sketch.prototype.hand = function(ctrl) { $('.toolSelected').removeClass('toolSelected'); ctrl.addClass('toolSelected'); $('.sub_pencil_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_zoom_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_shape_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_text_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_font_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_draw_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_move_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_thickness_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_mark_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_color_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_x_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_pb_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_dent_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_scratch_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); $('.sub_question_size_session').addClass(CONST_CSS_CLASS_HIDE_SESSION); this.tool = 'hand'; }; Sketch.prototype.zoomIn = function() { if(this.zoomInfo.zoom >= CONST_ZOOM_MAX){ return; } var canvas = $('canvas'); var width = this.zoomInfo.width; var height = this.zoomInfo.height; var scale = height/width; this.zoomInfo.zoom += CONST_ZOOM_STEP; width = width*this.zoomInfo.zoom; height = scale*width; canvas.css('width', width + 'px'); canvas.css('height', height + 'px'); $('#canvasPar').addClass('zoom'); this.redraw(); }; Sketch.prototype.zoomOut = function() { if(this.zoomInfo.zoom <= CONST_ZOOM_MIN){ return; } var canvas = $('canvas'); var width = this.zoomInfo.width; var height = this.zoomInfo.height; var scale = height/width; this.zoomInfo.zoom -= CONST_ZOOM_STEP; width = width*this.zoomInfo.zoom; height = scale*width; canvas.css('width', width + 'px'); canvas.css('height', height + 'px'); $('#canvasPar').addClass('zoom'); this.redraw(); }; return Sketch; })(); $.sketch = { tools: {} }; $.sketch.tools.marker = { onEvent: function(e) { switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type, kind: this.kind }, this)); return this.redraw(); } }, draw: function(action) { var event, previous, _i, _len, _ref; this.context.lineJoin = "round"; this.context.lineCap = "round"; this.context.beginPath(); if(action.events[0].kind == 'dash'){ this.context.setLineDash(CONST_DASH_LINE[action.size]); }else{ this.context.setLineDash([]); } this.context.moveTo(action.events[0].x, action.events[0].y); _ref = action.events; for (_i = 0, _len = _ref.length; _i < _len; _i++) { event = _ref[_i]; this.context.lineTo(event.x, event.y); previous = event; } this.context.strokeStyle = action.color; this.context.lineWidth = action.size/this.scale; return this.context.stroke(); } }; $.sketch.tools.shape_square = { onEvent: function(e) { switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type, kind: this.kind }, this)); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { if(this.action.events.length == 1){ this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); }else{ this.action.events[1] = cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this); } return this.redraw(); } }, draw: function(action) { this.context.beginPath(); if(action.events[0].kind == 'dash'){ this.context.setLineDash(CONST_DASH_LINE[action.size]); }else{ this.context.setLineDash([]); } var x = 0; var y = 0; var width = 0; var height = 0; if(action.events[0].x == action.events[1].x){ x = action.events[0].x; width = 1; }else if(action.events[0].x > action.events[1].x){ x = action.events[1].x; width = action.events[0].x - action.events[1].x; }else{ x = action.events[0].x; width = action.events[1].x - action.events[0].x; } if(action.events[0].y == action.events[1].y){ y = action.events[0].y; height = 1; }else if(action.events[0].y > action.events[1].y){ y = action.events[1].y; height = action.events[0].y - action.events[1].y; }else{ y = action.events[0].y; height = action.events[1].y - action.events[0].y; } this.context.strokeStyle = action.color; this.context.lineWidth = action.size/this.scale; this.context.lineJoin = 'miter'; this.context.strokeRect(x,y,width,height); return this.context.stroke(); } }; $.sketch.tools.shape_square_circle = { onEvent: function(e) { switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type, kind: this.kind }, this)); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { if(this.action.events.length == 1){ this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); }else{ this.action.events[1] = cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this); } return this.redraw(); } }, draw: function(action) { this.context.beginPath(); if(action.events[0].kind == 'dash'){ this.context.setLineDash(CONST_DASH_LINE[action.size]); }else{ this.context.setLineDash([]); } var x = 0; var y = 0; var width = 0; var height = 0; var radius = 5; if(action.events[0].x == action.events[1].x){ x = action.events[0].x; width = 1; }else if(action.events[0].x > action.events[1].x){ x = action.events[1].x; width = action.events[0].x - action.events[1].x; }else{ x = action.events[0].x; width = action.events[1].x - action.events[0].x; } if(action.events[0].y == action.events[1].y){ y = action.events[0].y; height = 1; }else if(action.events[0].y > action.events[1].y){ y = action.events[1].y; height = action.events[0].y - action.events[1].y; }else{ y = action.events[0].y; height = action.events[1].y - action.events[0].y; } this.context.strokeStyle = action.color; this.context.lineWidth = action.size/this.scale; drawRoundRect(this.context, x, y , width, height, radius); return this.context.stroke(); } }; $.sketch.tools.shape_circle = { onEvent: function(e) { switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type, kind: this.kind }, this)); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { if(this.action.events.length == 1){ this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); }else{ this.action.events[1] = cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this); } return this.redraw(); } }, draw: function(action) { this.context.beginPath(); if(action.events[0].kind == 'dash'){ this.context.setLineDash(CONST_DASH_LINE[action.size]); }else{ this.context.setLineDash([]); } var x = 0; var y = 0; var width = 0; var height = 0; var radius = 5; if(action.events[0].x == action.events[1].x){ x = action.events[0].x; width = 1; }else if(action.events[0].x > action.events[1].x){ x = action.events[1].x; width = action.events[0].x - action.events[1].x; }else{ x = action.events[0].x; width = action.events[1].x - action.events[0].x; } if(action.events[0].y == action.events[1].y){ y = action.events[0].y; height = 1; }else if(action.events[0].y > action.events[1].y){ y = action.events[1].y; height = action.events[0].y - action.events[1].y; }else{ y = action.events[0].y; height = action.events[1].y - action.events[0].y; } this.context.strokeStyle = action.color; this.context.lineWidth = action.size/this.scale; drawEllipse(this.context, x, y, width, height); return this.context.stroke(); } }; $.sketch.tools.shape_line = { onEvent: function(e) { switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type, kind: this.kind }, this)); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { if(this.action.events.length == 1){ this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); }else{ this.action.events[1] = cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this); } return this.redraw(); } }, draw: function(action) { this.context.lineJoin = "round"; this.context.lineCap = "square"; this.context.beginPath(); if(action.events[0].kind == 'dash'){ this.context.setLineDash(CONST_DASH_LINE[action.size]); }else{ this.context.setLineDash([]); } this.context.strokeStyle = action.color; this.context.lineWidth = action.size/this.scale; this.context.moveTo(action.events[0].x, action.events[0].y); this.context.lineTo(action.events[1].x, action.events[1].y); return this.context.stroke(); } }; $.sketch.tools.draw_arrow = { onEvent: function(e) { switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { if(this.action.events.length == 1){ this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); }else{ this.action.events[1] = cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this); } return this.redraw(); } }, draw: function(action) { this.context.lineJoin = "round"; this.context.lineCap = "butt"; this.context.beginPath(); if(action.events[0].kind == 'dash'){ this.context.setLineDash(CONST_DASH_LINE[action.size]); }else{ this.context.setLineDash([]); } this.context.strokeStyle = action.color; this.context.lineWidth = action.size/this.scale; this.context.fillStyle = action.color; drawArrow(this.context, action.events[0].x, action.events[0].y, action.events[1].x, action.events[1].y); return this.context.stroke(); } }; $.sketch.tools.draw_mark = { onEvent: function(e) { switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { this.action.events[0] = cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this); return this.redraw(); } }, draw: function(action) { this.context.lineJoin = "round"; this.context.lineCap = "round"; this.context.beginPath(); if(action.events[0].kind == 'dash'){ this.context.setLineDash(CONST_DASH_LINE[action.size]); }else{ this.context.setLineDash([]); } var x = action.events[0].x; var y = action.events[0].y; var width = 0; var height = 0; var lineWidth = 0; switch(action.markSize){ case 'markL': width = 36; height = 36; lineWidth = 10; break; case 'markM': width = 24; height = 24; lineWidth = 5; break; default: width = 12; height = 12; lineWidth = 3; } this.context.strokeStyle = '#0f0'; //this.context.lineWidth = CONST_DEFAULT_SIZE/this.scale; this.context.lineWidth = lineWidth/this.scale; drawCheckMark(this.context, x, y, width/this.scale, height/this.scale); return this.context.stroke(); } }; $.sketch.tools.draw_x = { onEvent: function(e) { switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { this.action.events[0] = cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this); return this.redraw(); } }, draw: function(action) { this.context.lineJoin = "round"; this.context.lineCap = "round"; this.context.beginPath(); if(action.events[0].kind == 'dash'){ this.context.setLineDash(CONST_DASH_LINE[action.size]); }else{ this.context.setLineDash([]); } var x = action.events[0].x; var y = action.events[0].y; var width = 0; var height = 0; var lineWidth = 0; switch(action.xSize){ case 'xL': width = 36; height = 36; lineWidth = 10; break; case 'xM': width = 24; height = 24; lineWidth = 5; break; default: width = 12; height = 12; lineWidth = 3; } this.context.strokeStyle = '#f00'; //this.context.lineWidth = CONST_DEFAULT_SIZE/this.scale; this.context.lineWidth = lineWidth/this.scale; drawXMark(this.context, x, y, width/this.scale, height/this.scale); return this.context.stroke(); } }; $.sketch.tools.draw_pb = { onEvent: function(e) { switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { this.action.events[0] = cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this); return this.redraw(); } }, draw: function(action) { this.context.lineJoin = "round"; this.context.lineCap = "round"; this.context.beginPath(); if(action.events[0].kind == 'dash'){ this.context.setLineDash(CONST_DASH_LINE[action.size]); }else{ this.context.setLineDash([]); } var x = action.events[0].x; var y = action.events[0].y; var width = 0; var height = 0; switch(action.pbSize){ case 'pbL': width = 36; height = 36; break; case 'pbM': width = 24; height = 24; break; default: width = 12; height = 12; } this.context.strokeStyle = '#f00'; this.context.lineWidth = CONST_DEFAULT_SIZE/this.scale; drawPBMark(this.context, x, y, width/this.scale, height/this.scale); return this.context.stroke(); } }; $.sketch.tools.draw_dent = { onEvent: function(e) { switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { this.action.events[0] = cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this); return this.redraw(); } }, draw: function(action) { this.context.lineJoin = "round"; this.context.lineCap = "round"; this.context.beginPath(); if(action.events[0].kind == 'dash'){ this.context.setLineDash(CONST_DASH_LINE[action.size]); }else{ this.context.setLineDash([]); } var x = action.events[0].x; var y = action.events[0].y; var width = 0; var height = 0; switch(action.dentSize){ case 'dentL': width = 36; height = 36; break; case 'dentM': width = 24; height = 24; break; default: width = 12; height = 12; } this.context.strokeStyle = '#f00'; this.context.lineWidth = CONST_DEFAULT_SIZE/this.scale; drawDentMark(this.context, x, y, width/this.scale, height/this.scale); return this.context.stroke(); } }; $.sketch.tools.draw_scratch = { onEvent: function(e) { switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { this.action.events[0] = cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this); return this.redraw(); } }, draw: function(action) { this.context.lineJoin = "round"; this.context.lineCap = "round"; this.context.beginPath(); if(action.events[0].kind == 'dash'){ this.context.setLineDash(CONST_DASH_LINE[action.size]); }else{ this.context.setLineDash([]); } var x = action.events[0].x; var y = action.events[0].y; var width = 0; var height = 0; switch(action.scratchSize){ case 'scratchL': width = 36; height = 36; break; case 'scratchM': width = 24; height = 24; break; default: width = 12; height = 12; } this.context.strokeStyle = '#f00'; this.context.lineWidth = CONST_DEFAULT_SIZE/this.scale; drawScratchMark(this.context, x, y, width/this.scale, height/this.scale); return this.context.stroke(); } }; $.sketch.tools.draw_question = { onEvent: function(e) { switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { this.action.events[0] = cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this); return this.redraw(); } }, draw: function(action) { this.context.lineJoin = "round"; this.context.lineCap = "round"; this.context.beginPath(); if(action.events[0].kind == 'dash'){ this.context.setLineDash(CONST_DASH_LINE[action.size]); }else{ this.context.setLineDash([]); } var x = action.events[0].x; var y = action.events[0].y; var width = 0; var height = 0; switch(action.questionSize){ case 'questionL': width = 36; height = 36; break; case 'questionM': width = 24; height = 24; break; default: width = 12; height = 12; } this.context.strokeStyle = '#f00'; this.context.lineWidth = CONST_DEFAULT_SIZE/this.scale; drawQuestionMark(this.context, x, y, width/this.scale, height/this.scale); return this.context.stroke(); } }; $.sketch.tools.text = { onEvent: function(e) { if($('.sub_text_session .textString').val() == ''){ return; } switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.action.text = $('.sub_text_session .textString').val(); //this.action.fontSize = $('.sub_text_session .fontSize').val(); this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { if(this.action.events.length == 1){ this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); }else{ this.action.events[1] = cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this); } return this.redraw(); } }, draw: function(action) { this.context.beginPath(); if(action.events[0].kind == 'dash'){ this.context.setLineDash(CONST_DASH_LINE[action.size]); }else{ this.context.setLineDash([]); } this.context.strokeStyle = action.color; this.context.fillStyle = action.color; //this.context.font = action.fontSize + "px Arial"; if(action.fontSize == 'fontL'){ var size = Math.round(36/this.scale); this.context.font = size + 'px Arial'; }else if(action.fontSize == 'fontM'){ var size = Math.round(24/this.scale); this.context.font = size + 'px Arial'; }else{ var size = Math.round(12/this.scale); this.context.font = size + 'px Arial'; } var txt = action.text; this.context.fillText(txt, action.events[1].x, action.events[1].y); return this.context.stroke(); } }; $.sketch.tools.draw_move = { onEvent: function(e) { var selectedLayer = $('.sub_menu_move_tool .selectLayer').val(); if(selectedLayer == ''){ selectedLayer = this.actions.length - 1; } switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.action = null; this.actions[selectedLayer].eventsOrg = undefined; this.stopPainting(); } if (this.painting) { if(this.action.events.length == 1){ this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); }else{ this.action.events[1] = cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this); } var width = this.action.events[1].x - this.action.events[0].x; var height = this.action.events[1].y - this.action.events[0].y; move(this.actions[selectedLayer], width, height); return this.redraw(); } }, draw: function(action) { } }; $.sketch.tools.shape_triangle = { onEvent: function(e) { switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type, kind: this.kind }, this)); break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { if(this.action.events.length == 1){ this.action.events.push(cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this)); }else{ this.action.events[1] = cnvZoomEventJson({ x: (e.pageX - this.canvas.offset().left)/this.scale, y: (e.pageY - this.canvas.offset().top)/this.scale, event: e.type }, this); } return this.redraw(); } }, draw: function(action) { this.context.beginPath(); if(action.events[0].kind == 'dash'){ this.context.setLineDash(CONST_DASH_LINE[action.size]); }else{ this.context.setLineDash([]); } var x1,x2,x3,y1,y2,y3; x2 = action.events[1].x; y2 = action.events[1].y; x3 = action.events[0].x; y3 = action.events[1].y; x1 = action.events[0].x + (action.events[1].x - action.events[0].x)/2; y1 = action.events[0].y; this.context.strokeStyle = action.color; this.context.lineWidth = action.size/this.scale; var lineJoin = this.context.lineJoin; this.context.lineJoin = 'miter'; this.context.moveTo(x1, y1); this.context.lineTo(x2, y2); this.context.lineTo(x3, y3); this.context.lineTo(x1, y1); this.context.lineTo(x2, y2); return this.context.stroke(); this.context.lineJoin = lineJoin; } }; $.sketch.tools.hand = { onEvent: function(e) { switch (e.type) { case 'mousedown': case 'touchstart': this.startPainting(); this.x = e.pageX; this.y = e.pageY; break; case 'mouseup': case 'mouseout': case 'mouseleave': case 'touchend': case 'touchcancel': this.stopPainting(); } if (this.painting) { var canvasPar = $('div#canvasPar'); if((this.x+CONST_MOVE_STEP) <= e.pageX){ this.x = e.pageX; var curPos = canvasPar.scrollLeft(); canvasPar.scrollLeft(curPos - CONST_SCROLL_STEP); }else if((this.x-CONST_MOVE_STEP) > e.pageX){ this.x = e.pageX; var curPos = canvasPar.scrollLeft(); canvasPar.scrollLeft(curPos + CONST_SCROLL_STEP); } if((this.y+CONST_MOVE_STEP) <= e.pageY){ this.y = e.pageY; var curPos = canvasPar.scrollTop(); canvasPar.scrollTop(curPos - CONST_SCROLL_STEP); }else if((this.y-CONST_MOVE_STEP) > e.pageY){ this.y = e.pageY; var curPos = canvasPar.scrollTop(); canvasPar.scrollTop(curPos + CONST_SCROLL_STEP); } } }, draw: function(action) { } }; return $.sketch.tools.eraser = { onEvent: function(e) { return $.sketch.tools.marker.onEvent.call(this, e); }, draw: function(action) { var oldcomposite; oldcomposite = this.context.globalCompositeOperation; this.context.globalCompositeOperation = "copy"; action.color = "rgba(0,0,0,0)"; $.sketch.tools.marker.draw.call(this, action); return this.context.globalCompositeOperation = oldcomposite; } }; })(jQuery);