+/*\r
+ * bind : 出版
+ */\r
+pettanr.bind = ( function(){\r
+ var BIND_WORKER_ARRAY = [],\r
+ NAMESPACE_CLASSNAME = pettanr.CONST.NS_PETTANR_COMIC + '-',\r
+ RESOURCE_PICTURE_PATH = pettanr.CONST.RESOURCE_PICTURE_PATH,\r
+ ELM_DETECT_WIDTH = ( function(){\r
+ var ret = document.createElement( 'div');\r
+ ret.style.cssText = 'width: auto;height: 0;padding: 0;margin: 0;display: block;visibility: hidden;float: none;position: static;';\r
+ return ret;\r
+ })();\r
+\r
+ /*\r
+ * original\r
+ * http://d.hatena.ne.jp/uupaa/20090720/1248097177\r
+ */\r
+ var ResizeAgentClass = function( onResizeFunction, opt_elmCheck){\r
+ var _globalLock = 0,\r
+ _size = { w: 0, h: 0 };\r
+ _ie = !!document.all,\r
+ _quirks = (document.compatMode || "") !== "CSS1Compat",\r
+ _ieroot = _quirks ? "body" : "documentElement";\r
+ _root = opt_elmCheck ? opt_elmCheck : ( _ie ? document[_ieroot] : window);\r
+\r
+ function getInnerSize() {\r
+ return {\r
+ w: _root.innerWidth || _root.clientWidth,\r
+ h: _root.innerHeight || _root.clientHeight\r
+ };\r
+ }\r
+\r
+ function loop() {\r
+ if (!_globalLock++) {\r
+ var size = getInnerSize();\r
+ if (_size.w !== size.w || _size.h !== size.h) { // resized\r
+ _size = size; // update\r
+ onResizeFunction( _size);\r
+ }\r
+ setTimeout( unlock, 0); // delay unlock\r
+ }\r
+ setTimeout(loop, 500);\r
+ }\r
+ function unlock(){\r
+ _globalLock = 0;\r
+ }\r
+ loop();\r
+ }\r
+ \r
+ \r
+ var ElementBuilder = ( function(){\r
+ var ELM_TITLE_ORIGN = ( function(){\r
+ \r
+ })(),\r
+ ELM_TEXT_ORIGN = ( function(){\r
+ var _table = document.createElement( 'table'),\r
+ _tr = document.createElement( 'tr');\r
+ _table.appendChild( _tr);\r
+ _tr.appendChild( document.createElement( 'td'));\r
+ _table.cellspacing = '0';\r
+ return _table;\r
+ })();\r
+ \r
+ function buildComicElement(){\r
+ \r
+ }\r
+ \r
+ function buildPanelElement( elmTarget, json, noClassnameMode){\r
+ var _elmPanel = document.createElement( 'div'),\r
+ _style = {\r
+ "border-width": typeof json.border === 'number' ? json.border + 'px' : 0,\r
+ width: json.width + 'px',\r
+ height: json.height + 'px'\r
+ },\r
+ _cssText = [],\r
+ _comicElements = json.panel_elements || [],\r
+ _comicElement, _elmImgWrap, _rImg, _rPic, _balloon, _elmBalloonWrap, _elmText;\r
+ if( noClassnameMode === true){\r
+ \r
+ } else {\r
+ _elmPanel.className = NAMESPACE_CLASSNAME + 'panel';\r
+ }\r
+ for( var _key in _style){\r
+ _cssText.push( _key + ':' + _style[ _key]);\r
+ }\r
+ _elmPanel.style.cssText = _cssText.join( ';');\r
+ elmTarget.appendChild( _elmPanel);\r
+ \r
+ for( var i=0, l=_comicElements.length; i<l; ++i){\r
+ _comicElement = _comicElements[ i];\r
+ if( _comicElement.resource_picture){\r
+ _rPic = _comicElement.resource_picture || {};\r
+ _rImg = pettanr.image.createReversibleImage(\r
+ [ RESOURCE_PICTURE_PATH, _rPic.id, '.', _rPic.ext].join( ''),\r
+ _comicElement.width, _comicElement.height\r
+ );\r
+ _elmImgWrap = document.createElement( 'div');\r
+ _elmPanel.appendChild( _elmImgWrap);\r
+ _elmImgWrap.appendChild( _rImg.elm);\r
+ _elmImgWrap.className = NAMESPACE_CLASSNAME + 'image';\r
+ _elmImgWrap.style.cssText = [\r
+ 'width:', Math.abs( _comicElement.width), 'px;',\r
+ 'height:', Math.abs( _comicElement.height), 'px;',\r
+ 'left:', _comicElement.x, 'px;',\r
+ 'top:', _comicElement.y, 'px;',\r
+ 'z-index:', _comicElement.z, ';'\r
+ ].join( '');\r
+ } else {\r
+ _elmBalloonWrap = document.createElement( 'div');\r
+ _elmPanel.appendChild( _elmBalloonWrap);\r
+ _elmBalloonWrap.className = NAMESPACE_CLASSNAME + 'balloon';\r
+ _elmBalloonWrap.style.cssText = [\r
+ 'width:', _comicElement.width, 'px;',\r
+ 'height:', _comicElement.height, 'px;',\r
+ 'left:', _comicElement.x, 'px;',\r
+ 'top:', _comicElement.y, 'px;',\r
+ 'z-index:', _comicElement.z, ';'\r
+ ].join( '');\r
+\r
+ _balloon = pettanr.balloon.createBalloon( _comicElement.width, _comicElement.height, _comicElement.tail);\r
+ _elmBalloonWrap.appendChild( _balloon.elm);\r
+ \r
+ _elmText = ELM_TEXT_ORIGN.cloneNode( true);\r
+ _elmBalloonWrap.appendChild( _elmText);\r
+ _elmText.className = NAMESPACE_CLASSNAME + 'speach';\r
+ _elmText.getElementsByTagName( 'td')[ 0].appendChild( document.createTextNode( 'hello'));\r
+ }\r
+ }\r
+ }\r
+ \r
+ return {\r
+ build: function( elmTarget, json, zoom, noClassnameMode){\r
+ // clean elmTarget\r
+ pettanr.util.removeAllChildren( elmTarget);\r
+ \r
+ // json is Comic ? Panel ?\r
+ if( json.panels){\r
+ // comic\r
+ \r
+ } else\r
+ if( json.panel_elements){\r
+ // panel\r
+ buildPanelElement( elmTarget, json, noClassnameMode);\r
+ } else {\r
+ // invalid json\r
+ }\r
+ }\r
+ }\r
+ })();\r
+ \r
+ var BindWorkerClass = function( elmTarget, json, zoomSelfEnabled, noClassnameMode){\r
+ typeof json === 'object' && build( elmTarget, json);\r
+ \r
+ var elmDetectW = ELM_DETECT_WIDTH.cloneNode( false)\r
+ \r
+ if( zoomSelfEnabled === true){\r
+ elmTarget.parentNode.insertBefore( elmDetectW, elmTarget);\r
+ new ResizeAgentClass( onResize, elmDetectW);\r
+ }\r
+ function onResize(){\r
+ \r
+ }\r
+ json && ElementBuilder.build( elmTarget, json, zoomSelfEnabled, noClassnameMode);\r
+ \r
+ return {\r
+ init: function(){\r
+ \r
+ },\r
+ zoom: function(){\r
+ \r
+ },\r
+ json: function( _json){\r
+ json = _json;\r
+ ElementBuilder.build( elmTarget, _json, zoomSelfEnabled, noClassnameMode);\r
+ },\r
+ targetElement: function(){\r
+ \r
+ },\r
+ layput: function(){\r
+ \r
+ },\r
+ destroy: function(){\r
+ \r
+ }\r
+ }\r
+ }\r
+ \r
+ return {\r
+ createBindWorker: function( elmTarget, opt_COMICJSONorPANELJSON, opt_zoomSelfEnabled, opt_noClassnameMode){\r
+ var ret = new BindWorkerClass( elmTarget, opt_COMICJSONorPANELJSON, !!opt_zoomSelfEnabled, !!opt_noClassnameMode);\r
+ BIND_WORKER_ARRAY.push( ret);\r
+ return ret;\r
+ },\r
+ isBindWorkerInstance: function( _bindWorker){\r
+ \r
+ }\r
+ }\r
+})();\r
+\r
+var VisualEffect = ( function(){\r
+ \r
+ var ANIMATION_TICKET_ARRAY = [],\r
+ fpms = 50,\r
+ TIMER = null,\r
+ FILTER = 'filter',\r
+ OPACITY = 'opacity',\r
+ CORON = ':',\r
+ EMPTY = '',\r
+ SEMICORON = ';';\r
+ \r
+ function startAnimation( _elm, _cssObject, _onComplete, _onEnterFrame, _numFrames){\r
+ var _ticket;\r
+ for( var i=0, l=ANIMATION_TICKET_ARRAY.length; i<l; ++i){\r
+ _ticket = ANIMATION_TICKET_ARRAY[ i];\r
+ if( _ticket.elm === _elm) {\r
+ _ticket.destroy();\r
+ break;\r
+ }\r
+ }\r
+ // coputedStyle と _cssObject を比較して , 一致及び非数は削除しつつ コピー\r
+ //\r
+ var _currentParameters = [],\r
+ _offsetParameters = [],\r
+ _endParameters = [],\r
+ _targetAttributes = [];\r
+ \r
+ ANIMATION_TICKET_ARRAY.push( new AnimationTaskClass(\r
+ _elm,\r
+ _currentParameters, _offsetParameters, _endParameters, _targetAttributes,\r
+ typeof _onComplete === 'function' ? _onComplete : null,\r
+ typeof _onEnterFrame === 'function' ? _onEnterFrame : null,\r
+ _numFrames\r
+ ));\r
+ \r
+ if( TIMER === null){\r
+ TIMER = window.setInterval( onEnterFrame, fpms);\r
+ }\r
+ }\r
+ function onEnterFrame(){\r
+ var _ticket,\r
+ i = 0;\r
+ while( i<ANIMATION_TICKET_ARRAY.length){\r
+ _ticket = ANIMATION_TICKET_ARRAY[ i];\r
+ if( _ticket.onEnterFrame() === true){\r
+ _ticket.destroy();\r
+ ANIMATION_TICKET_ARRAY.splice( i, 1);\r
+ } else {\r
+ ++i;\r
+ }\r
+ }\r
+ if( ANIMATION_TICKET_ARRAY.length === 0){\r
+ window.clearInterval( TIMER);\r
+ TIMER = null;\r
+ }\r
+ }\r
+ function updateCss( _elm, _updateParameters, _targetAttributes, _numAttributes){\r
+ if( _numAttributes > 1){\r
+ var _cssTexts = _elm.style.cssText.split( ';'), _css,\r
+ _separate,\r
+ _cssObject = {}, _target, _value, _number, _type, _new,\r
+ j;\r
+ for(var i=0, l=_cssTexts.length; i<l; ++i){\r
+ _css = _cssTexts[ i];\r
+ _separate = _css.indexOf( ':');\r
+ if( _separate >= 3){\r
+ _target = _css.substr( 0, _separate +1);\r
+ _value = _css.substr( _separate +1);\r
+ /*\r
+ * ie filter
+ */\r
+ if( _target === FILTER){\r
+ for( j=0; j<_numAttributes; ++j){\r
+ if( _targetAttributes[ j] === OPACITY){\r
+ \r
+ \r
+ \r
+ break;\r
+ }\r
+ }\r
+ /*\r
+ * other
+ */\r
+ } else {\r
+ _number = '' + parseFloat( _value);\r
+ _type = _value.indexOf( _number);\r
+ _type = _type > 0 ? _value.substr( _type + _number.length) : '';\r
+ for( j=0; j<_numAttributes; ++j){\r
+ if( _targetAttributes[ j] === _target){\r
+ _cssTexts[ i] = [ _target, ':', _updateParameters[ j], _type].join( '');\r
+ break;\r
+ }\r
+ } \r
+ }\r
+ }\r
+ }\r
+ _elm.style.cssText = _cssTexts.join( ';');\r
+ return; \r
+ }\r
+ /*\r
+ * 一度に update する Attributes が少ない場合、cssText は使用しない.
+ */\r
+ \r
+ }\r
+ \r
+ var AnimationTaskClass = function( ELM, currentParameters, offsetParameters, endParameters, targetAttributes, onComplete, onEnterFrame, numFrames){\r
+ var l = targetAttributes.length;\r
+ return {\r
+ elm: ELM,\r
+ onEnterFrame: function(){\r
+ var _updateCss = {};\r
+ if( numFrames === 1){\r
+ for( var i=0; i<l; ++i){\r
+ _updateCss[ targetAttributes[ i]] = endParameters[ i];\r
+ ++i;\r
+ }\r
+ updateCss( ELM, currentParameters, targetAttributes, l);\r
+ onComplete !== null && onComplete();\r
+ } else {\r
+ for( var i=0; i<l; ++i){\r
+ _updateCss[ targetAttributes[ i]] = currentParameters[ i] = Math.floor( currentParameters[ i] + offsetParameters[ i]);\r
+ ++i;\r
+ }\r
+ updateCss( ELM, currentParameters, targetAttributes, l);\r
+ onEnterFrame !== null && onEnterFrame( _updateCss);\r
+ }\r
+ --numFrames;\r
+ return numFrames === 0;\r
+ },\r
+ destroy: function(){\r
+ ELM = onComplete = onEnterFrame = null;\r
+ }\r
+ }\r
+ }\r
+ \r
+ var VisualEffectClass = function( ELM){\r
+ var isHtmlElement;\r
+ \r
+ function resisterAnime( _cssObject, _onComplete, _onEnterFrame, _time){\r
+ var _numFrames = Math.floor( _time / fpms);\r
+ startAnimation( ELM, _cssObject, _onComplete, _onEnterFrame, _numFrames);\r
+ }\r
+ function startFadeIn(){\r
+ \r
+ }\r
+ function startFadeOut(){\r
+ \r
+ }\r
+ function update( _x, _y, _w, _h){\r
+ var _cssText = ELM.style.cssText;\r
+ \r
+ }\r
+ \r
+ this.anime = resisterAnime;\r
+ this.fadeIn = startFadeIn;\r
+ this.fadeOut = startFadeOut;\r
+ this.update = update;\r
+ }\r
+ \r
+ return {\r
+ createVisualEffect: function( _elm){\r
+ return new VisualEffectClass( _elm);\r
+ },\r
+ isInstanceOfVisualEffect: function( _instance){\r
+ return _instance instanceof VisualEffectClass;\r
+ }\r
+ }\r
+})();\r