123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393 |
- /****************************************************************************
- Copyright (c) 2010-2012 cocos2d-x.org
- Copyright (c) 2008-2010 Ricardo Quesada
- Copyright (c) 2011 Zynga Inc.
- http://www.cocos2d-x.org
- Permission is hereby granted, free of charge, to any person obtaining a copy
- of this software and associated documentation files (the "Software"), to deal
- in the Software without restriction, including without limitation the rights
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- copies of the Software, and to permit persons to whom the Software is
- furnished to do so, subject to the following conditions:
- The above copyright notice and this permission notice shall be included in
- all copies or substantial portions of the Software.
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
- THE SOFTWARE.
- ****************************************************************************/
- /**
- * create a webgl context
- * @param {HTMLCanvasElement} canvas
- * @param {Object} opt_attribs
- * @return {WebGLRenderingContext}
- */
- cc.create3DContext = function (canvas, opt_attribs) {
- var names = ["webgl", "experimental-webgl", "webkit-3d", "moz-webgl"];
- var context = null;
- for (var ii = 0; ii < names.length; ++ii) {
- try {
- context = canvas.getContext(names[ii], opt_attribs);
- } catch (e) {
- }
- if (context) {
- break;
- }
- }
- return context;
- };
- /**
- * Browser detection, based on mootools<br/>
- * platform will print out win32, mac, etc<br/>
- * type is the browser type, chrome, firefox etc
- * @type {Object}
- */
- cc.Browser = {};
- /**
- * Browsers that Cocos2d-HTML5 support well in WebGL render mode
- * @type {Array}
- */
- cc.Browser.webglWhiteList = ["baidubrowser", "opera", "firefox", "chrome", "safari"];
- /**
- * Browsers that multiple audio support well
- * @type {Array}
- */
- cc.Browser.multipleAudioWhiteList = ["baidubrowser", "opera", "firefox", "chrome", "safari", "ucbrowser", "qqbrowser", "mqqbrowser", "ie"];
- (function () {
- var ua = navigator.userAgent;
- cc.Browser.ua = ua.toLowerCase();
- cc.Browser.platform = navigator.platform.toLowerCase();
- cc.Browser.isMobile = (cc.Browser.ua.indexOf('mobile') != -1 || cc.Browser.ua.indexOf('android') != -1);
- cc.Browser.type = (function () {
- var browserTypes = cc.Browser.ua.match(/micromessenger|qqbrowser|mqqbrowser|ucbrowser|360browser|baiduboxapp|baidubrowser|maxthon|ie|opera|miuibrowser|firefox/)
- || cc.Browser.ua.match(/chrome|safari/);
- if (browserTypes && browserTypes.length > 0) {
- var el = browserTypes[0];
- if (el == 'micromessenger') {
- return 'wechat';
- }else if( el === "safari" && (cc.Browser.ua.match(/android.*applewebkit/) != null))
- return "androidbrowser";
- return el;
- }
- return "unknow";
- })();
- cc.Browser.mode = cc.Browser.type == 'ie' && document.documentMode;
- if (!document["ccConfig"])
- document["ccConfig"] = {};
- var c = document["ccConfig"];
- // check supportWebGL item
- cc._userRenderMode = parseInt(c["renderMode"]) || 0;
- var notInWhiteList = cc.Browser.webglWhiteList.indexOf(cc.Browser.type) == -1;
- if (cc._userRenderMode === 1 || (cc._userRenderMode === 0 && (cc.Browser.isMobile || notInWhiteList))) {
- //canvas only
- cc.Browser.supportWebGL = false;
- } else {
- // WebGL first
- cc.Browser.supportWebGL = !(window.WebGLRenderingContext == null);
- var tempCanvas = document.createElement("Canvas");
- var tempContext = cc.create3DContext(tempCanvas, {'stencil': true, 'preserveDrawingBuffer': true });
- cc.Browser.supportWebGL = !(tempContext == null)
- }
- if (cc._userRenderMode === 2 && !cc.Browser.supportWebGL) {
- // WebGL render only, but browser doesn't support WebGL.
- cc.__renderDoesnotSupport = true;
- }
- // check if browser supports Web Audio
- cc.Browser.supportWebAudio = (function () {
- // check Web Audio's context
- try {
- var ctx = new (window.AudioContext || window.webkitAudioContext || window.mozAudioContext)();
- return ctx ? true : false;
- } catch (e) {
- return false;
- }
- })();
- cc.Browser.openURL = function (url) {
- if (this.isMobile) {
- var size = cc.Director.getInstance().getWinSize();
- var w = size.width + "px";
- var h = size.height + "px";
- var div = cc.$new("div");
- div.style.backgroundColor = "#ffffff";
- div.style.width = w;
- div.style.height = h;
- div.style.zindex = 1000;
- div.style.position = 'absolute';
- div.style.top = 0 + 'px';
- div.style.left = 0 + 'px';
- div.id = "cocos2d-browser";
- var iframe = cc.$new("iframe");
- iframe.src = url;
- iframe.style.width = w;
- iframe.style.height = h;
- iframe.setAttribute("frameborder", "no");
- iframe.setAttribute("scrolling", "no");
- div.appendChild(iframe);
- iframe.onload = function () {
- var close = document.createElement('img');
- close.src = "";
- div.appendChild(close);
- close.style.zindex = 1000;
- close.style.position = 'absolute';
- close.style.bottom = 10 + 'px';
- close.style.right = 10 + 'px';
- close.onclick = function () {
- div.remove();
- }
- };
- var tag = document['ccConfig'].tag;
- var parent = document.getElementById(tag).parentNode;
- if (parent) {
- parent.appendChild(div);
- }
- }
- else {
- window.open(url);
- }
- }
- })();
- cc.RenderDoesnotSupport = function () {
- if (cc.__renderDoesnotSupport === "undefined")
- return false;
- return cc.__renderDoesnotSupport;
- };
- /**
- * the dollar sign, classic like jquery, this selector add extra methods to HTMLElement without touching its prototype</br>
- * it is also chainable like jquery
- * @param {HTMLElement|String} x pass in a css selector in string or the whole HTMLElement
- * @class
- * @return {cc.$}
- */
- cc.$ = function (x) {
- /** @lends cc.$# */
- var parent = (this == cc) ? document : this;
- /**
- * @type {HTMLElement}
- */
- var el = (x instanceof HTMLElement) ? x : parent.querySelector(x);
- if (el) {
- /**
- * find and return the child wth css selector (same as jquery.find)
- * @param {HTMLElement|String} x pass in a css selector in string or the whole HTMLElement
- * @return {cc.$}
- */
- el.find = el.find || cc.$;
- /**
- * check if a DOMNode has a specific class
- * @param {String} cls
- * @return {Boolean}
- */
- el.hasClass = el.hasClass || function (cls) {
- return this.className.match(new RegExp('(\\s|^)' + cls + '(\\s|$)'));
- };
- /**
- * add a class to a DOMNode, returns self to allow chaining
- * @param {String} cls
- * @return {cc.$}
- */
- el.addClass = el.addClass || function (cls) {
- if (!this.hasClass(cls)) {
- if (this.className) {
- this.className += " ";
- }
- this.className += cls;
- }
- return this;
- };
- /**
- * remove a specific class from a DOMNode, returns self to allow chaining
- * @param {String} cls
- * @return {cc.$}
- */
- el.removeClass = el.removeClass || function (cls) {
- if (this.hasClass(cls)) {
- this.className = this.className.replace(cls, '');
- }
- return this;
- };
- /**
- * detach it self from parent
- * @function
- */
- el.remove = el.remove || function () {
- if (this.parentNode)
- this.parentNode.removeChild(this);
- return this;
- };
- /**
- * add to another element as a child
- * @param {HTMLElement|cc.$} x
- * @return {cc.$}
- */
- el.appendTo = el.appendTo || function (x) {
- x.appendChild(this);
- return this;
- };
- /**
- * add to another element as a child and place on the top of the children list
- * @param {HTMLElement|cc.$} x
- * @return {cc.$}
- */
- el.prependTo = el.prependTo || function (x) {
- ( x.childNodes[0]) ? x.insertBefore(this, x.childNodes[0]) : x.appendChild(this);
- return this;
- };
- /**
- * helper function for updating the css transform
- * @return {cc.$}
- */
- el.transforms = el.transforms || function () {
- this.style[cc.$.trans] = cc.$.translate(this.position) + cc.$.rotate(this.rotation) + cc.$.scale(this.scale) + cc.$.skew(this.skew);
- return this;
- };
- el.position = el.position || {x: 0, y: 0};
- el.rotation = el.rotation || 0;
- el.scale = el.scale || {x: 1, y: 1};
- el.skew = el.skew || {x: 0, y: 0};
- /**
- * move the element
- * @param {Number} x in pixel
- * @param {Number} y in pixel
- * @return {cc.$}
- */
- el.translates = function (x, y) {
- this.position.x = x;
- this.position.y = y;
- this.transforms();
- return this
- };
- /**
- * rotate the element
- * @param {Number} x in degrees
- * @return {cc.$}
- */
- el.rotate = function (x) {
- this.rotation = x;
- this.transforms();
- return this
- };
- /**
- * resize the element
- * @param {Number} x
- * @param {Number} y
- * @return {cc.$}
- */
- el.resize = function (x, y) {
- this.scale.x = x;
- this.scale.y = y;
- this.transforms();
- return this
- };
- /**
- * skews the element
- * @param {Number} x in degrees
- * @param {Number} y
- * @return {cc.$}
- */
- el.setSkew = function (x, y) {
- this.skew.x = x;
- this.skew.y = y;
- this.transforms();
- return this
- };
- }
- return el;
- };
- //getting the prefix and css3 3d support
- switch (cc.Browser.type) {
- case "firefox":
- cc.$.pfx = "Moz";
- cc.$.hd = true;
- break;
- case "chrome":
- case "safari":
- cc.$.pfx = "webkit";
- cc.$.hd = true;
- break;
- case "opera":
- cc.$.pfx = "O";
- cc.$.hd = false;
- break;
- case "ie":
- cc.$.pfx = "ms";
- cc.$.hd = false;
- break;
- default:
- cc.$.pfx = "webkit";
- cc.$.hd = true;
- }
- //cache for prefixed transform
- cc.$.trans = cc.$.pfx + "Transform";
- //helper function for constructing transform strings
- cc.$.translate = (cc.$.hd) ? function (a) {
- return "translate3d(" + a.x + "px, " + a.y + "px, 0) "
- } : function (a) {
- return "translate(" + a.x + "px, " + a.y + "px) "
- };
- cc.$.rotate = (cc.$.hd) ? function (a) {
- return "rotateZ(" + a + "deg) ";
- } : function (a) {
- return "rotate(" + a + "deg) ";
- };
- cc.$.scale = function (a) {
- return "scale(" + a.x + ", " + a.y + ") "
- };
- cc.$.skew = function (a) {
- return "skewX(" + -a.x + "deg) skewY(" + a.y + "deg)";
- };
- /**
- * Creates a new element, and adds cc.$ methods
- * @param {String} x name of the element tag to create
- * @return {cc.$}
- */
- cc.$new = function (x) {
- return cc.$(document.createElement(x))
- };
- cc.$.findpos = function (obj) {
- var curleft = 0;
- var curtop = 0;
- do {
- curleft += obj.offsetLeft;
- curtop += obj.offsetTop;
- } while (obj = obj.offsetParent);
- return {x: curleft, y: curtop};
- };
|