1/* 2 * Copyright (c) 2023 Huawei Device Co., Ltd. 3 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * you may not use this file except in compliance with the License. 5 * You may obtain a copy of the License at 6 * 7 * http://www.apache.org/licenses/LICENSE-2.0 8 * 9 * Unless required by applicable law or agreed to in writing, software 10 * distributed under the License is distributed on an "AS IS" BASIS, 11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 * See the License for the specific language governing permissions and 13 * limitations under the License. 14 */ 15 16import { CanvasInput } from '../ir/CanvasInput.js'; 17import { X2DFast } from './graphics/X2DFast.js'; 18import { Scr } from './XDefine.js'; 19import { XTools } from './XTools.js'; 20 21export var gl; 22var Mouse = { 23 MOUSE_LEFT: 0, 24 MOUSE_RILLER: 1, 25 MOUSE_RIGHT: 2, 26}; 27 28var MouseEvent = { 29 LEFT_CLICK: 1, 30 LEFT_MOVE: 2, 31 LEFT_RELEASE: 3, 32 RIGHT_CLICK: 4, 33 RIGHT_MOVE: 5, 34 RIGHT_RELEASE: 6, 35}; 36 37function touchStart(e) { 38 document.addEventListener('contextmenu', function (e) { 39 e.preventDefault(); 40 }); 41 e.preventDefault(); 42 GLFrame.pinstance_.callbackProctouch( 43 MouseEvent.LEFT_CLICK, 44 e.touches[0].clientX, 45 e.touches[0].clientY 46 ); 47} 48function touchMove(e) { 49 e.preventDefault(); 50 GLFrame.pinstance_.callbackProctouch( 51 MouseEvent.LEFT_MOVE, 52 e.touches[0].clientX, 53 e.touches[0].clientY 54 ); 55} 56function touchEnd(e) { 57 e.preventDefault(); 58 GLFrame.pinstance_.callbackProctouch( 59 MouseEvent.LEFT_RELEASE, 60 e.changedTouches[0].clientX, 61 e.changedTouches[0].clientY 62 ); 63} 64 65function mouseDown(e) { 66 e.preventDefault(); 67 switch (e.button) { 68 case Mouse.MOUSE_LEFT: 69 GLFrame.pinstance_.callbackProctouch( 70 MouseEvent.LEFT_CLICK, 71 e.offsetX, 72 e.offsetY 73 ); 74 break; 75 case Mouse.MOUSE_RIGHT: 76 GLFrame.pinstance_.callbackProctouch( 77 MouseEvent.RIGHT_CLICK, 78 e.offsetX, 79 e.offsetY 80 ); 81 break; 82 } 83} 84function mouseMove(e) { 85 e.preventDefault(); 86 GLFrame.pinstance_.callbackProctouch( 87 MouseEvent.LEFT_MOVE, 88 e.offsetX, 89 e.offsetY 90 ); 91} 92function mouseUp(e) { 93 e.preventDefault(); 94 switch (e.button) { 95 case Mouse.MOUSE_LEFT: 96 GLFrame.pinstance_.callbackProctouch( 97 MouseEvent.LEFT_RELEASE, 98 e.offsetX, 99 e.offsetY 100 ); 101 break; 102 case Mouse.MOUSE_RIGHT: 103 GLFrame.pinstance_.callbackProctouch( 104 MouseEvent.RIGHT_RELEASE, 105 e.offsetX, 106 e.offsetY 107 ); 108 break; 109 } 110} 111function mouseWheel(e) { 112 e.preventDefault(); 113 if (e.wheelDeltaY > 0) { 114 GLFrame.pinstance_.callbackProctouch(10, e.clientX, e.clientY); 115 } 116 else { 117 GLFrame.pinstance_.callbackProctouch(11, e.clientX, e.clientY); 118 } 119} 120 121function keyUp(e) { 122 if (!e.ctrlKey) { 123 XTools.KEY_CTRL = false; 124 } 125 if (!e.shiftKey) { 126 XTools.KEY_SHIFT = false; 127 } 128 if (!e.altKey) { 129 XTools.KEY_ALT = false; 130 } 131 e.preventDefault(); 132} 133 134function keyDown(e) { 135 let ret = ''; 136 if (e.ctrlKey) { 137 if (ret.length > 0) ret += '+'; 138 ret += 'ctrl'; 139 XTools.KEY_CTRL = true; 140 } 141 if (e.shiftKey) { 142 if (ret.length > 0) ret += '+'; 143 ret += 'shift'; 144 XTools.KEY_SHIFT = true; 145 } 146 if (e.altKey) { 147 if (ret.length > 0) ret += '+'; 148 ret += 'alt'; 149 XTools.KEY_ALT = true; 150 } 151 if (ret.length > 0) ret += '+'; 152 ret += e.key; 153 GLFrame.pinstance_.callbackKey(1, ret); 154 if (!CanvasInput.FOCUS) { 155 } 156 if (ret === 'ctrl+z' || ret === 'ctrl+f' || ret === 'Enter') { 157 e.preventDefault(); 158 } 159} 160 161function mainLoop() { 162 GLFrame.pinstance_.callbackDraw(); 163 window.requestAnimationFrame(mainLoop); 164} 165 166export class GLFrame { 167 static gi() { 168 return GLFrame.pinstance_; 169 } 170 constructor() { } 171 172 go(cvs, _draw = null, _touch = null, _key = null, _logic = null) { 173 gl = cvs.getContext('webgl', { premultipliedAlpha: false }); 174 175 this.pCallbackDraw = _draw; 176 this.pCallbackTouch = _touch; 177 this.pCallbackKey = _key; 178 this.pCallbackLogic = _logic; 179 this.pCallbackDropfile = null; 180 181 cvs.addEventListener('touchstart', touchStart); 182 cvs.addEventListener('touchmove', touchMove); 183 cvs.addEventListener('touchend', touchEnd); 184 185 cvs.addEventListener('mousedown', mouseDown); 186 cvs.addEventListener('mousemove', mouseMove); 187 cvs.addEventListener('mouseup', mouseUp); 188 cvs.addEventListener('mousewheel', mouseWheel); 189 190 cvs.addEventListener('drop', (e) => { 191 e.preventDefault(); 192 GLFrame.gi().callbackDropfile(e.dataTransfer.files, e.offsetX, e.offsetY); 193 }); 194 cvs.addEventListener('dragover', (e) => { 195 e.preventDefault(); 196 }); 197 cvs.addEventListener('dragenter', (e) => { 198 e.preventDefault(); 199 }); 200 cvs.focus(); 201 202 document.addEventListener('contextmenu', function (e) { 203 e.preventDefault(); 204 }); 205 206 207 window.addEventListener('keydown', keyDown); 208 window.addEventListener('keyup', keyUp); 209 window.requestAnimationFrame(mainLoop); 210 } 211 callbackKey(type, code) { 212 if (this.pCallbackKey !== null) { 213 this.pCallbackKey(type, code); 214 } 215 } 216 callbackDraw() { 217 gl.clearColor(1.0, 1.0, 1.0, 1.0); 218 gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT); 219 220 if (this.pCallbackDraw !== null) { 221 this.pCallbackDraw(); 222 } 223 } 224 225 callbackProctouch(msg, x, y) { 226 XTools.MOUSE_POS.x = x; 227 XTools.MOUSE_POS.y = y; 228 if (this.pCallbackTouch !== null) { 229 x = (x * Scr.logicw) / Scr.width; 230 y = (y * Scr.logich) / Scr.height; 231 this.pCallbackTouch(msg, x, y); 232 } 233 } 234 callbackDropfile(files, x, y) { 235 if (this.pCallbackDropfile !== null) { 236 this.pCallbackDropfile(files, x, y); 237 } 238 } 239 resize() { 240 gl.viewport(0, 0, Scr.logicw, Scr.logich); 241 X2DFast.gi().resetMat(); 242 } 243} 244 245GLFrame.pinstance_ = new GLFrame(); 246