2022-08-25 06:25:48 +00:00
|
|
|
import NativeClass from "./NativeClass";
|
2022-01-21 03:01:58 +00:00
|
|
|
|
2021-12-28 15:37:22 +00:00
|
|
|
const { ccclass, property } = cc._decorator;
|
|
|
|
|
|
|
|
@ccclass
|
|
|
|
export default class Manager extends cc.Component {
|
2022-08-25 06:25:48 +00:00
|
|
|
//#region 外調參數
|
|
|
|
|
|
|
|
@property({ type: cc.WebView })
|
|
|
|
public webview: cc.WebView = null;
|
|
|
|
|
|
|
|
@property({ type: cc.Node })
|
|
|
|
public BG: cc.Node = null;
|
|
|
|
|
|
|
|
//#endregion
|
|
|
|
|
|
|
|
//#region private
|
|
|
|
|
|
|
|
// private _text_to_Speech: Text_to_Speech;
|
|
|
|
|
|
|
|
//#endregion
|
|
|
|
|
|
|
|
//#region Lifecycle
|
|
|
|
|
|
|
|
protected onLoad(): void {
|
2022-08-29 03:23:54 +00:00
|
|
|
cc.debug.setDisplayStats(false);
|
2022-08-25 06:25:48 +00:00
|
|
|
if (CC_DEBUG) {
|
|
|
|
console.log("Debug");
|
|
|
|
}
|
|
|
|
|
|
|
|
new NativeClass();
|
|
|
|
|
|
|
|
let self: this = this;
|
|
|
|
// this._text_to_Speech = new Text_to_Speech();
|
2022-08-29 01:54:55 +00:00
|
|
|
let href: string = window.location.href;
|
|
|
|
|
|
|
|
// let url: string = `http://220.134.195.1/public/bonus_casino/html5/jianmiau/Test/?host=${href}&v=${Date.now()}`;
|
|
|
|
// let url: string = `https://karolchang.github.io/jm-expense-vue-ts/?host=${href}&ignore=${Date.now()}`;
|
|
|
|
// let url: string = `http://karol.jianmiau.cf/jm-expense-vue-ts/?v=${Date.now()}`;
|
|
|
|
let url: string = `https://jm-expense-2022.firebaseapp.com/login?host=${href}&v=${Date.now()}`;
|
|
|
|
this.webview.url = url;
|
|
|
|
this.webview.node.active = true;
|
|
|
|
|
|
|
|
cc.view.setResizeCallback(this._resize.bind(this));
|
|
|
|
this._resize();
|
|
|
|
|
|
|
|
const FCMToken: string = NativeClass.Instance.GetFCMToken();
|
|
|
|
console.log(`FCMToken ${FCMToken}`);
|
|
|
|
|
|
|
|
// Set EventListener
|
2022-08-25 06:25:48 +00:00
|
|
|
window.addEventListener("message", function (e: MessageEvent<any>): void {
|
|
|
|
let data: any = e.data;
|
|
|
|
let method: string = data.method;
|
|
|
|
let value: any = data.value;
|
2022-08-25 09:49:29 +00:00
|
|
|
if (method) {
|
|
|
|
self.Birdge(method, ...value);
|
|
|
|
}
|
2022-08-25 06:25:48 +00:00
|
|
|
}, false);
|
|
|
|
|
|
|
|
if (!window["Bridge"]) {
|
|
|
|
window["Bridge"] = function (method: string = "", value: string = ""): void {
|
|
|
|
self.Birdge(method, value);
|
|
|
|
};
|
|
|
|
}
|
2022-08-29 05:59:46 +00:00
|
|
|
let scheme: string = "jmka";
|
2022-08-25 09:49:29 +00:00
|
|
|
this.webview.setJavascriptInterfaceScheme(scheme);
|
2022-08-29 01:54:55 +00:00
|
|
|
this.webview.setOnJSCallback((sender: any, url: any) => {
|
2022-08-29 05:56:24 +00:00
|
|
|
let content: string = decodeURI(url.split(`${scheme}://?data=`)[1]);
|
2022-08-29 04:25:51 +00:00
|
|
|
try {
|
|
|
|
let data: JSON = JSON.parse(content);
|
|
|
|
let method: any = data["method"];
|
|
|
|
let value: any = data["value"];
|
|
|
|
if (method) {
|
|
|
|
self.Birdge(method, ...value);
|
|
|
|
}
|
|
|
|
} catch (error) {
|
|
|
|
console.error(error);
|
2022-08-25 09:49:29 +00:00
|
|
|
}
|
|
|
|
});
|
2022-08-25 06:25:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/** 跨版本溝通
|
|
|
|
* @example
|
|
|
|
* CallParent('Speak', '我愛豬涵')
|
|
|
|
*/
|
|
|
|
public Birdge(method: string, value: string = ""): void {
|
|
|
|
let self: this = this;
|
|
|
|
if (method && self[method]) {
|
|
|
|
if (value) {
|
|
|
|
self[method](value);
|
|
|
|
return;
|
|
|
|
} else if (self[method]) {
|
|
|
|
self[method]();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
console.log(`not function: ${method}, value: ${value}`);
|
|
|
|
}
|
|
|
|
|
|
|
|
public CloseBG(): void {
|
|
|
|
this.BG.destroy();
|
|
|
|
}
|
|
|
|
|
|
|
|
public Log(msg: string): void {
|
|
|
|
console.log(msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
public Speak(msg: string): void {
|
|
|
|
// this._text_to_Speech.speak(msg);
|
|
|
|
NativeClass.Instance.TTS_Play(msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
public Alert(msg: string): void {
|
|
|
|
alert(msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
private _resize(): void {
|
|
|
|
let Canvas: cc.Canvas = cc.Canvas.instance;
|
|
|
|
let rect: DOMRect = cc.game.canvas.getBoundingClientRect();
|
|
|
|
/** 判断是否是横屏 */
|
|
|
|
let landscape: boolean = false;
|
|
|
|
if (rect.width > rect.height) {
|
|
|
|
landscape = true;
|
|
|
|
}
|
|
|
|
// 根据横竖屏调整节点的位置适配等
|
|
|
|
let frameSize: cc.Size = cc.view.getFrameSize();
|
|
|
|
if (landscape) {
|
|
|
|
// 横屏
|
|
|
|
cc.view.setOrientation(cc.macro.ORIENTATION_LANDSCAPE);
|
|
|
|
if (frameSize.height > frameSize.width) {
|
|
|
|
cc.view.setFrameSize(frameSize.height, frameSize.width);
|
|
|
|
}
|
|
|
|
Canvas.designResolution = cc.size(1920, 1080);
|
|
|
|
} else {
|
|
|
|
// 竖屏
|
|
|
|
cc.view.setOrientation(cc.macro.ORIENTATION_PORTRAIT);
|
|
|
|
if (frameSize.width > frameSize.height) {
|
|
|
|
cc.view.setFrameSize(frameSize.height, frameSize.width);
|
|
|
|
}
|
|
|
|
Canvas.designResolution = cc.size(1080, 1920);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//#endregion
|
2021-12-28 15:37:22 +00:00
|
|
|
}
|