import * as PIXI from "./pixi.min"
import { TimelineLite, Sine, TweenMax , Back } from "./TweenMax.min"
import {Howl, Howler} from './howler.min'
var gamen = require("./gamen");
(function () {
var XORcipher = function () {
return new XORcipher.fn.init();
};
XORcipher.fn = XORcipher.prototype =
{
constructor: XORcipher,
init:function()
{
return this;
},
//암호화
xorEncoder:function($str, $key)
{
var bytes = [];
for (var i = 0; i < $str.length; ++i)
{
bytes.push($str.charCodeAt(i));
}
var result = [];
for(var i = 0; i < bytes.length; i++)
{
result.push(bytes[i] ^ $key);
}
return result;
},
//복호화
xorDecoder:function($byte, $key)
{
var bytes = [];
for(var i = 0; i < $byte.length; i++)
{
bytes.push($byte[i] ^ $key);
}
var str = String.fromCharCode.apply(String, bytes);
return str;
}
};
window.XORcipher = XORcipher;
}());
XORcipher.fn.init.prototype = XORcipher.fn;
var GD = {};
var DataManager = {};
var GamePadManager = {};
/*Image server*/
var IMG_SERVER = '';
var GAME_IMG_PATH = 'https://pub.dwstatic.com/wxgame/momobakery/';
var COMMON_IMG_PATH = 'https://pub.dwstatic.com/wxgame/momobakery/';
/*JS Server*/
var JS_SERVER = '';
var GAME_JS_PATH = '';
var COMMON_JS_PATH = 'js/common/';
var JS_PATH = '';
var CACHE_VER = 0.2;
var RES_DIR_IMG = GAME_IMG_PATH + 'image/';
var RES_DIR_JSON = RES_DIR_IMG + 'json/';
var RES_DIR_PNG = RES_DIR_IMG + 'png/';
var RES_DIR_SPINE = RES_DIR_IMG + 'spine/';
var RES_DIR_SOUND = GAME_IMG_PATH + 'sound/';
// source code version
var IMG_VERSION = CACHE_VER;
var SOUND_VERSION = CACHE_VER;
!function(t) {
function e(n) {
if (i[n])
return i[n].exports;
var o = i[n] = {
exports: {},
id: n,
loaded: !1
};
return t[n].call(o.exports, o, o.exports, e),
o.loaded = !0,
o.exports
}
var i = {};
return e.m = t,
e.c = i,
e.p = "",
e(0)
}([function(t, e, i) {
i(1),
i(5),
i(10),
i(6),
i(7),
i(9),
i(8),
i(11),
i(12),
i(13),
i(14),
i(15),
i(2),
i(3),
i(4)
}
, function(t, e) {}
, function(t, e) {
PIXI.Container.prototype.setTouchStartAction = function(t, e, i) {
t.mousedown = t.touchstart = function(n) {
n.stopPropagation(),
GD.fullScreen(),
GD.buttonAction(t),
e && e.call(i, n)
}
.bind(i)
}
,
PIXI.Container.prototype.setTouchStart = function(t, e, i) {
t.mousedown = t.touchstart = function(t) {
t.stopPropagation(),
GD.fullScreen(),
e && e.call(i, t)
}
.bind(i)
}
,
PIXI.Container.prototype.setTouchEnd = function(t, e, i) {
t.tap = function(t) {
t.stopPropagation(),
GD.fullScreen(),
e && e.call(i, t)
}
.bind(i),
GD.isMobile || (t.click = function(t) {
t.stopPropagation(),
e && e.call(i, t)
}
.bind(i))
}
,
PIXI.Container.prototype.setTouchMove = function(t, e, i) {
t.mousemove = t.touchmove = function(t) {
t.stopPropagation(),
e && e.call(i, t)
}
.bind(i)
}
,
PIXI.Container.prototype.addGamePadEvent = function() {
this.removeGamePadEvent()
// $(GamePadManager).on("padButton", this.onGamePadEvent.bind(this)),
// $(GamePadManager).on("padStickX", this.onGamePadStickXEvent.bind(this)),
// $(GamePadManager).on("padStickY", this.onGamePadStickYEvent.bind(this))
}
,
PIXI.Container.prototype.removeGamePadEvent = function() {
// $(GamePadManager).off()
}
,
PIXI.Container.prototype.onGamePadEvent = function(t, e) {}
,
PIXI.Container.prototype.onGamePadStickXEvent = function(t, e) {}
,
PIXI.Container.prototype.onGamePadStickYEvent = function(t, e) {}
,
PIXI.Container.prototype.showLoading = function() {
GD.loading = GD.LoadingView.getInstance(),
GD.loading.init(),
this.addChild(GD.loading)
}
,
PIXI.Container.prototype.hideLoading = function() {
this.removeChild(GD.loading)
}
}
, function(t, e) {
GD.CommonIntro = function(t, e) {
PIXI.Container.call(this),
this.helpBtn = null,
this.soundpBtn = null,
this.startBtn = null,
this.callBackFunc = null,
this.callBackTarget = null,
this.bg = this.setSpriteTexture(this.bg, "texture", e),
this.addChild(this.bg),
// this.copyText = this.setSpriteTexture(this.copyText, "texture", "copybar_" + t),
// this.copyText.anchor.set(.5),
// this.copyText.x = GD.width / 2,
// this.copyText.y = GD.height - 20,
// this.addChild(this.copyText),
this.gamePadGuide = null,
this.soundPopup = new GD.OptionPopup,
this.soundPopup.on("SOUND_POPUP_CLOSE_EVENT", this.closeSoundPopup.bind(this)),
gamen.loadend()
}
,
GD.CommonIntro.constructor = GD.CommonIntro,
GD.CommonIntro.prototype = Object.create(PIXI.Container.prototype),
GD.CommonIntro.prototype.init = function() {
GamePadManager.isConnected && GD.isShowPadGuide && (this.gamePadGuide || (this.gamePadGuide = new GD.GamePadGuide),
this.showGamePadGuide(),
this.addGamePadEvent()),
GD.isShowPadGuide = !1,
this.setInteractive(!0)
}
,
GD.CommonIntro.prototype.showGamePadGuide = function() {
this.gamePadGuide.init(),
this.addChild(this.gamePadGuide)
}
,
GD.CommonIntro.prototype.hideGamePadGuide = function() {
this.removeChild(this.gamePadGuide)
}
,
GD.CommonIntro.prototype.initHelp = function(t, e, i) {
this.helpBtn = this.setSpriteTexture(this.helpBtn, "texture", t),
this.helpBtn.anchor.set(.5),
this.helpBtn.x = e,
this.helpBtn.y = i,
this.helpBtn.scale.set(1),
this.addChild(this.helpBtn),
this.setTouchStartAction(this.helpBtn),
this.setTouchEnd(this.helpBtn, this.showHelp, this)
}
,
GD.CommonIntro.prototype.initSound = function(t, e, i) {
this.soundpBtn = this.setSpriteTexture(this.soundpBtn, "texture", t),
this.soundpBtn.anchor.set(.5),
this.soundpBtn.x = e,
this.soundpBtn.y = i,
this.soundpBtn.scale.set(1),
this.addChild(this.soundpBtn),
this.setTouchStartAction(this.soundpBtn),
this.setTouchEnd(this.soundpBtn, this.showSoundPopup, this)
}
,
GD.CommonIntro.prototype.initStart = function(t, e, i, n, o) {
this.startBtn = this.setSpriteTexture(this.startBtn, "texture", t),
this.startBtn.anchor.set(.5),
this.startBtn.x = e,
this.startBtn.y = i,
this.callBackFunc = n,
this.callBackTarget = o,
this.startBtn.scale.set(1),
this.addChild(this.startBtn),
this.setTouchStartAction(this.startBtn),
this.setTouchEnd(this.startBtn, this.sendStartData, this)
}
,
GD.CommonIntro.prototype.onGamePadEvent = function(t, e) {
switch (e) {
case "button-1":
this.hideGamePadGuide(),
this.sendStartData();
break;
case "button-2":
this.hideGamePadGuide(),
this.showHelp();
break;
case "button-3":
this.hideGamePadGuide(),
this.showSoundPopup();
break;
case "button-4":
this.hideGamePadGuide()
}
}
,
GD.CommonIntro.prototype.showHelp = function() {
this.setInteractive(!1),
GD.tutorial.initPage(0, "help_start"),
GD.tutorial.once("TUTORIAL_CLOSE_EVENT", this.hideHelp.bind(this)),
this.addChild(GD.tutorial)
}
,
GD.CommonIntro.prototype.hideHelp = function() {
this.sendStartData()
}
,
GD.CommonIntro.prototype.showSoundPopup = function() {
this.setInteractive(!1),
this.soundPopup.show(0),
this.addChild(this.soundPopup)
}
,
GD.CommonIntro.prototype.closeSoundPopup = function() {
this.removeChild(this.soundPopup),
this.setInteractive(!0)
}
,
GD.CommonIntro.prototype.sendStartData = function() {
this.showLoading(),
DataManager.start(this.startDataComplete, this)
}
,
GD.CommonIntro.prototype.startDataComplete = function() {
this.hideLoading(),
GD.tutorial && this.removeChild(GD.tutorial),
this.callBackFunc.call(this.callBackTarget)
}
,
GD.CommonIntro.prototype.setInteractive = function(t) {
this.helpBtn.interactive = t,
this.soundpBtn.interactive = t,
this.startBtn.interactive = t,
GamePadManager.isConnected && (t ? this.addGamePadEvent() : this.removeGamePadEvent())
}
,
GD.CommonIntro.getInstance = function(t, e) {
return GD.commonIntro || (GD.commonIntro = new GD.CommonIntro(t,e)),
GD.commonIntro
}
}
, function(t, e) {
GD.CommonOption = function(t) {
PIXI.Container.call(this),
this.scorePopup = new GD.ScorePopup,
this.scorePopup.on("SCORE_POPUP_CLOSE_EVENT", this.closeScorePopup.bind(this)),
this.optionPopup = new GD.OptionPopup,
this.optionPopup.on("SOUND_POPUP_CLOSE_EVENT", this.closeOptionPopup.bind(this)),
this.optionPopup.on("TUTORIAL_OPEN_EVENT", this.showTutorial.bind(this)),
this.optBtn = this.setSpriteTexture(this.optBtn, "texture", "btn_option_" + t),
this.optBtn.anchor.set(.5),
this.optBtn.x = GD.width - 40,
this.optBtn.y = 110,
this.setTouchStartAction(this.optBtn),
this.setTouchEnd(this.optBtn, function() {
this.setInteractive(!1),
this.optionPopup.show(1),
this.addChild(this.optionPopup),
this.emit("OPTION_OPEN_EVENT")
}
.bind(this)),
this.achievement = new GD.Achievement
}
,
GD.CommonOption.constructor = GD.CommonOption,
GD.CommonOption.prototype = Object.create(PIXI.Container.prototype),
GD.CommonOption.prototype.init = function() {
this.removeAll(),
this.addChild(this.optBtn),
this.addChild(this.achievement),
this.setInteractive(!0)
}
,
GD.CommonOption.prototype.setAchievement = function(t) {
this.achievement.show(t)
}
,
GD.CommonOption.prototype.setInteractive = function(t) {
this.optBtn.interactive = t
}
,
GD.CommonOption.prototype.closeOptionPopup = function() {
this.removeChild(this.optionPopup),
this.setInteractive(!0),
this.emit("OPTION_CLOSE_EVENT")
}
,
GD.CommonOption.prototype.showTutorial = function() {
GD.tutorial.initPage(0, "help_close"),
GD.tutorial.on("TUTORIAL_CLOSE_EVENT", this.hideHelp.bind(this)),
this.addChild(GD.tutorial)
}
,
GD.CommonOption.prototype.hideHelp = function() {
this.removeChild(GD.tutorial),
this.optionPopup.setInteractive(!0)
}
,
GD.CommonOption.prototype.closeScorePopup = function() {
this.gameRestart()
}
,
GD.CommonOption.prototype.finish = function(t) {
gamen.score_view_status ? (this.scorePopup.show(t),
this.addChild(this.scorePopup)) : (GD.exitFullScreen(),
DataManager.finish(t))
}
,
GD.CommonOption.prototype.gameRestart = function() {
this.emit("GAME_RESTART")
}
,
GD.CommonOption.prototype.removeAll = function() {
this.removeChildren()
}
,
GD.CommonOption.getInstance = function(t) {
return GD.commonOption || (GD.commonOption = new GD.CommonOption(t)),
GD.commonOption
}
}
, function(t, e) {
GD = {
loader: null,
stats: null,
width: 504,
height: 861,
leng: "ko",
isMobile: !1,
isDebug: !1,
isShowLog: !1,
isLogin: !1,
unique: null,
pk: null,
sKey: null,
oKey: null,
startTime: null,
medal: [],
soundType: 1,
isAllSound: !0,
isBgmSound: !0,
isEffectSound: !0,
isShowPadGuide: !0,
orientationType: null,
orientationGuide: null,
sound: {},
darkBg: null,
stage: null,
commonIntro: null,
commonOption: null,
tutorial: null,
loading: null
},
GD.init = function(t, e, i, n, backgroundColor) {
var {pixelRatio, windowWidth, windowHeight} = wx.getSystemInfoSync()
// var gWidth = windowWidth * pixelRatio
// var gHeight = windowHeight * pixelRatio
var gWidth = 720;
var gHeight = 1232;
GD.width = gWidth
GD.height = gHeight
GD.leng = gamen.game_language
var app = GD.app = new PIXI.Application({
width: gWidth,
height: gHeight,
forceCanvas:true,
backgroundColor: backgroundColor,
clearBeforeRender: false,
resolution: 2,
view: canvas
})
var xRatio = windowWidth * pixelRatio / gWidth;
var yRatio = windowHeight * pixelRatio / gHeight;
console.log(xRatio, yRatio);
app.renderer.plugins.interaction.mapPositionToPoint = (point, x, y) => {
point.x = x * pixelRatio / xRatio
point.y = y * pixelRatio / yRatio
}
// requestAnimationFrame(this.update)
this.renderer = app.renderer
this.stage = app.stage
// this.resize()
this.setSpriteTexture()
this.resourceLoad()
// if (GD.width = t,
// GD.height = e,
// GD.leng = gamen.game_language,
// this.renderer = PIXI.autoDetectRenderer(t, e, {
// backgroundColor: backgroundColor,
// resolution: 2,
// clearBeforeRender: !1
// }),
// // $("#gamecontainer")[0] ? ($("#gameCanvas") && $("#gameCanvas").remove(),
// // $("#gamecontainer").append(this.renderer.view)) : document.body.appendChild(this.renderer.view),
// GD.Util.mobileCheck() && (GD.isMobile = !0),
// GD.Util.mobileCheck()) {
// var s = navigator.userAgent.toLowerCase();
// -1 != s.indexOf("android 4.") ? -1 == s.indexOf("chrome") && -1 == s.indexOf("mobile safari") || (GD.soundType = 1) : GD.soundType = 1
// } else
// GD.soundType = 1;
// requestAnimationFrame(this.update),
// this.root = new PIXI.Container,
// this.stage = new PIXI.Container,
// this.root.addChild(this.stage),
// GD.isDebug && (GD.stats = new Stats,
// document.body.appendChild(GD.stats.domElement),
// GD.stats.domElement.style.position = "absolute",
// GD.stats.domElement.style.top = "0px"),
// this.resize(),
// this.setSpriteTexture(),
// this.resourceLoad()
}
,
GD.resourceLoad = function() {
var t = COMMON_IMG_PATH + "image/json/";
GD.loader = PIXI.loader,
GD.loader.add(t + "human_common.json"),
GD.loader.add(t + "human_popup_" + this.leng + ".json")
}
,
GD.showProgress = function() {
GD.progress = new GD.Progress,
GD.progress.show(),
this.stage.addChild(GD.progress)
}
,
GD.hideProgress = function() {
GD.progress.hide(),
this.stage.removeChild(GD.progress)
}
,
GD.resize = function() {
if (GD.renderer) {
var t = GD.width / GD.height
, e = window.innerWidth
, i = window.innerHeight
, n = e / i;
// if ($("#gamecontainer")[0]) {
if(0) {
var o = document.getElementById("gamecontainer");
o.style.color = "#FF0000",
n > t ? (e = i * t,
o.style.width = e + "px",
o.style.height = i + "px",
GD.renderer.view.style.width = e + "px",
GD.renderer.view.style.height = i + "px") : (i = e / t,
o.style.width = e + "px",
o.style.height = i + "px",
GD.renderer.view.style.width = e + "px",
GD.renderer.view.style.height = i + "px")
} else
n > t ? e = i * t : i = e / t,
this.renderer.view.style.width = e + "px",
this.renderer.view.style.height = i + "px"
}
gamen.score_view_status || this.setOrientationGuide()
}
,
GD.render = function() {
GD.renderer.render(GD.root)
}
,
GD.update = function() {
GD.isDebug && GD.stats.begin(),
requestAnimationFrame(GD.update),
GD.render(),
GD.isDebug && GD.stats.end()
}
,
GD.buttonAction = function(t, e, i) {
e || (e = 1.2),
i || (i = 1),
t.scale.set(e),
TweenMax.to(t.scale, .2, {
x: i,
y: i
})
}
,
GD.setSpriteTexture = function() {
PIXI.Container.prototype.setSpriteTexture = function(t, e, i) {
return "sprite" == e ? t ? t.texture = GD.loader.resources[i].texture : t = new PIXI.Sprite(GD.loader.resources[i].texture) : t ? t.texture = PIXI.Texture.fromFrame(i + ".png") : t = new PIXI.Sprite.fromFrame(i + ".png"),
t
}
}
,
GD.getDarkBg = function() {
return GD.darkBg || (GD.darkBg = new PIXI.Graphics,
GD.darkBg.beginFill(0, .8),
GD.darkBg.drawRect(0, 0, GD.width, GD.height),
GD.darkBg.endFill()),
GD.darkBg
}
,
GD.log = function(t) {
GD.isShowLog ? (GD.logStr = t + "\n" + GD.logStr,
GD.logText || (GD.logText = new PIXI.Text("",{
font: "14px Arial",
fill: "#F7EDCA",
stroke: "#000",
strokeThickness: 4,
wordWrapWidth: GD.width - 60,
wordWrap: !0
}),
GD.logText.x = 30,
GD.logText.y = 30),
GD.logText.parent || GD.root.addChild(GD.logText),
GD.logText.text = GD.logStr) : console.log(t)
}
,
GD.fullScreen = function() {
if (GD.isMobile) {
var t = navigator.platform.match(/iPhone|iPod|iPad/);
if (!t) {
var e = GD.renderer.view;
e.requestFullscreen ? e.requestFullscreen() : e.webkitRequestFullScreen ? e.webkitRequestFullScreen() : e.mozRequestFullScreen()
}
}
}
,
GD.exitFullScreen = function() {
if (GD.isMobile) {
var t = navigator.platform.match(/iPhone|iPod|iPad/);
if (!t) {
var e = GD.renderer.view;
e.exitFullscreen ? e.exitFullscreen() : e.mozCancelFullScreen ? e.mozCancelFullScreen() : e.webkitExitFullscreen && e.webkitExitFullscreen()
}
}
}
,
GD.setOrientationGuide = function() {
var t = document.getElementById("rank_layout");
if (t && "none" != t.style.display && com)
return GD.renderer.view.style.display = "none",
void GD.showOrientation(!1);
var e = window.innerWidth / window.innerHeight
, i = GD.width / GD.height;
i > 1 ? GD.orientationType = "phone rotate_x" : GD.orientationType = "phone rotate_y",
e > 1 && 1 > i || 1 > e && i > 1 ? GD.showOrientation(!0) : GD.showOrientation(!1)
}
,
GD.showOrientation = function(t) {
// for (var e = ["Z300C", "TF701T", "TF700T", "TF103C", "TF101-1B251A", "TA2506 10BK", "SM-T805", "SM-T800", "SM-T677", "SM-T670", "SM-P900", "SMP-605", "SMP-600", "SMART-TV", "SmartTV", "SM-905", "SHW-M480W", "SHW-M380", "SHV-E230", "SGP771", "SGP311", "QM0101", "Q109", "MZ68", "MZ601", "MX1080", "MID 1065-8", "MID 1042-8", "ME102A", "LGV940", "LGV700N", "GT-P5110", "FZ-A1", "AT105", "A10-70", "10QS", "10ES"], i = e.length; i--; )
// if (navigator.userAgent.match(e[i]))
// return;
// var n, o, s, r, a, h;
// if (GD.isMobile) {
// var l = document.getElementsByClassName("xy_wrap").length;
// if (t) {
// if (n = GD.orientationGuide,
// null == n) {
// if (n = document.createElement("div"),
// n.style.backgroundColor = "#ff7e17",
// n.style.position = "absolute",
// n.style.left = 0,
// n.style.top = 0,
// n.style.right = 0,
// n.style.bottom = 0,
// n.style.margin = "auto",
// n.setAttribute("class", "xy_wrap"),
// GD.orientationGuide = n,
// o = document.createElement("div"),
// o.setAttribute("class", "xy_info"),
// s = document.createElement("div"),
// s.setAttribute("class", GD.orientationType),
// r = document.createElement("span"),
// r.setAttribute("class", "yes"),
// a = document.createElement("span"),
// a.setAttribute("class", "no"),
// n.appendChild(o),
// o.appendChild(s),
// o.appendChild(r),
// o.appendChild(a),
// h = document.createElement("p"),
// h.style.left = "0px",
// h.style.right = "0px",
// h.style.padding = "15px",
// h.style.lineHeight = "130%",
// h.style.color = "#FFFFFF",
// h.style.position = "absolute",
// "en" == GD.lang)
// h.style.fontSize = "18px",
// h.innerHTML = "Please rotate your device.";
// else {
// var u;
// switch (GD.lang) {
// case "jp":
// u = "お使いの 携?電話を 回?させて 下ください。";
// break;
// case "en":
// u = "ROTATE YOUR PHONE";
// break;
// case "cn":
// u = "如果?幕不能旋?,?打?自?旋?功能。";
// break;
// default:
// u = window.innerWidth > 480 ? "화면 전환이 되지 않는다면, 자동회전 기능을 켜 주세요." : "화면 전환이 되지 않는다면,
자동회전 기능을 켜 주세요."
// }
// h.innerHTML = u
// }
// o.appendChild(h)
// }
// 0 == l && (document.body.appendChild(n),
// GD.orientationChange(!0),
// GD.renderer.view.style.visibility = "hidden")
// } else
// l > 0 && (document.body.removeChild(GD.orientationGuide),
// GD.orientationChange(!1),
// GD.renderer.view.style.visibility = "visible")
// }
}
,
GD.orientationChange = function(t) {
t ? GD.soundMute() : GD.isAllSound && GD.soundUnMute()
}
,
GD.loadSound = function(t, e) {
var index = 0,
options = [],
n = t.length;
for (let o = 0, s = n; s--;) {
let i = t[s];
options[s] = {
key: i,
value: {
src: [RES_DIR_SOUND + i + ".mp3?ver=" + SOUND_VERSION, RES_DIR_SOUND + i + ".ogg?ver=" + SOUND_VERSION, RES_DIR_SOUND + i + ".wav?ver=" + SOUND_VERSION],
onload: function () {
o++;
if (index < n) {
index++;
let option = options[index - 1]
GD.sound[option.key] = new Howl(option.value)
index == n && e();
}
},
onloaderror: function (msg) {
console.error("error:", msg);
o++;
if (index < n) {
index++;
let option = options[index - 1]
GD.sound[option.key] = new Howl(option.value)
index == n && e();
}
}
}
}
}
while (index <= 4) {
let option = options[index]
GD.sound[option.key] = new Howl(option.value);
index++;
}
}
,
GD.bgmPlay = function(t) {
var e = GD.sound.sound_bgm;
e._loop = !0,
t ? e._volume = t : e._volume = .3,
GD.isBgmSound && e.play()
}
,
GD.bgmStop = function() {
GD.sound.sound_bgm.stop()
}
,
GD.soundPlay = function(t, e, i) {
var n = GD.sound[t];
e || (e = 1),
e ? n._volume = e : n._volume = 1,
i ? n._loop = i : n._loop = !1,
GD.isEffectSound && n.play()
}
,
GD.soundStop = function(t) {
GD.isEffectSound && GD.sound[t].stop()
}
,
GD.soundAllStop = function() {
for (var t in GD.sound)
GD.sound[t].stop()
}
,
GD.soundMute = function() {
Howler.mute(!0)
}
,
GD.soundUnMute = function() {
GD.isAllSound && Howler.mute(!1)
}
,
window.onresize = function(t) {
GD.resize()
}
}
, function(t, e) {
DataManager = {},
DataManager.unique = null,
DataManager.pk = null,
DataManager.Skey = null,
DataManager.Okey = null,
DataManager.callFunc = null,
DataManager.target = null,
DataManager.playInterval = null,
DataManager.start = function(t, e) {
DataManager.callFunc = t,
DataManager.target = e,
gamen.start(DataManager.startDataComplete)
}
,
DataManager.startDataComplete = function(t, e, i, n, o) {
if (GD.isLogin = t,
GD.isLogin && (GD.sKey = gamen.spkey(n),
GD.oKey = gamen.opkey(o),
GD.unique = XORcipher().xorDecoder(e, GD.sKey),
GD.pk = i,
GD.startTime = Date.now(),
GD.medal = [],
null != gamen.achievement))
for (var s = gamen.achievement.length, r = 0; s > r; ++r) {
var a = XORcipher().xorDecoder(gamen.achievement[r], GD.sKey)
, h = [];
h = a.split("_gamen_"),
GD.medal[r] = [parseInt(h[0]), !1, parseInt(h[1]), h[2], h[3], parseInt(h[5]), h[4]]
}
DataManager.callFunc.call(DataManager.target),
DataManager.playInterval = setInterval(DataManager.promisePlay, .1)
}
,
DataManager.point = function(t, e) {
if (GD.log(t + " : " + e),
DataManager.otherPoint(t, e),
GD.isLogin) {
t = XORcipher().xorEncoder(t, GD.sKey),
e = XORcipher().xorEncoder(e.toString(), GD.sKey);
var i = Date.now() - GD.startTime
, n = XORcipher().xorEncoder(i.toString(), GD.sKey);
gamen.point(t, e, n)
}
}
,
DataManager.otherPoint = function(t, e) {
if (GD.isLogin) {
t = XORcipher().xorEncoder(t, GD.oKey),
e = XORcipher().xorEncoder(e.toString(), GD.oKey);
var i = Date.now() - GD.startTime
, n = XORcipher().xorEncoder(i.toString(), GD.oKey);
gamen.otherpoint(t, e, n)
}
}
,
DataManager.promisePlay = function() {
var t = Date.now() - GD.startTime
, e = XORcipher().xorEncoder(t.toString(), GD.oKey);
gamen.promiseplay(e)
}
,
DataManager.finish = function(t) {
if (DataManager.playInterval && clearInterval(DataManager.playInterval),
GD.isLogin) {
if (GD.medal.length > 0) {
var e = []
, i = GD.medal.length;
gamen.new_achievement = [];
for (var n = 0; i > n; ++n)
e[n] = GD.medal[n][0] + "_gamen_" + GD.medal[n][2] + "_gamen_" + GD.medal[n][3] + "_gamen_" + GD.medal[n][4] + "_gamen_" + parseInt(GD.medal[n][5]),
gamen.new_achievement[n] = XORcipher().xorEncoder(e[n], GD.sKey)
}
GD.log("finish : " + t);
var o = XORcipher().xorEncoder(t.toString(), GD.sKey)
, s = GD.commonOption.gameRestart.bind(GD.commonOption)
, r = XORcipher().xorEncoder(GD.unique, GD.sKey)
, a = XORcipher().xorEncoder(GD.startTime.toString(), GD.sKey)
, h = Date.now()
, l = XORcipher().xorEncoder(h.toString(), this.sKey);
gamen.finish(GD.pk, o, s, r, a, l)
} else
gamen.finish(t, GD.commonOption.gameRestart.bind(GD.commonOption))
}
,
DataManager.addMedal = function(t, e) {
if (GD.isLogin && GD.medal.length > 0)
for (var i = null, n = 0; n < GD.medal.length; ++n)
if (t == GD.medal[n][0]) {
i = n,
0 == GD.medal[i][1] && (null == e && (e = 1),
GD.medal[i][5] += e,
GD.medal[i][2] <= GD.medal[i][5] && (GD.medal[i][1] = !0,
GD.commonOption.setAchievement(i + 1)));
break
}
}
}
, function(t, e) {
GamePadManager = {
isConnected: !1,
init: function() {
gamepadSupport.init()
},
showNotSupported: function() {},
updateGamePads: function(t) {
if (this.isConnected = !1,
t)
for (var e in t) {
var i = t[e];
i && (this.isConnected = !0)
}
},
updateButton: function(t, e, i) {
// t.pressed && $(this).trigger("padButton", i)
},
updateAxis: function(t, e, i, n, o) {
// "stick-1" == n && ("stick-1-axis-x" == i ? $(this).trigger("padStickX", t) : "stick-1-axis-y" == i && $(this).trigger("padStickY", t))
}
}
}
, function(t, e) {
GD.OptionPopup = function() {
PIXI.Container.call(this),
this.darkBg = GD.getDarkBg(),
this.bg = null,
this.type = null,
this.allBtn = this.setSpriteTexture(this.allBtn, "texture", "option_on_0"),
this.allBtn.anchor.set(.5),
this.allBtn.x = 110,
this.setTouchEnd(this.allBtn, function() {
GD.isAllSound = !GD.isAllSound,
this.setAllSoundBtn(),
this.setBgmBtn(!1),
this.setEffectBtn()
}, this),
this.bgmBtn = this.setSpriteTexture(this.bgmBtn, "texture", "option_on_0"),
this.bgmBtn.anchor.set(.5),
this.bgmBtn.x = this.allBtn.x,
this.setTouchEnd(this.bgmBtn, function() {
GD.isAllSound && (GD.isBgmSound = !GD.isBgmSound,
this.setBgmBtn(!0))
}, this),
this.effectBtn = this.setSpriteTexture(this.effectBtn, "texture", "option_on_0"),
this.effectBtn.anchor.set(.5),
this.effectBtn.x = this.allBtn.x,
this.setTouchEnd(this.effectBtn, function() {
GD.isAllSound && (GD.isEffectSound = !GD.isEffectSound,
this.setEffectBtn())
}, this),
this.closeBtn = this.setSpriteTexture(this.closeBtn, "texture", "option_close_btn"),
this.closeBtn.anchor.set(.5),
this.closeBtn.x = 200,
this.setTouchStartAction(this.closeBtn, function() {
this.emit("SOUND_POPUP_CLOSE_EVENT")
}, this),
this.tutorialBtn = this.setSpriteTexture(this.tutorialBtn, "texture", "option_help_btn"),
this.tutorialBtn.anchor.set(.5),
this.setTouchStartAction(this.tutorialBtn),
this.setTouchEnd(this.tutorialBtn, function() {
this.setInteractive(!1),
this.emit("TUTORIAL_OPEN_EVENT")
}, this)
}
,
GD.OptionPopup.constructor = GD.OptionPopup,
GD.OptionPopup.prototype = Object.create(PIXI.Container.prototype),
GD.OptionPopup.prototype.show = function(t) {
this.removeChild(),
this.type = t;
var e = "option_box_0";
0 == this.type ? (1 == GD.soundType ? (this.closeBtn.y = -185,
this.allBtn.y = -62) : (e = "option_box1_0",
this.closeBtn.y = -92,
this.allBtn.y = 25,
this.allBtn.y = 30),
this.bgmBtn.y = 70,
this.effectBtn.y = 165) : (e = "option_box_1",
1 == GD.soundType ? (this.closeBtn.y = -247,
this.allBtn.y = -124,
this.tutorialBtn.y = 230) : (e = "option_box1_1",
this.closeBtn.y = -148,
this.allBtn.y = -27,
this.tutorialBtn.y = 130),
this.bgmBtn.y = 20,
this.effectBtn.y = 115),
this.addChild(this.darkBg),
this.bg = this.setSpriteTexture(this.bg, "texture", e),
this.bg.anchor.set(.5),
this.bg.x = GD.width / 2,
this.bg.y = GD.height / 2,
this.addChild(this.bg),
this.bg.addChild(this.closeBtn),
this.bg.addChild(this.allBtn),
1 == GD.soundType && (this.bg.addChild(this.bgmBtn),
this.bg.addChild(this.effectBtn)),
1 == this.type && this.bg.addChild(this.tutorialBtn),
this.setAllSoundBtn(),
this.setBgmBtn(!1),
this.setEffectBtn(),
this.bg.scale.set(.1),
TweenMax.to(this.bg.scale, .15, {
x: 1,
y: 1,
ease: Back.easeOut,
onComplete: this.showComplete.bind(this)
})
}
,
GD.OptionPopup.prototype.showComplete = function() {
this.setInteractive(!0)
}
,
GD.OptionPopup.prototype.hide = function() {
this.removeChild()
}
,
GD.OptionPopup.prototype.setAllSoundBtn = function() {
GD.isAllSound ? (this.allBtn = this.setSpriteTexture(this.allBtn, "texture", "option_on_0"),
GD.soundUnMute()) : (this.allBtn = this.setSpriteTexture(this.allBtn, "texture", "option_off_0"),
GD.soundMute())
}
,
GD.OptionPopup.prototype.setBgmBtn = function(t) {
GD.isAllSound ? (GD.isBgmSound ? this.bgmBtn = this.setSpriteTexture(this.bgmBtn, "texture", "option_on_0") : this.bgmBtn = this.setSpriteTexture(this.bgmBtn, "texture", "option_off_0"),
t && 1 == this.type && (GD.isBgmSound ? GD.bgmPlay() : GD.bgmStop())) : GD.isBgmSound ? this.bgmBtn = this.setSpriteTexture(this.bgmBtn, "texture", "option_on_1") : this.bgmBtn = this.setSpriteTexture(this.bgmBtn, "texture", "option_off_1")
}
,
GD.OptionPopup.prototype.setEffectBtn = function() {
GD.isAllSound ? GD.isEffectSound ? this.effectBtn = this.setSpriteTexture(this.effectBtn, "texture", "option_on_0") : this.effectBtn = this.setSpriteTexture(this.effectBtn, "texture", "option_off_0") : GD.isEffectSound ? this.effectBtn = this.setSpriteTexture(this.effectBtn, "texture", "option_on_1") : this.effectBtn = this.setSpriteTexture(this.effectBtn, "texture", "option_off_1")
}
,
GD.OptionPopup.prototype.setInteractive = function(t) {
this.allBtn.interactive = t,
this.bgmBtn.interactive = t,
this.effectBtn.interactive = t,
this.tutorialBtn.interactive = t,
this.closeBtn.interactive = t
}
,
GD.OptionPopup.prototype.removeChild = function() {
this.removeChildren(),
this.bg && this.bg.removeChildren(),
this.setInteractive(!1)
}
}
, function(t, e) {
GD.ScorePopup = function() {
PIXI.Container.call(this),
this.darkBg = GD.getDarkBg(),
this.bg = this.setSpriteTexture(this.allBtn, "texture", "gameOver_box"),
this.bg.anchor.set(.5),
this.bg.x = GD.width / 2,
this.bg.y = GD.height / 2,
this.closeBtn = this.setSpriteTexture(this.closeBtn, "texture", "option_close_btn"),
this.closeBtn.anchor.set(.5),
this.closeBtn.x = 267,
this.closeBtn.y = -88,
this.setTouchStartAction(this.closeBtn, function() {
this.emit("SCORE_POPUP_CLOSE_EVENT")
}, this),
this.bg.addChild(this.closeBtn),
this.pointTxt = new gc.NumberText("gameOver_num_","center",-12),
this.pointTxt.y = 8,
this.bg.addChild(this.pointTxt)
}
,
GD.ScorePopup.constructor = GD.ScorePopup,
GD.ScorePopup.prototype = Object.create(PIXI.Container.prototype),
GD.ScorePopup.prototype.show = function(t) {
this.removeChild(),
this.pointTxt.setValue(t),
this.addChild(this.darkBg),
this.addChild(this.bg),
this.bg.scale.set(.1),
TweenMax.to(this.bg.scale, .15, {
x: 1,
y: 1,
ease: Back.easeOut,
onComplete: this.showComplete.bind(this)
})
}
,
GD.ScorePopup.prototype.showComplete = function() {
this.setInteractive(!0)
}
,
GD.ScorePopup.prototype.setInteractive = function(t) {
this.closeBtn.interactive = t
}
,
GD.ScorePopup.prototype.removeChild = function() {
this.setInteractive(!1),
this.removeChildren()
}
}
, function(t, e) {
GD.Util = {
zeroStr: function(t, e) {
for (var i = t.toString(), n = e - i.length; n--; )
i = "0" + i;
return i
},
randomNumber: function(t, e) {
var i = 10 * e || 1;
return Math.floor(Math.random() * t * i / i)
},
hitTest: function(t, e) {
return e.x >= t.x && e.x <= t.x + t.width && e.y >= t.y && e.y <= t.y + t.height
},
uniqueArray: function(t) {
for (var e = [], i = 0, n = t.length; n > i; i++)
-1 === e.indexOf(t[i]) && "" !== t[i] && e.push(t[i]);
return e
},
comma: function(t) {
return t = String(t),
t.replace(/(\d)(?=(?:\d{3})+(?!\d))/g, "$1,")
},
shuffle: function(t) {
var e, i, n;
for (n = t.length; n; n--)
e = Math.floor(Math.random() * n),
i = t[n - 1],
t[n - 1] = t[e],
t[e] = i
},
grep: function(t, e) {
return jQuery.grep(t, function(t) {
return t != e
})
},
getParam: function(t) {
var e = window.location.search.match(new RegExp("(?:[?&]" + t + "=)([^&]+)"));
return e ? e[1] : null
},
mobileCheck: function() {
return !!(navigator.userAgent.match(/Android/i) || navigator.userAgent.match(/webOS/i) || navigator.userAgent.match(/iPhone/i) || navigator.userAgent.match(/iPad/i) || navigator.userAgent.match(/iPod/i) || navigator.userAgent.match(/BlackBerry/i) || navigator.userAgent.match(/Windows Phone/i))
},
radiansToDegrees: function(t) {
return t * Math.PI / 180
},
degreesToradians: function(t) {
return 180 * t / Math.PI
}
}
}
, function(t, e) {
GD.Achievement = function() {
PIXI.Container.call(this),
this.icons = [],
this.idx = 0
}
,
GD.Achievement.constructor = GD.Achievement,
GD.Achievement.prototype = Object.create(PIXI.Container.prototype),
GD.Achievement.prototype.show = function(t, e) {
var i = this.setSpriteTexture(null, "texture", "medal_box");
i.anchor.set(.5),
i.scale.set(.3),
i.idx = this.idx,
i.x = GD.width + 50,
e ? i.y = e : i.y = 140,
this.icons.length > 0 && (i.y += 100 * this.icons.length),
GD.log("game_medal_" + t);
var n = this.setSpriteTexture(null, "sprite", "game_medal_" + t);
n.anchor.set(.5),
n.y = -30,
i.addChild(n),
this.addChild(i),
this.icons.push(i),
setTimeout(function() {
TweenMax.to(i, .5, {
x: GD.width - 50,
ease: Back.easeOut,
onComplete: this.iconHide.bind(this),
onCompleteParams: [i]
})
}
.bind(this), 3),
this.idx++
}
,
GD.Achievement.prototype.iconHide = function(t) {
TweenMax.to(t, .5, {
x: GD.width + 50,
delay: 2,
ease: Back.easeIn,
onComplete: function() {
for (var e, i = this.icons.length; i--; )
if (e = this.icons[i],
e.idx == t.idx) {
this.icons.splice(i, 1),
this.removeChild(e);
break
}
}
.bind(this)
})
}
,
GD.Achievement.prototype.removeAll = function() {
this.removeChildren()
}
}
, function(t, e) {
GD.GamePadGuide = function() {
PIXI.Container.call(this),
this.guide = this.setSpriteTexture(this.guide, "sprite", "gamePadGuide"),
this.setTouchEnd(this.guide, function() {
this.setInteractive(!1),
this.removeChild(this.guide),
this.emit("GAME_PAD_GUIDE_CLOSE_EVENT")
}
.bind(this))
}
,
GD.GamePadGuide.constructor = GD.GamePadGuide,
GD.GamePadGuide.prototype = Object.create(PIXI.Container.prototype),
GD.GamePadGuide.prototype.init = function() {
this.removeChild(),
this.addChild(this.guide),
this.setInteractive(!0)
}
,
GD.GamePadGuide.prototype.setInteractive = function(t) {
this.guide.interactive = t
}
,
GD.GamePadGuide.prototype.removeChild = function() {
this.removeChildren()
}
}
, function(t, e) {
GD.LoadingView = function() {
PIXI.Container.call(this),
this.darkBg = GD.getDarkBg(),
this.img = this.setSpriteTexture(null, "texture", "loadingCircle"),
this.img.scale.set(.8),
this.img.anchor.set(.5),
this.img.x = GD.width / 2,
this.img.y = GD.height / 2,
this.addChild(this.img)
}
,
GD.LoadingView.constructor = GD.LoadingView,
GD.LoadingView.prototype = Object.create(PIXI.Container.prototype),
GD.LoadingView.prototype.init = function() {
this.removeAll(),
this.addChild(this.darkBg),
this.addChild(this.img)
}
,
GD.LoadingView.prototype.removeAll = function() {
this.removeChildren()
}
,
GD.LoadingView.prototype.updateTransform = function() {
PIXI.Container.prototype.updateTransform.call(this),
this.img.rotation += .1
}
,
GD.LoadingView.getInstance = function() {
return GD.loading || (GD.loading = new GD.LoadingView),
GD.loading
}
}
, function(t, e) {
GD.Progress = function() {
this.bg = null,
this.logo = null,
this.logoTxt = null,
// this.tween = null,
PIXI.Container.call(this)
}
,
GD.Progress.constructor = GD.Progress,
GD.Progress.prototype = Object.create(PIXI.Container.prototype),
GD.Progress.prototype.show = function() {
if (this.bg || (this.bg = new PIXI.Graphics,
this.bg.beginFill(16777215, 1),
this.bg.drawRect(0, 0, GD.width, GD.height),
this.bg.endFill()),
this.addChild(this.bg),
!this.logo) {
var logo = ""
this.logo = new PIXI.Sprite.fromImage(logo)
}
this.logo.x = GD.width / 2,
this.logo.y = GD.height / 2,
this.logo.anchor.set(.5),
this.logo.scale.set(.1),
this.logo.rotation = 20,
this.addChild(this.logo),
this.tween ? this.tween.kill() : this.tween = new TimelineLite,
this.tween.to(this.logo, 1, {
rotation: 0,
ease: Sine.easeOut
}),
this.tween.call(this.showLocoText.bind(this)),
TweenMax.to(this.logo.scale, 1, {
x: 1,
y: 1
})
}
,
GD.Progress.prototype.showLocoText = function() {
if (!this.logoTxt) {
var logoTxt = ""
this.logoTxt = new PIXI.Sprite.fromImage(logoTxt),
this.logoTxt.anchor.set(.5),
this.logoTxt.scale.set(1),
this.logoTxt.y = GD.height / 2
}
this.logoTxt.x = GD.width / 2 + 65,
this.logoTxt.alpha = 0,
this.addChild(this.logoTxt),
TweenMax.to(this.logo, .4, {
x: GD.width / 2 - 110,
ease: Sine.easeOut
}),
TweenMax.to(this.logoTxt, .4, {
x: GD.width / 2 + 90,
alpha: 1,
ease: Sine.easeOut
}),
TweenMax.delayedCall(2, this.replay.bind(this))
}
,
GD.Progress.prototype.replay = function() {
this.hide(),
this.show()
}
,
GD.Progress.prototype.hide = function() {
TweenMax.killAll(),
// this.tween.clear(),
this.removeChildren()
}
,
GD.Progress.prototype.updateTransform = function() {
PIXI.Container.prototype.updateTransform.call(this)
}
}
, function(t, e) {
GD.Tutorial = function() {
PIXI.Container.call(this),
this.type = 1,
this.tutorialImg = null,
this.nowPage = 0,
this.totalPage = 0,
this.contents = [],
this.container = new PIXI.Container,
this.img = this.setSpriteTexture(this.img, "texture", "temp"),
this.prevBtn = this.setSpriteTexture(this.prevBtn, "texture", "temp"),
this.prevBtn.anchor.set(.5),
this.prevBtn.x = 30,
this.prevBtn.y = GD.height / 2,
this.setTouchStartAction(this.prevBtn, function() {
this.nowPage > 0 && this.initPage(this.nowPage - 1)
}, this),
this.addChild(this.prevBtn),
this.nextBtn = this.setSpriteTexture(this.nextBtn, "texture", "temp"),
this.nextBtn.anchor.set(.5),
this.nextBtn.x = GD.width - 30,
this.nextBtn.y = GD.height / 2,
this.setTouchStartAction(this.nextBtn, function() {
this.nowPage + 1 < this.totalPage && this.initPage(this.nowPage + 1)
}, this),
this.addChild(this.nextBtn),
this.closeBtn = this.setSpriteTexture(this.closeBtn, "texture", "temp"),
this.closeBtn.anchor.set(.5),
this.closeBtn.x = GD.width / 2,
this.closeBtn.y = GD.height - 105,
this.setTouchStartAction(this.closeBtn),
this.setTouchEnd(this.closeBtn, function() {
this.emit("TUTORIAL_CLOSE_EVENT")
}, this),
this.addChild(this.closeBtn)
}
,
GD.Tutorial.constructor = GD.Tutorial,
GD.Tutorial.prototype = Object.create(PIXI.Container.prototype),
GD.Tutorial.prototype.init = function(t, e) {
this.removeChild(),
this.type = 1,
this.tutorialImg = e,
this.nowPage = 0,
this.totalPage = t,
this.addChild(this.img),
this.addChild(this.closeBtn),
this.initPageButton(),
this.setTutorialImg(),
this.setInteractive(!0),
this.setButtons()
}
,
GD.Tutorial.prototype.initContent = function(t, e) {
this.removeChild(),
this.type = 2,
this.nowPage = 0,
this.totalPage = t,
this.contents = e,
this.addChild(this.container),
this.addChild(this.closeBtn),
this.container.addChild(this.contents[0]),
this.setContent(),
this.initPageButton(),
this.setInteractive(!0),
this.setButtons()
}
,
GD.Tutorial.prototype.initPage = function(t, e) {
this.nowPage = t,
e && (this.closeBtn = this.setSpriteTexture(this.closeBtn, "texture", e)),
1 == this.type ? this.setTutorialImg() : this.setContent(),
this.setButtons()
}
,
GD.Tutorial.prototype.initPageButton = function() {
this.totalPage > 0 && (this.prevBtn = this.setSpriteTexture(this.prevBtn, "texture", "help_prev"),
this.nextBtn = this.setSpriteTexture(this.nextBtn, "texture", "help_next"),
this.prevBtn.scale.set(1),
this.nextBtn.scale.set(1),
this.addChild(this.prevBtn),
this.addChild(this.nextBtn))
}
,
GD.Tutorial.prototype.setPrevButtonPos = function(t, e) {
this.prevBtn.x = t,
this.prevBtn.y = e
}
,
GD.Tutorial.prototype.setNextButtonPos = function(t, e) {
this.nextBtn.x = t,
this.nextBtn.y = e
}
,
GD.Tutorial.prototype.setCloseButtonPos = function(t, e) {
this.closeBtn.x = t,
this.closeBtn.y = e
}
,
GD.Tutorial.prototype.setTutorialImg = function() {
this.img = this.setSpriteTexture(this.img, "texture", this.tutorialImg + (this.nowPage + 1))
}
,
GD.Tutorial.prototype.setContent = function() {
this.container.removeChildren();
var t = this.contents[this.nowPage];
t.init && t.init(),
this.container.addChild(t)
}
,
GD.Tutorial.prototype.setButtons = function() {
this.totalPage > 0 && (0 == this.nowPage ? (this.prevBtn.alpha = .3,
this.nextBtn.alpha = 1,
this.prevBtn.interactive = !1,
this.nextBtn.interactive = !0) : this.nowPage + 1 == this.totalPage ? (this.prevBtn.alpha = 1,
this.nextBtn.alpha = .3,
this.prevBtn.interactive = !0,
this.nextBtn.interactive = !1) : (this.prevBtn.alpha = 1,
this.nextBtn.alpha = 1,
this.prevBtn.interactive = !0,
this.nextBtn.interactive = !0))
}
,
GD.Tutorial.prototype.setInteractive = function(t) {
this.prevBtn.interactive = t,
this.nextBtn.interactive = t,
this.closeBtn.interactive = t
}
,
GD.Tutorial.prototype.removeChild = function() {
this.setInteractive(!1),
this.container.removeChildren(),
this.removeChildren()
}
,
GD.Tutorial.getInstance = function() {
return GD.tutorial || (GD.tutorial = new GD.Tutorial),
GD.tutorial
}
}
]);
module.exports.GD = GD;
var {pixelRatio, windowWidth, windowHeight} = wx.getSystemInfoSync()
var gWidth = windowWidth * pixelRatio
var gHeight = windowHeight * pixelRatio
var gc = {
loader:null,
stats:null,
width:gWidth,
height:gHeight,
stage:null,
intro:null,
tutorial:null,
game:null
};
gc.MovieClip = function(fileName, start, end, speed, repeat) {
PIXI.extras.AnimatedSprite.call(this, this.getRepeatTexture(fileName, start, end, repeat));
this.animationSpeed = speed;
this.play();
};
gc.MovieClip.constructor = gc.MovieClip;
gc.MovieClip.prototype = Object.create(PIXI.extras.AnimatedSprite.prototype);
gc.MovieClip.prototype.setAnimation = function(fileName, start, end, speed, repeat){
this.textures = this.getRepeatTexture(fileName, start, end, repeat);
this.animationSpeed = speed;
};
gc.MovieClip.prototype.getRepeatTexture = function(fileName, start, end, repeat){
var textures = [];
var i = repeat || 1;
while(i--){
textures = textures.concat(this.getTexture(fileName, start, end));
}
return textures;
};
gc.MovieClip.prototype.getTexture = function(fileName, start, end){
start = start || 1;
var textures = [],
i = end - start + 1,
j = start;
while(i--) {
if(j < 10){textures.push(PIXI.Texture.fromFrame(fileName + '0' + j + '.png'));}
else {textures.push(PIXI.Texture.fromFrame(fileName + j + '.png'));}
j++;
}
return textures;
};
gc.MovieClip.prototype.updateTransform = function() {
PIXI.extras.AnimatedSprite.prototype.updateTransform.call(this);
};
gc.NumberText = function(fileName, align, space, iconName, iconAlign, strLen) {
this.CENTER = 'center';
this.RIGHT = 'right';
this.value = 0;
this.isChange = false;
this.list = [];
this.tmpList = [];
this.fileName = fileName;
this.align = align;
this.space = space;
this.iconName = iconName;
this.iconAlign = iconAlign;
this.strLen = strLen;
this.icon = null;
PIXI.Container.call(this);
this.container = new PIXI.Container();
this.addChild(this.container);
this.setValue(0);
};
gc.NumberText.constructor = gc.NumberText;
gc.NumberText.prototype = Object.create(PIXI.Container.prototype);
gc.NumberText.prototype.setValue = function(value){
this.value = value;
this.isChange = true;
};
gc.NumberText.prototype.getNumberSprite = function(num){
var sprite, name = this.fileName + num + '.png';
if(this.tmpList.length > 0){
sprite = this.tmpList.shift();
sprite.texture = PIXI.Texture.fromFrame(name);
}else{
sprite = PIXI.Sprite.fromFrame(name);
}
return sprite;
};
gc.NumberText.prototype.removeAll = function(){
var txt, i = this.list.length;
while(i--){
txt = this.list.shift();
this.tmpList.push(txt);
}
if(this.container) this.container.removeChildren();
};
gc.NumberText.prototype.updateTransform = function() {
if(this.isChange){
this.removeAll();
var numStr = this.value.toString();
if(this.strLen) numStr = Util.zeroStr(this.value, this.strLen);
var index = 0, txt,
space = 0,
i = numStr.length;
if(this.iconName){
if(!this.icon) this.icon = PIXI.Sprite.fromFrame(this.iconName + '.png');
this.container.addChild(this.icon);
if(this.iconAlign == 'left'){
space += this.icon.width + this.space;
}
}
while(i--){
txt = this.getNumberSprite(parseInt(numStr.substr(index, 1))+1);
txt.x = space;
space += txt.width + this.space;
index++;
this.container.addChild(txt);
this.list[i] = txt;
}
if(this.iconAlign == 'right'){
this.icon.x = space;
space += this.icon.width + this.space;
}
if(this.align == this.CENTER){
this.container.x = -space/2;
}else if(this.align == this.RIGHT){
this.container.x = -space;
}
this.isChange = false;
}
PIXI.Container.prototype.updateTransform.call(this);
};
gc.GameScene = function(){
PIXI.Container.call(this);
this.lastEventTime = undefined; //Time the click occurred
//120
this.cookieMatrixPos = [[75,550], [170,550], [265,550], [360,550], [455,550], [550,550], [645,550],
[75,645], [170,645], [265,645], [360,645], [455,645], [550,645], [645,645],
[75,740], [170,740], [265,740], [360,740], [455,740], [550,740], [645,740],
[75,835], [170,835], [265,835], [360,835], [455,835], [550,835], [645,835],
[75,935], [170,935], [265,935], [360,935], [455,935], [550,935], [645,935],
[75,1030], [170,1030], [265,1030], [360,1030], [455,1030], [550,1030], [645,1030],
[75,1125], [170,1125], [265,1125], [360,1125], [455,1125], [550,1125], [645,1125]];
this.cookieNumMatrix = [];
this.cookieMatrix = [];
this.itemEffectMc = [];
this.bombAnerge = 0;
this.bombfull = 50;
this.fixArr1 = [];
this.fixArr2 = [];
this.readytxt = true;
this.starttxt = false;
this.playGame = false;
this.addPoint = 0;
this.itemIndex = undefined;
this.itemIndex1 = undefined;
this.itemIndex2 = undefined;
this.itemIndexes = [];
this.canClick = false;
this.hint = [];
this.giveHint = false;
this.bundle = [];
this.prestageMode = 'normal';
this.stageMode = 'normal';
this.chance = 60;
this.useItem = false;
this.remembers = [];//Store cookies like items
this.combo = 0;
this.restComboTime = 0;
this.lastTime = undefined;
this.totalCombo = 0; //Combo 3 times or more .. Medal 1, Combo 100 times or more .. Medal 4
this.champagneCombo = 0; //Champagne 10 times .. Medals 2
this.bombCombo = 0; //Bomb item 10 times .. Medals 3
this.getMedal1 = false;
this.getMedal2 = false;
this.getMedal3 = false;
this.getMedal4 = false;
this.callfevercnt = 0;
this.lastEnd = false; //To prevent timeup if last fang
this.bumpscale = 0.01;
this.pauseMode = false;
this.pauseTime = 0;
this.exceptSound = false; //During mode change = To inform the fiver sound only once when using the item
};
gc.GameScene.constructor = gc.GameScene;
gc.GameScene.prototype = Object.create(PIXI.Container.prototype);
gc.GameScene.prototype.init = function() {
this.readytxt = true;
this.starttxt = false;
this.declareObjects();
this.setBG();
this.readyGame();
this.fever = setInterval(this.setFever.bind(this), 33.333);
this.test = true;
this.explode();
this.stageMode = 'fever';
this.actFever(); //Make a one-time call to resolve the bug in the first peer
//Return to default mode
this.stageMode = 'normal';
this.normalMode();
};
//Create Object
gc.GameScene.prototype.declareObjects = function () {
this.bomb = new PIXI.Sprite.fromFrame('bomb_0001.png');
this.bombgauge = new PIXI.Sprite.fromFrame('bomb_gauge_bar_0001.png');
this.chanceImg= new gc.NumberText('score_num_', 'center', -4);
this.readyBG = new PIXI.Sprite(GD.loader.resources['ready_bg'].texture);
this.readyImg = new PIXI.Sprite.fromFrame('ready_0001.png');
this.startImg = new PIXI.Sprite.fromFrame('start_0001.png');
this.gameoverImg = new PIXI.Sprite.fromFrame('gameover.png');
for(var i=0; i 6){
this.scanIndex = i;
this.useItem = true;
if (this.cookieNumMatrix[i] == 10) {this.actBomb(i);}
else if (this.cookieNumMatrix[i] == 9) {this.actEqual(i);}
else if (this.cookieNumMatrix[i] == 8) {
this.crossIndex = i;
this.actCross(i);
}
break;
} else {count++;}
}
if(count == this.cookieNumMatrix.length) {
this.itemOver = true;
this.checkMatching3();
}
};
//게임오버===========================================================================================================
gc.GameScene.prototype.setGameOver = function(){
this.canClick = false;
this.playGame = false;
this.checkLeftItem();
if(this.lastEnd) {
this.timeup.anchor.set(0.5);
this.timeup.position.x = this.gameBG.width / 2;
this.timeup.position.y = GD.height/2+50;
this.timeup.scale.x = 0;
this.timeup.scale.y = 0;
this.addChild(this.timeup);
GD.soundPlay('sound_momotime');
this.canClick = false;
this.removeChild(this.hintMc1);
this.removeChild(this.hintMc2);
if (this.real1 != undefined) {this.real1.alpha = 1;}
if (this.real2 != undefined) {this.real2.alpha = 1;}
this.reachmax = false;
this.incdgree = 0.15;
this.stageMode = 'momotime';
this.playGame = false;
this.otherMode();
this.actfeverEffect();
this.momotime = setInterval(this.showMomoTime.bind(this), 33.333);
}
else {//아이템이 없으면 모모타임 이미지, 소리 없이 끝내기
this.lastPang();
}
};
gc.GameScene.prototype.checkLeftItem = function () {
this.lastEnd = false;
for(var i=0; i7) {
this.lastEnd = true;
}
}
};
gc.GameScene.prototype.showMomoTime = function () {
if(this.reachmax && this.timeup.scale.x <= 1) {
this.incdgree = 0;
setTimeout(this.delay.bind(this), 1000);
clearInterval(this.momotime);
}
if(this.timeup.scale.x >= 1.3){
this.incdgree *= -1;
this.reachmax = true;
}
this.timeup.scale.x += this.incdgree;
this.timeup.scale.y += this.incdgree;
};
gc.GameScene.prototype.delay = function () {
this.dropmomotime = setInterval(this.dropMomoTime.bind(this),33.333);
};
gc.GameScene.prototype.dropMomoTime = function () {
this.timeup.scale.y = 1.2;
this.timeup.position.y += 70;
if(this.timeup.position.y >= gc.height+this.timeup.height){
this.removeChild(this.timeup);
//모모타임이 되고 나서 제일 첫 lastpang
this.lastPang();
clearInterval(this.dropmomotime);
}
};
gc.GameScene.prototype.setScore = function(){
this.scoreTxt.x = 355;
this.scoreTxt.y = 45;
this.scoreTxt.scale.x = 0.8;
this.scoreTxt.scale.y = 0.8;
this.score = 0;
this.scoreTxt.setValue(this.score);
this.shadowContainer.addChild(this.chanceImg);
this.shadowContainer.addChild(this.scoreTxt);
};
gc.GameScene.prototype.setBomb = function() {
this.bomb.anchor.set(0.5);
this.bomb.x = 69;
this.bomb.y = 211;
//this.bomb.alpha = 0;
this.bombgauge.anchor.x = 0.5;
this.bombgauge.anchor.y = 1;
this.bombgauge.position.x = 69;
this.bombgauge.position.y = 448;
this.addChild(this.bombgauge);
this.addChild(this.bomb);
};
gc.GameScene.prototype.setCookies = function() {
for(var i=0; i= 5) {
if (!this.giveHint && this.playGame) this.showHint();
}
}else{
if(this.pauseTime == 0) this.pauseTime = now;
}
};
gc.GameScene.prototype.findHint = function () {
var temp = undefined;
var index = undefined;
var check1 = undefined;
var check2 = undefined;
this.hint = [];
//오른쪽 맨 끝 열은 체크안해도 됨
for(var i=0; i<6; i++){
for(var j=0; j<7; j++){
index = i + j*7;
temp = this.cookieNumMatrix[index];
this.cookieNumMatrix[index] = this.cookieNumMatrix[index+1];
this.cookieNumMatrix[index+1] = temp;
check1 = this.checkMatching1();
this.cookieNumMatrix[index+1] = this.cookieNumMatrix[index];
this.cookieNumMatrix[index] = temp;
if(check1) this.hint.push([index, index+1]);
}
}
//맨 아래 행은 체크 안해도 됨
for(var i=0; i<7; i++){
for(var j=0; j<6; j++){
index = i+ j*7;
temp = this.cookieNumMatrix[index];
this.cookieNumMatrix[index] = this.cookieNumMatrix[index+7];
this.cookieNumMatrix[index+7] = temp;
check2 = this.checkMatching1();
this.cookieNumMatrix[index+7] = this.cookieNumMatrix[index];
this.cookieNumMatrix[index] = temp;
if(check2) this.hint.push([index, index+7]);
}
}
//맞춰지는 블럭 없을 때 다시 그리기
if(this.hint.length == 0){
for(var i=0; i6) {
this.scanIndex = index;
if(this.chance>0) {
this.chance--;
this.rangeChance();
}
this.useItem = true;
this.lastEventTime = Date.now();
this.giveHint = false;
this.removeChild(this.hintMc1);
this.removeChild(this.hintMc2);
if(this.real1 != undefined) this.real1.alpha = 1;
if(this.real2 != undefined) this.real2.alpha = 1;
if (this.cookieNumMatrix[index] == 10) {
if (this.canClick) this.actBomb(index);
} else if (this.cookieNumMatrix[index] == 9) {
if (this.canClick) this.actEqual(index);
} else if (this.cookieNumMatrix[index] == 8) {
this.crossIndex = index;
if (this.canClick) this.actCross(index);
}
this.combo++;
this.totalCombo++;
if(this.combo>=15) {this.stageMode = 'superfever';}
else if(this.combo>=5){
this.stageMode = 'fever';
this.callfevercnt = 0;
} else{this.stageMode = 'normal';}
this.lastTime = Date.now();
this.restComboTime = 3;
this.canClick = false;
}else this.useItem = false;
};
//스와핑==================================================================================
gc.GameScene.prototype.swap = function(clickIndex){
var gapX = this.currentX - this.previousX;
var gapY = this.currentY - this.previousY;
//힌트 movieclip삭제
this.removeChild(this.hintMc1);
this.removeChild(this.hintMc2);
//힌트애니메이션동안 안보였던 원래 텍스쳐 보이게 하기
if(this.real1 != undefined) this.real1.alpha = 1;
if(this.real2 != undefined) this.real2.alpha = 1;
//왼쪽 쿠키랑 바꾸기
if((gapX<0) && (Math.abs(gapX)>Math.abs(gapY))){
if(clickIndex%7 != 0){
this.lastEventTime = Date.now();
this.canClick = false;
this.swapLeft(clickIndex);
return;
}
}
//오른쪽
if((gapX>0) && (Math.abs(gapX)>Math.abs(gapY))){
if((clickIndex%7) != 6 || (clickIndex==0)){
this.lastEventTime = Date.now();
this.canClick = false;
this.swapRight(clickIndex);
return;
}
}
//위쪽
if((gapY<0) && (Math.abs(gapX) 6){
this.lastEventTime = Date.now();
this.canClick = false;
this.swapUp(clickIndex);
return;
}
}
//아래쪽
if((gapY>0) && (Math.abs(gapX)=15) {this.stageMode = 'superfever';}
else if(this.combo>=5){
this.stageMode = 'fever';
this.callfevercnt = 0;
} else{this.stageMode = 'normal';}
this.lastTime = Date.now();
this.restComboTime = 3;
this.rangeChance();
//스와핑 효과 보이기
this.cookieMatrix[selectIndex].texture = tempTexture2;
this.cookieMatrix[selectIndex - 1].texture = tempTexture1;
TweenMax.from(this.cookieMatrix[selectIndex], 0.1, {x: this.cookieMatrixPos[selectIndex - 1][0], onComplete:(function () {
for(var i=0; i=15) {this.stageMode = 'superfever';}
else if(this.combo>=5){
this.stageMode = 'fever';
this.callfevercnt = 0;
} else{this.stageMode = 'normal';}
this.lastTime = Date.now();
this.restComboTime = 3;
this.rangeChance();
this.cookieMatrix[selectIndex].texture = tempTexture2;
this.cookieMatrix[selectIndex + 1].texture = tempTexture1;
TweenMax.from(this.cookieMatrix[selectIndex], 0.1, {x: this.cookieMatrixPos[selectIndex + 1][0], onComplete:(function () {
for(var i=0; i=15) {this.stageMode = 'superfever';}
else if(this.combo>=5){
this.stageMode = 'fever';
this.callfevercnt = 0;
} else{this.stageMode = 'normal';}
this.lastTime = Date.now();
this.restComboTime = 3;
this.rangeChance();
this.cookieMatrix[selectIndex].texture = tempTexture2;
this.cookieMatrix[selectIndex-7].texture = tempTexture1;
TweenMax.from(this.cookieMatrix[selectIndex], 0.1, {y:this.cookieMatrixPos[selectIndex-7][1], onComplete:(function () {
for(var i=0; i=15) {this.stageMode = 'superfever';}
else if(this.combo>=5){
this.stageMode = 'fever';
this.callfevercnt = 0;
} else{this.stageMode = 'normal';}
this.lastTime = Date.now();
this.restComboTime = 3;
this.rangeChance();
this.cookieMatrix[selectIndex].texture = tempTexture2;
this.cookieMatrix[selectIndex + 7].texture = tempTexture1;
TweenMax.from(this.cookieMatrix[selectIndex], 0.1, {y: this.cookieMatrixPos[selectIndex + 7][1], onComplete:(function () {
for(var i=0; i= this.bombfull) {
makeBomb = true;
this.setBombItem();
this.bombAnerge -= this.bombfull;
}
var explodeMc = new gc.MovieClip('clear_effect_00', 1, 9, 0.4);
explodeMc.anchor.set(0.5);
explodeMc.position.x = this.cookieMatrixPos[i][0];
explodeMc.position.y = this.cookieMatrixPos[i][1];
explodeMc.alpha = 1;
explodeMc.loop = false;
if(!explodeEqual) {this.explodeContainer.addChild(explodeMc);
}else{this.explodeContainer2.addChild(explodeMc);}
}
}
this.scanIndex = undefined;
//mask 폭탄 게이지 보이는 화면
var gap = this.bombgauge.height/this.bombfull;
if(this.thing == undefined) {
this.thing = new PIXI.Graphics();
this.thing.position.x = 0;
this.thing.position.y = 0;
this.bombgauge.addChild(this.thing);
this.bombgauge.mask = this.thing;
this.thing.lineStyle(0);
this.thing.clear();
this.thing.beginFill(0xffffff, 1);
this.maskRect = this.thing.drawRect(-14, -this.bombgauge.height+gap*(this.bombfull-this.bombAnerge), this.bombgauge.width, this.bombgauge.height, 10);
this.thing.endFill();
}
//점수 부여
for(var i=0; i=5){
this.setEqualItem('origin');
} else if(this.fixArr1.length >=4){
this.setCrossItem('origin');
}
this.cookieMatrix[this.itemIndex1].alpha = 1;
this.cookieMatrix[this.itemIndex1].flag = 1;
this.itemIndex1 = undefined;
}
if(this.itemIndex2 != undefined){
if(this.fixArr2.length >=5){
this.setEqualItem('other');
} else if(this.fixArr2.length >=4){
this.setCrossItem('other');
}
this.cookieMatrix[this.itemIndex2].alpha = 1;
this.cookieMatrix[this.itemIndex2].flag = 1;
this.itemIndex2 = undefined;
}
};
gc.GameScene.prototype.setBombItem = function(){
this.randBombIndex = parseInt(Math.random()*14);
if(this.cookieMatrix[this.randBombIndex].flag != 0 && this.cookieNumMatrix[this.randBombIndex] <7) {
this.cookieMatrix[this.randBombIndex].texture = PIXI.Texture.fromFrame('bomb_item_0001.png');
this.cookieNumMatrix[this.randBombIndex] = 10;
this.matchItemSize(this.randBombIndex);
}else this.setBombItem();
};
gc.GameScene.prototype.setEqualItem = function(thing){
var itemName = 'cookie2_000';
var fullItemName;
switch (thing) {
case 'origin':
this.cookieMatrix[this.itemIndex1].remember = this.cookieNumMatrix[this.itemIndex1];
fullItemName = itemName+this.cookieMatrix[this.itemIndex1].remember+'.png';
this.cookieMatrix[this.itemIndex1].texture = PIXI.Texture.fromFrame(fullItemName);
this.cookieNumMatrix[this.itemIndex1] = 9;
this.matchItemSize(this.itemIndex1);
break;
case 'other':
this.cookieMatrix[this.itemIndex2].remember = this.cookieNumMatrix[this.itemIndex2];
fullItemName = itemName+this.cookieMatrix[this.itemIndex2].remember+'.png';
this.cookieMatrix[this.itemIndex2].texture = PIXI.Texture.fromFrame(fullItemName);
this.cookieNumMatrix[this.itemIndex2] = 9;
this.matchItemSize(this.itemIndex2);
break;
}
};
gc.GameScene.prototype.setCrossItem = function(thing){
switch (thing) {
case 'origin':
this.cookieMatrix[this.itemIndex1].texture = PIXI.Texture.fromFrame('eraser_0001.png');
this.cookieNumMatrix[this.itemIndex1] = 8;
this.matchItemSize(this.itemIndex1);
break;
case 'other':
this.cookieMatrix[this.itemIndex2].texture = PIXI.Texture.fromFrame('eraser_0001.png');
this.cookieNumMatrix[this.itemIndex2] = 8;
this.matchItemSize(this.itemIndex2);
break;
}
};
gc.GameScene.prototype.matchItemSize = function (index) {
var min = 2;
var max = 0;
for(var i=0; i max){max = this.cookieMatrix[i].scale.x}
}
}
if(min != 0.85) {
this.cookieMatrix[index].scale.x = min;
this.cookieMatrix[index].scale.y = min;
}else {
this.cookieMatrix[index].scale.x = max;
this.cookieMatrix[index].scale.y = max;
}
this.getItemIndex();
};
gc.GameScene.prototype.bump = function () {
if(this.itemIndexes.length > 0) {
if(this.cookieMatrix[this.itemIndexes[0]].scale.x >= 1 || this.cookieMatrix[this.itemIndexes[0]].scale.x <= 0.85){
if(this.cookieMatrix[this.itemIndexes[0]].scale.x > 1) this.cookieMatrix[this.itemIndexes[0]].scale.x = 1;
if(this.cookieMatrix[this.itemIndexes[0]].scale.x < 0.85) this.cookieMatrix[this.itemIndexes[0]].scale.x = 0.85;
this.bumpscale *= -1;
}
this.cookieMatrix[this.itemIndexes[0]].scale.x += this.bumpscale;
this.cookieMatrix[this.itemIndexes[0]].scale.y += this.bumpscale;
}
for(var i=0; i6){
this.itemIndexes.push(i);
}
}
};
gc.GameScene.prototype.actBomb = function(actIndex){
this.bombCombo++;
//본인
this.cookieMatrix[actIndex].flag = 0;
this.cookieMatrix[actIndex].remember = 0;
this.cookieMatrix[actIndex].alpha = 0;
//첫번째 열이 아님
if(actIndex%7 != 0) {
//왼쪽 위
if(actIndex-7-1 >= 0) {
//대상이 아이템 블럭이 아님
if(this.cookieNumMatrix[actIndex - 7 - 1] < 7) {
this.cookieMatrix[actIndex - 7 - 1].flag = 0;
this.cookieMatrix[actIndex - 7 - 1].alpha = 0;
this.cookieMatrix[actIndex - 7 - 1].remember = 0;
}
}
//왼쪽 아래
if(actIndex+7-1 <= 48) {
//대상이 아이템 블럭이 아님
if(this.cookieNumMatrix[actIndex + 7 - 1] < 7) {
this.cookieMatrix[actIndex + 7 - 1].flag = 0;
this.cookieMatrix[actIndex + 7 - 1].alpha = 0;
this.cookieMatrix[actIndex + 7 - 1].remember = 0;
}
}
//왼쪽
if(actIndex-1 >= 0) {
//대상이 아이템 블럭이 아님
if(this.cookieNumMatrix[actIndex - 1] < 7) {
this.cookieMatrix[actIndex - 1].flag = 0;
this.cookieMatrix[actIndex - 1].alpha = 0;
this.cookieMatrix[actIndex - 1].remember = 0;
}
}
}
//위
if(actIndex-7 >= 0){
if(this.cookieNumMatrix[actIndex - 7] < 7) {
this.cookieMatrix[actIndex - 7].flag = 0;
this.cookieMatrix[actIndex - 7].alpha = 0;
this.cookieMatrix[actIndex - 7].remember = 0;
}
}
//아래
if(actIndex+7 <= 48){
if(this.cookieNumMatrix[actIndex + 7] < 7) {
this.cookieMatrix[actIndex + 7].flag = 0;
this.cookieMatrix[actIndex + 7].alpha = 0;
this.cookieMatrix[actIndex + 7].remember = 0;
}
}
//오른쪽 끝 열이 아님
if(actIndex%7 != 6) {
//오른쪽 위
if (actIndex - 7 + 1 >= 0) {
//대상이 아이템 블럭이 아님
if (this.cookieNumMatrix[actIndex - 7 + 1] < 7) {
this.cookieMatrix[actIndex - 7 + 1].flag = 0;
this.cookieMatrix[actIndex - 7 + 1].alpha = 0;
this.cookieMatrix[actIndex - 7 + 1].remember = 0;
}
}
//오른쪽 아래
if (actIndex + 7 + 1 <= 48) {
//대상이 아이템 블럭이 아님
if (this.cookieNumMatrix[actIndex + 7 + 1] < 7) {
this.cookieMatrix[actIndex + 7 + 1].flag = 0;
this.cookieMatrix[actIndex + 7 + 1].alpha = 0;
this.cookieMatrix[actIndex + 7 + 1].remember = 0;
}
}
//오른쪽
if (actIndex + 1 <= 48) {
//대상이 아이템 블럭이 아님
if (this.cookieNumMatrix[actIndex + 1] < 7) {
this.cookieMatrix[actIndex + 1].flag = 0;
this.cookieMatrix[actIndex + 1].alpha = 0;
this.cookieMatrix[actIndex + 1].remember = 0;
}
}
}
//아이템 사용시 강조 이펙트 제거를 위함
this.stopItemAccentEffect();
this.playItemAccentEffect();
this.explode();
};
gc.GameScene.prototype.explodeEqual = function () {
var explodeMc = new gc.MovieClip('clear_effect_00', 1, 9, 0.4);
explodeMc.onComplete = function() {gc.game.explodeContainer2.removeChild(explodeMc);};
explodeMc.anchor.set(0.5);
explodeMc.position.x = this.cookieMatrixPos[this.remembers[0]][0];
explodeMc.position.y = this.cookieMatrixPos[this.remembers[0]][1];
explodeMc.alpha = 1;
explodeMc.scale.x = 1.3;
explodeMc.scale.y = 1.3;
explodeMc.loop = false;
this.explodeContainer2.addChild(explodeMc);
};
gc.GameScene.prototype.rise = function () {
var fakeCookie = new PIXI.Sprite.fromFrame('cookie_1_0001.png');
fakeCookie.texture = this.cookieMatrix[this.remembers[0]].texture;
fakeCookie.anchor.set(0.5);
fakeCookie.position.x = this.cookieMatrixPos[this.remembers[0]][0];
fakeCookie.position.y = this.cookieMatrixPos[this.remembers[0]][1];
this.explodeContainer2.addChild(fakeCookie);
this.manageSound();
this.cookieMatrix[this.remembers[0]].alpha = 0;
this.cookieMatrix[this.remembers[0]].flag = 0;
this.cookieMatrix[this.remembers[0]].remember = 0;
TweenMax.to(fakeCookie.scale, 0.1,{x:1.15, y:1.15, onComplete:(function () {
this.explodeEqual();
this.remembers.splice(0, 1);
if(this.remembers.length>0) setTimeout(this.rise.bind(this),100);
else{
this.explodeContainer2.removeChildren();
this.explode();
this.shadow.alpha = 0;
}
}).bind(this)});
};
gc.GameScene.prototype.actEqual = function(actIndex){
this.remembers = [];
this.tempRemembers = []; // 쿠키가 커진 후 크기 돌려놓기 위함
//본인
this.cookieMatrix[actIndex].flag = 0;
this.remembers.push(actIndex);
for (var i = 0; i < this.cookieNumMatrix.length; i++) {
if (this.cookieNumMatrix[i] == this.cookieMatrix[actIndex].remember) {
this.cookieMatrix[i].flag = 0;
this.remembers.push(i);
this.tempRemembers.push(i);
}
}
this.shadow.alpha = 1;
//아이템 사용시 강조 이펙트 제거를 위함
this.stopItemAccentEffect();
this.playItemAccentEffect();
//순서대로 커지게 만들기
this.rise();
};
gc.GameScene.prototype.actCross = function(actIndex){
this.champagneCombo++;
//본인
this.cookieMatrix[actIndex].flag = 0;
this.cookieMatrix[actIndex].remember = 0;
this.cookieMatrix[actIndex].alpha = 0;
var colIndex = actIndex%7; //몇번째 열인지 체크
for(var i=0; i<7; i++){
if(this.cookieMatrix[i * 7 + colIndex].flag != 0) {
if (this.cookieNumMatrix[i * 7 + colIndex] < 7) {
this.cookieMatrix[i * 7 + colIndex].flag = 0;
this.cookieMatrix[i * 7 + colIndex].alpha = 0;
this.cookieMatrix[i * 7 + colIndex].remember = 0;
}
}
}
var rowIndex = Math.floor(actIndex/7); //몇번째 열인지 체크
for(var i=0; i<7; i++){
if(this.cookieMatrix[rowIndex * 7 + i].flag != 0) {
if (this.cookieNumMatrix[rowIndex * 7 + i] < 7) {
this.cookieMatrix[rowIndex * 7 + i].flag = 0;
this.cookieMatrix[rowIndex * 7 + i].alpha = 0;
this.cookieMatrix[rowIndex * 7 + i].remember = 0;
}
}
}
//아이템 사용시 강조 이펙트 제거를 위함
this.stopItemAccentEffect();
this.playItemAccentEffect();
this.explode();
};
//쿠키 메우기==================================================================
gc.GameScene.prototype.dropCookie = function(){
var index;
var lineCount = 0; //한 열의 빈 블럭 수 카운트
var dropCount = 0; //한 열의 내려온 블럭 수 카운트(완전히 내려온 후 카운트)
var fullCount = 0; //떨어질 블럭 전체 수 카운트(빈 공간 + 새로 떨어질 블럭 수)
var dropIndexes = []; //떨어질 블럭 인덱스
for(var i=0; i<7; i++){
lineCount = 0;
//기존 블럭 내리기
for(var j=6; j>=0; j--){
index = j*7+i;
if(this.cookieMatrix[index].flag == 0){
lineCount++;
this.cookieMatrix[index].alpha = 1;
this.cookieMatrix[index].flag = 1;
}else{
if(lineCount > 0) {
fullCount++;
dropIndexes.push(index + lineCount * 7);
//내려올 블럭: (index + lineCount * 7), 복사해올 블럭: (index)
this.cookieMatrix[index + lineCount * 7].texture = this.cookieMatrix[index].texture;
this.cookieMatrix[index + lineCount * 7].remember = this.cookieMatrix[index].remember;
this.cookieMatrix[index].remember = 0;
this.cookieNumMatrix[index + lineCount * 7] = this.cookieNumMatrix[index];
this.cookieNumMatrix[index] = 0;
//아이템이 내려올 때 크기 복사
if(this.cookieNumMatrix[index + lineCount * 7] > 7) this.matchItemSize(index + lineCount * 7);
else{
this.cookieMatrix[index + lineCount * 7].scale.x = 0.85;
this.cookieMatrix[index + lineCount * 7].scale.y = 0.85;
}
TweenMax.from(this.cookieMatrix[index + lineCount * 7], 0.3, {
y: this.cookieMatrixPos[index][1], onComplete: (function () {
dropCount++;
if(dropCount == fullCount && !this.canClick) {
//이전 스테이지모드 저장
if(this.stageMode != 'momotime') this.prestageMode = this.stageMode;
this.checkAgain();
}
else {
this.lastEventTime = Date.now();
}
}.bind(this))
});
}
}
}
//새로운 쿠키 내리기
for(var j= lineCount-1; j>=0; j--){
index = j*7+i;
fullCount++;
this.cookieNumMatrix[index] = parseInt(Math.random()*6+1);
this.cookieMatrix[index].texture = PIXI.Texture.fromFrame('cookie_000'+ this.cookieNumMatrix[index] + '.png');
this.cookieMatrix[index].scale.x = 0.85;
this.cookieMatrix[index].scale.y = 0.85;
this.cookieMatrix[index].remember = 0;
this.cookieMatrix[index].alpha = 1;
this.cookieMatrix[index].flag = 1;
TweenMax.from(this.cookieMatrix[index], 0.3, {y:this.gameTable.position.y+this.cookieMatrix[index].height/2, onComplete: (function (){
dropCount++;
if(dropCount == fullCount && !this.canClick) {
//이전 스테이지모드 저장
if(this.stageMode != 'momotime') this.prestageMode = this.stageMode;
this.checkAgain();
}
else {
this.lastEventTime = Date.now();
}
}.bind(this))});
}
}
//내려올 블럭이 아이템일 경우 아이템 강조 이펙트도 같이 움직이기 위함
this.stopItemAccentEffect();
this.playItemAccentEffect();
this.getItemIndex();
//객체 의미 없음
TweenMax.from(this.cookieMatrix[0], 0.3, {onComplete: (function (){
this.restComboTime = 3; //=아이템 블럭이 많으면 다음 콤보까지 시간 부족.. 블럭 다 떨어지고 초기화
//힌트 저장을 위함
this.giveHint = false;
if(!this.checkMatching1() && this.playGame) {
this.checkAgain();
this.findHint();
}
////게임 종료
//if(this.chance<=0 && !this.haveEmpty) this.setGameOver();
}.bind(this))});
};
gc.GameScene.prototype.checkAgain = function(){
for(var i=0; i 7 && this.cookieMatrix[i].flag == 1){
this.itemEffectMc[i].alpha = 1;
this.itemEffectMc[i].play();
}
}
};
gc.GameScene.prototype.stopItemAccentEffect = function () {
for(var i=0; i= 3) {
return true;
}
}
}
//세로(열) 매칭 체크
for(var i=0; i<7; i++){
countCol = 0;
num2 = this.cookieNumMatrix[i];
for(var j=0; j<7; j++){
index2 = j*7+i;
if (num2<7 && this.cookieNumMatrix[index2] == num2) {
countCol++;
} else {
num2 = this.cookieNumMatrix[index2];
countCol = 1;
}
if (countCol >= 3) {
return true;
}
}
}
return false;
};
//스와핑 후 매칭 확인
gc.GameScene.prototype.checkMatching2 = function (checkingIndex){
this.l_c = 0;
this.r_c = 0;
this.u_c = 0;
this.d_c = 0;
this.itemIndex = undefined;
this.memories = [];
if(this.cookieNumMatrix[checkingIndex] < 7) {
//왼쪽 파트
for (var i = checkingIndex; i >= Math.floor(checkingIndex / 7) * 7; i--) {
if (this.cookieNumMatrix[i] == this.cookieNumMatrix[checkingIndex]) {
this.l_c++;
} else {
break;
}
}
//오른쪽 파트
for (var i = checkingIndex; i <= Math.floor(checkingIndex / 7 + 1) * 7 - 1; i++) {
if (this.cookieNumMatrix[i] == this.cookieNumMatrix[checkingIndex]) {
this.r_c++;
} else {
break;
}
}
//위쪽 파트
for (var i = checkingIndex; i >= 0; i -= 7) {
if (this.cookieNumMatrix[i] == this.cookieNumMatrix[checkingIndex]) {
this.u_c++;
} else {
break;
}
}
//아래쪽 파트
for (var i = checkingIndex; i < this.cookieMatrix.length; i += 7) {
if (this.cookieNumMatrix[i] == this.cookieNumMatrix[checkingIndex]) {
this.d_c++;
} else {
break;
}
}
}
//매칭 쿠키 확인
if(this.l_c+this.r_c -1 >= 3){ //맞춰진 가로 수가 3개 이상이면
//가로 4개 이상
if(this.l_c+this.r_c -1 >= 4) this.itemIndex = checkingIndex;
for(var i=checkingIndex-this.l_c+1; i <= checkingIndex + this.r_c-1; i++){
this.cookieMatrix[i].flag = 0;
this.memories.push(i);
}
if(this.u_c+this.d_c-1 >= 3){ //맞춰진 세로 수가 3개 이상이면
for(var i=checkingIndex-(this.u_c-1)*7; i <= checkingIndex+(this.d_c-1)*7; i+=7){
if(i != checkingIndex) {
this.cookieMatrix[i].flag = 0;
this.memories.push(i);
}
}
//십자 모양
this.itemIndex = checkingIndex;
}
return true;
}else if(this.l_c+this.r_c -1 < 3 && this.u_c+this.d_c-1 >= 3) { //가로 개수가 3개 미만이고, 세로 개수가 3개 이상
for(var i=checkingIndex-(this.u_c-1)*7; i <= checkingIndex+(this.d_c-1)*7; i+=7){
this.cookieMatrix[i].flag = 0;
this.memories.push(i);
}
//세로 4개 이상
if(this.memories.length>=4) this.itemIndex = checkingIndex;
return true;
}else{ //맞는게 없을 때
return false;
}
};
//모든 쿠키 내리고 나서 다시 매칭 확인
gc.GameScene.prototype.checkMatching3 = function(){
this.bundle = []; //매칭되는 모든 배열을 저장하기 위한 배열
for (var j = 0; j < this.cookieMatrix.length; j++) {
this.l_c = 0;
this.r_c = 0;
this.u_c = 0;
this.d_c = 0;
this.itemIndex = undefined;
this.memories = [];
if (this.cookieMatrix[j].flag != 0 && this.cookieNumMatrix[j]<7) {
//왼쪽 파트
for (var i = j; i >= Math.floor(j / 7) * 7; i--) {
if (this.cookieNumMatrix[i] == this.cookieNumMatrix[j]) {
this.l_c++;
} else {
break;
}
}
//오른쪽 파트
for (var i = j; i <= Math.floor(j / 7 + 1) * 7 - 1; i++) {
if (this.cookieNumMatrix[i] == this.cookieNumMatrix[j]) {
this.r_c++;
} else {
break;
}
}
//위쪽 파트
for (var i = j; i >= 0; i -= 7) {
if (this.cookieNumMatrix[i] == this.cookieNumMatrix[j]) {
this.u_c++;
} else {
break;
}
}
//아래쪽 파트
for (var i = j; i < this.cookieMatrix.length; i += 7) {
if (this.cookieNumMatrix[i] == this.cookieNumMatrix[j]) {
this.d_c++;
} else {
break;
}
}
//매칭 쿠키 확인
if (this.l_c + this.r_c - 1 >= 3) { //맞춰진 가로 수가 3개 이상이면
for (var i = j - this.l_c + 1; i <= j + this.r_c - 1; i++) {
this.memories.push(i);
}
if (this.u_c + this.d_c - 1 >= 3) { //맞춰진 세로 수가 3개 이상이면
for (var i = j - (this.u_c - 1) * 7; i <= j + (this.d_c - 1) * 7; i += 7) {
if (i != j) {
this.memories.push(i);
}
}
}
} else if (this.l_c + this.r_c - 1 < 3 && this.u_c + this.d_c - 1 >= 3) { //가로 개수가 3개 미만이고, 세로 개수가 3개 이상
for (var i = j - (this.u_c - 1) * 7; i <= j + (this.d_c - 1) * 7; i += 7) {
this.memories.push(i);
}
}
}
this.bundle[j] = this.memories;
}
var bundleCount = 0;
for (var i = 0; i < this.bundle.length; i++) {
if (this.bundle[i].length == 0) {
bundleCount++;
}
}
//맞춰진 블럭이 있을때
if (bundleCount != this.bundle.length) this.searchingMaxLength();
else {
this.haveEmpty = false;
for (var i = 0; i < this.cookieMatrix.length; i++) {
if (this.cookieMatrix[i].flag == 0) this.haveEmpty = true;
}
if (this.haveEmpty) this.explode();
else {
if (this.playGame) {
this.canClick = true;
}
else {
if (this.itemOver) {
this.PlayOver();//게임이 완전히 끝났을 때
} else {
this.lastPang();//횟수는 끝났으나 아이템이 남아있으면 터뜨리기}
}
}
//게임 종료
if (this.playGame && this.chance <= 0 && !this.haveEmpty) this.setGameOver();
}
}
};
gc.GameScene.prototype.PlayOver = function () {
this.gameoverImg.anchor.set(0.5);
this.gameoverImg.x = GD.width/2;
this.gameoverImg.y = GD.height/2;
this.addChild(this.gameoverImg);
TweenMax.to(this.gameoverImg.scale, 0.5, {x:1, y:1, onComplete:(function () {
TweenMax.to(this.gameoverImg.scale, 0.3, {x:1.2, y:1.2});
}).bind(this)});
TweenMax.from(this.gameoverImg, 0.5, {y:GD.height+this.gameoverImg.height});
this.giveHint = true;
this.canClick = false;
this.normalmomo.stop();
this.fevermomo.stop();
this.normalshushu.stop();
this.fevershushu.stop();
this.fevereffect1.stop();
this.fevereffect2.stop();
GD.soundPlay('sound_gameover');
setTimeout(this.onResult.bind(this),1000);
};
//타임업 사운드가 끝나고 결과창으로 이동
gc.GameScene.prototype.onResult = function () {
GD.bgmStop();
gc.game = null;
GD.commonOption.finish(this.score);
};
//맞춰진 배열에서 가장 긴 배열에 아이템을 넣기 위한 함수
gc.GameScene.prototype.searchingMaxLength = function(){
var maxLength = 0;
var maxLengthIndex = undefined;
for(var i=0; i maxLength) {
maxLength = this.bundle[i].length;
maxLengthIndex = i;
}
}
for (var i = 0; i < this.bundle[maxLengthIndex].length; i++) {
this.cookieMatrix[this.bundle[maxLengthIndex][i]].flag = 0;
this.cookieMatrix[this.bundle[maxLengthIndex][i]].alpha = 0;
this.cookieMatrix[this.bundle[maxLengthIndex][i]].remember = 0;
}
if(this.bundle[maxLengthIndex].length >= 4) {
if (this.bundle[maxLengthIndex].length >= 5) {
this.cookieMatrix[maxLengthIndex].remember = this.cookieNumMatrix[maxLengthIndex];
var itemName = 'cookie2_000';
var fullItemName = itemName+this.cookieMatrix[maxLengthIndex].remember+'.png';
this.cookieMatrix[maxLengthIndex].texture = PIXI.Texture.fromFrame(fullItemName);
this.cookieNumMatrix[maxLengthIndex] = 9;
}else if (this.bundle[maxLengthIndex].length >= 4) {
this.cookieMatrix[maxLengthIndex].texture = PIXI.Texture.fromFrame('eraser_0001.png');
this.cookieNumMatrix[maxLengthIndex] = 8;
}
this.cookieMatrix[maxLengthIndex].flag = 1;
this.cookieMatrix[maxLengthIndex].alpha = 1;
}
this.combo++;
this.totalCombo++;
if(this.stageMode != 'momotime') {
if(this.combo>=15) {this.stageMode = 'superfever';}
else if(this.combo>=5){
this.stageMode = 'fever';
this.callfevercnt = 0;
} else{this.stageMode = 'normal';}
}
this.lastTime = Date.now();
this.restComboTime = 3;
this.checkMatching3();
};
//피버모드=======================================================================================================
gc.GameScene.prototype.setFeverText = function () {
this.superfeverText.anchor.set(0.5);
this.superfeverText.position.x = gc.width / 2;
this.superfeverText.position.y = this.gameTable.position.y;
this.superfeverText.scale.x = 0;
this.superfeverText.scale.y = 0;
this.addChild(this.superfeverText);
this.feverText.anchor.set(0.5);
this.feverText.position.x = gc.width / 2;
this.feverText.position.y = this.gameTable.position.y;
this.feverText.scale.x = 0;
this.feverText.scale.y = 0;
this.addChild(this.feverText);
};
gc.GameScene.prototype.setFever = function () {
if(!this.pauseMode) {
var now = Date.now();
if (this.lastTime == undefined) this.lastTime = now;
if (this.playGame) {
if (this.restComboTime > 0) {this.restComboTime -= (now - this.lastTime) / 1000;}
else {
this.combo = 0;
this.restComboTime = 0;
this.lastTime = undefined;
if(this.stageMode != 'normal') this.prestageMode = this.stageMode;
this.stageMode = 'normal';
this.callfevercnt = 0;
}
if (this.prestageMode != this.stageMode && this.callfevercnt == 0) {this.actFever();}
this.lastTime = now;
}
}else this.lastTime = Date.now();
};
gc.GameScene.prototype.actFever = function () {
this.callfevercnt++;
if(this.stageMode == 'normal'){
this.normalMode();
this.gameBG.texture = GD.loader.resources['game_bg'].texture;
this.fevereffect1.alpha = 0;
this.fevereffect2.alpha = 0;
} else{
this.otherMode();
this.actfeverEffect();
}
};
gc.GameScene.prototype.actfeverEffect = function(){
if(this.test){
this.fevereffect1.y = -200;
this.fevereffect2.y = -200;
}else {
this.gameBG.texture = GD.loader.resources['game_bg_fever'].texture;
this.fevereffect1.y = 465;
this.fevereffect2.y = 345;
}
this.fevereffect1.alpha = 1;
this.fevereffect2.alpha = 1;
this.fevereffect2.scale.y = 1.5;
if(!this.test)if (this.stageMode != 'momotime') GD.soundPlay('sound_fever');
if (this.stageMode == 'superfever') {
this.superfeverText.alpha = 1;
TweenMax.to(this.superfeverText.scale, 0.5, {
x: 1, y: 1, alpha: 1, onComplete: (function () {
TweenMax.to(this.superfeverText, 0.7, {
onComplete: (function () {
this.superfeverText.scale.x = 0;
this.superfeverText.scale.y = 0;
this.superfeverText.alpha = 0;
}).bind(this)
});
}).bind(this)
});
} else if (this.stageMode == 'fever') {
this.feverText.alpha = 1;
TweenMax.to(this.feverText.scale, 0.5, {
x: 1, y: 1, alpha: 1, onComplete: (function () {
TweenMax.to(this.feverText, 0.7, {
onComplete: (function () {
this.feverText.scale.x = 0;
this.feverText.scale.y = 0;
this.feverText.alpha = 0;
if(this.test) {
this.test = false;
this.stageMode = 'normal';
}
}).bind(this)
});
}).bind(this)
});
}
};
// 일시정지
gc.GameScene.prototype.pause = function(){
this.pauseMode = true;
this.setInteractive(false);
};
// 게임진행
gc.GameScene.prototype.resume = function(){
this.pauseMode = false;
this.setInteractive(true);
};
// 버튼 이벤트 설정
gc.GameScene.prototype.setInteractive = function(bool){
for(var i=0; i= 100 && !this.getMedal4) {
DataManager.addMedal(4);
this.getMedal4 = true;
} else if(this.totalCombo >= 3 && !this.getMedal1) {
DataManager.addMedal(1);
this.getMedal1 = true;
}else if(this.champagneCombo >= 10 && !this.getMedal2) {
DataManager.addMedal(2);
this.getMedal2 = true;
}else if(this.bombCombo >= 10 && !this.getMedal3) {
DataManager.addMedal(3);
this.getMedal3 = true;
}
};
gc.GameScene.getInstance = function(){
if(!gc.game) gc.game = new gc.GameScene();
return gc.game;
};
module.exports.gc = gc;