svnno****@sourc*****
svnno****@sourc*****
2010年 11月 16日 (火) 22:11:40 JST
Revision: 2150 http://sourceforge.jp/projects/sie/svn/view?view=rev&revision=2150 Author: dhrname Date: 2010-11-16 22:11:40 +0900 (Tue, 16 Nov 2010) Log Message: ----------- 0.63のモジュール同士を結合させた Modified Paths: -------------- branches/06x/sie.js Modified: branches/06x/sie.js =================================================================== --- branches/06x/sie.js 2010-11-16 13:09:43 UTC (rev 2149) +++ branches/06x/sie.js 2010-11-16 13:11:40 UTC (rev 2150) @@ -326,25 +326,11 @@ *ノードのコピーを作る。引数は、子ノードのコピーも作るかどうか。コピー機能。 */ /*Node*/ cloneNode : function( /*boolean*/ deep) { - var s; - switch (this.nodeType) { - case Node.ELEMENT_NODE: - s = new Element(); - s.tagName = this.tagName; - s.attributes._copyNode(this.attributes,false); //NamedNodeMapのコピーを行う - break; - case Node.DOCUMENT_NODE: - s = new Document(); - break; - default: + if ("ownerDocument" in this) { + var s = this.ownerDocument.importNode(this, deep); + } else { s = new Node(); - break; } - s.parentNode = null; - s.nodeType = this.nodeType; s.nodeValue = this.nodeValue; s.nodeName = this.nodeName; s.namespaceURI = this.namespaceURI; s.localName = this.localName; s.prefix = this.prefix; - if (deep) { - s.childNodes._copyNode(this.childNodes,true); - } return s; }, /*normalizeメソッド @@ -2672,8 +2658,8 @@ /*interface SVGLocatable*/ /*SVGRect*/ SVGElement.prototype.getBBox = function(){ var s = new SVGRect(); - var data = this._tar.path.value, vi = this.ownerDocument.documentElement; - var el = vi.width.baseVal.value, et = vi.height.baseVal.value, er = 0, eb = 0; + var data = this._tar.path.value, vi = this.ownerDocument.documentElement.viewport; + var el = vi.width, et = vi.height, er = 0, eb = 0; /*要素の境界領域を求める(四隅の座標を求める) *etは境界領域の上からビューポート(例えばsvg要素)の上端までの距離であり、ebは境界領域の下からビューポートの下端までの距離 *elは境界領域の左からビューポートの左端までの距離であり、erは境界領域の右からビューポートの右端までの距離 @@ -2688,8 +2674,8 @@ nx = ny = null; } data = degis = null; - s.x = et; - s.y = el; + s.x = el; + s.y = et; s.width = er - el; s.height = eb - et; el = et = er = eb = vi = null; @@ -3342,6 +3328,8 @@ ev.initEvent("SVGLoad", false, false); tar.dispatchEvent(ev); ev = null; + /*IEのメモリリーク対策として、空関数を入力*/ + xmlhttp.onreadystatechange = NAIBU.emptyFunction; } } } @@ -3928,9 +3916,10 @@ } str = attr = null; var sdt = tar._tar, sp = document.createElement("div"), dcp = document.createElement("v:group"); - dcp.style.width = tar.width.baseVal.value+ "px"; - dcp.style.height = tar.height.baseVal.value+ "px"; - dcp.coordsize = tar.width.baseVal.value+ " " +tar.height.baseVal.value; + var view = tar.viewport; + dcp.style.width = view.width+ "px"; + dcp.style.height = view.height+ "px"; + dcp.coordsize = view.width+ " " +view.height; sp.appendChild(dcp); objei.parentNode.insertBefore(sp, objei); dcp.appendChild(sdt) @@ -4003,6 +3992,8 @@ } s.defaultView._cache = s.defaultView._cache_ele = null; s = evt = null; + /*IEのメモリリーク対策として、空関数を入力*/ + this.xmlhttp.onreadystatechange = NAIBU.emptyFunction; if (this._next) { this._next._init(); } else { @@ -4016,6 +4007,8 @@ return (this._document); } }; +/*空関数(IEのメモリリーク対策)*/ +NAIBU.emptyFunction = function() {}; /*SVGStyleElement *style要素をあらわすオブジェクト @@ -4042,8 +4035,8 @@ }; SVGPoint.prototype.matrixTransform = function(/*SVGMatrix*/ matrix ) { /*整数にしているのは、VMLの設計上、小数点を扱えないときがあるため*/ - var x = parseInt(matrix.a * this.x + matrix.c * this.y + matrix.e, 10); - var y = parseInt(matrix.b * this.x + matrix.d * this.y + matrix.f, 10); + var x = parseInt(matrix.a * this.x + matrix.c * this.y + matrix.e); + var y = parseInt(matrix.b * this.x + matrix.d * this.y + matrix.f); if ((-1 < x) && (x < 1)) {x=1;} if ((-1 < y) && (y < 1)) {y=1;} var s = new SVGPoint(); @@ -4649,6 +4642,10 @@ *SVG1.1 「8.3.9 The grammar for path data」の項目にある最後の文章を参照 */ var tnl = tar.normalizedPathSegList, tlist = tar.pathSegList, D = [], _parseFloat = parseFloat; + if (tnl.numberOfItems > 0) { + tnl.clear(); + tlist.clear(); + } /*d属性の値を正規表現を用いて、二次元配列Dに変換している。もし、d属性の値が"M 20 30 L20 40"ならば、 *JSONにおける表現は以下のとおり *D = [["M", 20, 30], ["L", 20 40]] @@ -4735,7 +4732,7 @@ *変換をする処理。相対座標を絶対座標に変換して、M、L、Cコマンドに正規化していく */ var cx = 0, cy = 0; //現在セグメントの終了点の絶対座標を示す (相対座標を絶対座標に変換するときに使用) - var xn = 0, yn = 0; //T,tコマンドで仮想的な座標を算出するのに用いる + var xn = 0, yn = 0; //T,tコマンドで仮想的な座標を算出するのに用いる。第一コントロール点 var startx = 0, starty = 0; //M,mコマンドにおける始点座標(Z,zコマンドで用いる) for (var j=0, tli=tlist.numberOfItems;j<tli;++j) { var ti = tlist.getItem(j), ts = ti.pathSegType, dii = ti.pathSegTypeAsLetter; @@ -4865,11 +4862,14 @@ if (tg.pathSegTypeAsLetter === "C") { var x1 = 2*tg.x - tg.x2; var y1 = 2*tg.y - tg.y2; - } else { - var x1 = ti.x2, y1 = ti.y2; + } else { //前のコマンドがCでなければ、現在の座標を第1コントロール点に用いる + var x1 = rx, y1 = ry; } - tnl.appendItem(tar.createSVGPathSegCurvetoCubicAbs(cx, cy, x1, y1, ti.x2, ti.y2)); + } else { + var x1 = rx, y1 = ry; } + tnl.appendItem(tar.createSVGPathSegCurvetoCubicAbs(cx, cy, x1, y1, ti.x2, ti.y2)); + x1 = y1 = null; } else if (dii === "s") { if (j !== 0) { var tg = tnl.getItem(tnl.numberOfItems-1); @@ -4877,23 +4877,33 @@ var x1 = 2*tg.x - tg.x2; var y1 = 2*tg.y - tg.y2; } else { - var x1 = ti.x2, y1 = ti.y2; + var x1 = rx, y1 = ry; } - tnl.appendItem(tar.createSVGPathSegCurvetoCubicAbs(cx, cy, x1, y1, ti.x2+rx, ti.y2+ry)); + } else { + var x1 = rx, y1 = ry; } + tnl.appendItem(tar.createSVGPathSegCurvetoCubicAbs(cx, cy, x1, y1, ti.x2+rx, ti.y2+ry)); + x1 = y1 = null; } else if (dii === "T" || dii === "t") { if (j !== 0) { var tg = tlist.getItem(j-1); if ("QqTt".indexOf(tg.pathSegTypeAsLetter) > -1) { - tnl.appendItem(tar.createSVGPathSegCurvetoCubicAbs(cx, cy, (rx + 2*xn) / 3, (ry + 2*yn) / 3, (2*xn + cx) / 3, (2*yn + cy) / 3)); - xn = 2*cx - xn; - yn = 2*cy - yn; + } else { + xn = rx, yn = ry; } + } else { + xn = rx, yn = ry; } + tnl.appendItem(tar.createSVGPathSegCurvetoCubicAbs(cx, cy, (rx + 2*xn) / 3, (ry + 2*yn) / 3, (2*xn + cx) / 3, (2*yn + cy) / 3)); + xn = 2*cx - xn; + yn = 2*cy - yn; + xx1 = yy1 = null; } else if (dii === "H" || dii === "h") { tnl.appendItem(tar.createSVGPathSegLinetoAbs(cx, ry)); + cy = ry; //勝手にti.yが0としているため } else if (dii === "V" || dii === "v") { tnl.appendItem(tar.createSVGPathSegLinetoAbs(rx, cy)); + cx = rx; } } ti = dii = ts = null; @@ -5213,7 +5223,7 @@ }; /*SVGPathSegLinetoVerticalAbs*/ SVGPathElement.prototype.createSVGPathSegLinetoVerticalAbs = function(/*float*/ y ) { var s = new SVGPathSegLinetoVerticalAbs(); - s.x = 0; //DOMでは指定されていないが、変換処理が楽なので用いる + s.x = 0; s.y = y; return s; }; @@ -5752,6 +5762,7 @@ /*Textノードにdiv要素を格納したリストをプロパティとして蓄えておく*/ tar._tars = []; var data = tar.data.replace(/^\s+/, "").replace(/\s+$/, ""); + tar.data = data; for (var i=0, tdli=data.length;i<tdli;++i) { var d = document.createElement("div"), dstyle = d.style; dstyle.position = "absolute"; @@ -6429,7 +6440,7 @@ SVGLinearGradientElement.prototype = new SVGGradientElement(); function SVGRadialGradientElement() { - SVGGradientElement.apply(this, arguments); + SVGGradientElement.apply(this); /*readonly SVGAnimatedLength*/ this.cx = new SVGAnimatedLength(); /*readonly SVGAnimatedLength*/ this.cy = new SVGAnimatedLength(); /*readonly SVGAnimatedLength*/ this.r = new SVGAnimatedLength(); @@ -6452,8 +6463,8 @@ var r = grad.r.baseVal.value, rx, ry; rx = ry = r; var tarrect = tar.getBBox(); - var vi = tar.ownerDocument.documentElement; - var el = vi.width.baseVal.value, et = vi.height.baseVal.value, er = 0, eb = 0; + var vi = tar.ownerDocument.documentElement.viewport; + var el = vi.width, et = vi.height, er = 0, eb = 0; var units = grad.getAttributeNS(null, "gradientUnits"); if (!units || units === "objectBoundingBox") { //%の場合は小数点に変換(10% -> 0.1) @@ -6467,7 +6478,7 @@ if (gt) { grad.setAttributeNS(null, "transform", gt); } - matrix = tar.getScreenCTM().multiply(grad.getCTM()); + var matrix = tar.getScreenCTM().multiply(grad.getCTM()); el = cx - rx; et = cy - ry; er = cx + rx; eb = cy + ry; var rrx = rx * 0.55228, rry = ry * 0.55228; var list = ["m", cx,et, "c", cx-rrx,et, el,cy-rry, el,cy, el,cy+rry, cx-rrx,eb, cx,eb, cx+rrx,eb, er,cy+rry, er,cy, er,cy-rry, cx+rrx,et, cx,et, "x e"]; @@ -6491,7 +6502,7 @@ var background = document.createElement("div"), bstyle = background.style; bstyle.position = "absolute"; bstyle.display = "inline-block"; - var w = vi.width.baseVal.value, h = vi.height.baseVal.value; + var w = vi.width, h = vi.height; bstyle.textAlign = "left"; bstyle.top = "0px"; bstyle.left = "0px"; bstyle.width = w+ "px"; bstyle.height = h+ "px"; outline.appendChild(background); bstyle.filter = "progid:DXImageTransform.Microsoft.Compositor"; @@ -6504,7 +6515,7 @@ background.filters[0].play(); tar._tar.parentNode.insertBefore(background, tar._tar); tar._tar.filled = "false"; - ellipse = circle = data = list = gt = cx = cy = r = w = h = null; + ellipse = outline = background = bstyle = circle = data = list = gt = cx = cy = r = w = h = matrix = null; } else if (!ele.parentNode){ tar._tar.appendChild(ele); } @@ -6645,14 +6656,23 @@ this._tar = document.createElement("a"); /*readonly SVGAnimatedString*/ this.target = new SVGAnimatedString(); this.addEventListener("DOMAttrModified", function(evt){ + var tar = evt.target; + if (evt.eventPhase === Event.BUBBLING_PHASE) { + return; //強制終了させる + } if (evt.attrName === "target") { - evt.target.target.baseVal = evt.newValue; + tar.target.baseVal = evt.newValue; + } else if (evt.attrName === "xlink:title") { + tar._tar.setAttribute("title", evt.newValue); } evt = null; }, false); this.addEventListener("DOMNodeInserted", function(evt){ var tar = evt.target; if (evt.eventPhase === Event.BUBBLING_PHASE) { + if ((tar.parentNode === evt.currentTarget) && (tar.nodeType === Node.TEXT_NODE)) { //直接Textノードが指定されれば + evt.currentTarget._tar.appendChild(document.createTextNode(tar.data)); + } return; //強制終了させる } if (tar.nextSibling) { @@ -6819,7 +6839,7 @@ this._begin = null; this._end = null; this._from = this._to = this._values = this._by = null; - this._keyTimes = null; + this._keyTimes = [0, 1]; this.addEventListener("beginEvent", function(evt) { var tar = evt.target; if (!tar.isRepeat) { @@ -6860,7 +6880,11 @@ } else if (name === "by") { tar._by = evt.newValue; } else if (name === "keyTimes") { - tar._keyTimes = evt.newValue.split(";"); + var s = evt.newValue.split(";"); + for (var i=0;i<s.length;++i) { + tar._keyTimes[i] = parseFloat(s[i]); + } + s = null; } evt = null; }, false); @@ -6884,7 +6908,7 @@ tar._values = [null, tar._to]; } else if (tar._by) { tar._values = ["0", tar._by]; - } else { + } else if (!tar.hasChildNodes() && !tar.hasAttributeNS(null, "path")) { //SVGAnimateMotionElementに留意 /*アニメーションの効果が出ないように調整する *SMILアニメーションの仕様を参照 * @@ -7010,6 +7034,10 @@ throw new DOMException(DOMException.INVALID_STATE_ERR); } }; +/*getCurrentTimeメソッド + *現在の時間コンテナ内での時刻であり、 + *決して現在時刻ではない。要素のbeginイベントの発火したときが0sである。 + */ /*float*/ SVGAnimationElement.prototype.getCurrentTime = function(){ return (this._currentFrame * 125 / 0.8); }; @@ -7057,6 +7085,7 @@ } if (!!nci._frame) { nci._frame(); + nci._currentFrame++; } } nci = null; @@ -7065,7 +7094,7 @@ stlog.add(e, 4157); }*/ }), - 125 + 64 ); } } @@ -7078,11 +7107,133 @@ *くわしくはNAIBU.Time.start関数のコードを参照 */ NAIBU.Clip[NAIBU.Clip.length] = this; + /*_valueListプロパティは、 + *機械が理解できる形で保管されているvalueの値の配列リスト + */ + this._valueList = []; + this.addEventListener("DOMNodeInserted", function(evt){ + if (evt.eventPhase === Event.BUBBLING_PHASE) { + return; //強制終了させる + } + var tar = evt.target; + tar.addEventListener("DOMNodeInsertedIntoDocument", function(evt){ + var tar = evt.target, attrName = tar.getAttributeNS(null, "attributeName"),ttr = tar.targetElement, tta = ttr[attrName]; + /*tar.valuesのリスト: ex. ["12px", "13px"]を、次のように機械に理解できるよう変換して、tar._valueListに格納 + *[(new SVGPoint()), (new SVGPoint())] + *この_valueListプロパティはアニメの際に使うので、_valuesプロパティはアニメ中に使わない + */ + var vi = ttr.cloneNode(false); + if (!tar._values[0]) { + tar._values[0] = ttr.getAttributeNS(null, attrName) || ttr.style.getPropertyValue(attrName); + } + if (!!tta) { + ttr[attrName].animVal = vi[attrName].baseVal; + for (var i=0, tav=tar._values, tvli=tav.length;i<tvli;++i) { + var vir = ttr.cloneNode(false); //仮の要素 + delete vir._tar; + vir.setAttributeNS(null, attrName, tav[i]); + tar._valueList[tar._valueList.length] = vir[attrName].baseVal; + } + } else if (!!CSS2Properties[attrName] || attrName.indexOf("-") > -1) { //スタイルシートのプロパティならば + for (var i=0, tav=tar._values, tvli=tav.length;i<tvli;++i) { + tar._valueList[i] = parseFloat(tav[i]); + } + } else if ("animatedPoints" in ttr) { + ttr.animatedPoints = vi.points; + for (var i=0, tav=tar._values, tvli=tav.length;i<tvli;++i) { + var vir = ttr.cloneNode(false); + delete vir._tar; + vir.setAttributeNS(null, "points", tav[i]); + tar._valueList[tar._valueList.length] = vir.points; + } + } else if ("normalizedPathSegList" in ttr) { + ttr.animatedNormalizedPathSegList = vi.normalizedPathSegList; + for (var i=0, tav=tar._values, tvli=tav.length;i<tvli;++i) { + var vir = ttr.cloneNode(false); + delete vir._tar; + vir.setAttributeNS(null, "d", tav[i]); + tar._valueList[tar._valueList.length] = vir.normalizedPathSegList; + } + } else { + vi = null; + return; + } + if ((tar._keyTimes[1] === 1) && (tar._valueList.length > 2)) { + for (var i=0,n=0,tvli=tar._valueList.length-1;i<tvli;++i) { + n += 1 / tvli; + tar._keyTimes[i+1] = n; + } + } + evt = tta = vir = vi = null; + }, false); + }, false); this.addEventListener("beginEvent", function(evt) { var tar = evt.target; + var attrName = tar.getAttributeNS(null, "attributeName"), newAttr = tar.targetElement.attributes.getNamedItemNS(null, attrName); + var ttr = tar.targetElement, tta = ttr[attrName]; + tar._frame = function() { + var d = tar.getSimpleDuration() * 0.8, n = tar._valueList.length - 1, tg = tar.getCurrentTime(); + if ((n !== -1) && (d !== 0) && (tg <= d)) { + var ii = Math.floor((tg*n) / d); + } else { + return; + } + /*setAttrbute(NS)メソッドはDOM属性を書き換えるため利用しない。 + * + * 参照:アニメーションサンドイッチモデル + * >アニメーションが起動している時,それは実際,DOMの中の属性値は変化しない。 + *http://www.jsa.or.jp/stdz/instac/syoukai/H13/H13annual_report/12/ngc-wg3/offline/smil_20_20020131/animation.html#animationNS-AnimationSandwichModel + */ + var evt = tar.ownerDocument.createEvent("MutationEvents"); + evt.initMutationEvent("DOMNodeInsertedIntoDocument", false, false, null, null, null, null, null); + if (!!tta) { + var base = tta.baseVal, tanim = tta.animVal; + var v1 = tar._valueList[ii].value, v2 = tar._valueList[ii+1].value; + /*vを求める公式に関しては、SMIL2.0 Animation Moduleの単純アニメーション関数の項を参照 + * 3.4.2 Specifying the simple animation function f(t) + *http://www.w3.org/TR/2005/REC-SMIL2-20050107/animation.html#animationNS-SpecifyingAnimationFunction + */ + var v = v1 + (v2-v1) * (tg-tar._keyTimes[ii]*d) / d; + console.log(tg); + tanim.newValueSpecifiedUnits(tanim.unitType, v); + tta.baseVal = tanim; + tanim = null; + ttr.dispatchEvent(evt); + /*変化値はanimValプロパティに収納しておき、 + *変化する前の、元の値はbaseValプロパティに再び収納しておく + */ + tta.animVal = tta.baseVal; + tta.baseVal = base; + } else if (!!CSS2Properties[attrName] || attrName.indexOf("-") > -1) { //スタイルシートのプロパティならば + var base = null; + var v1 = tar._valueList[ii], v2 = tar._valueList[ii+1]; + var v = v1 + (v2-v1) * (tg-tar._keyTimes[ii]*d) / d; + ttr.dispatchEvent(evt); + } else if ("animatedPoints" in ttr) { + var base = ttr.points; + ttr.points = ttr.animatedPoints; + ttr.dispatchEvent(evt); + tta.animatedPoints = tta.points; + tta.points = base; + } else if ("normalizedPathSegList" in ttr) { + var base = ttr.normalizedPathSegList; + ttr.normalizedPathSegList = ttr.animatedNormalizedPathSegList; + ttr.dispatchEvent(evt); + tta.animatedNormalizedPathSegList = tta.normalizedPathSegList; + tta.normalizedPathSegList = base; + } + evt = v1 = v2 = v = null; + }; + evt = vir = null; }, false); this.addEventListener("endEvent", function(evt) { - var tar = evt.target; + var tar = evt.target, fill = tar.getAttributeNS(null, "fill"); + if (!fill || (fill === "remove")) { + var evt = tar.ownerDocument.createEvent("MutationEvents"); + evt.initMutationEvent("DOMNodeInsertedIntoDocument", false, false, null, null, null, null, null); + tar.targetElement.dispatchEvent(evt); + evt = null; + } }, false); this.addEventListener("repeatEvent", function(evt) { var tar = evt.target; @@ -7186,17 +7337,22 @@ tar._frame = function() { var _tar = tar, tpn = _tar._path; if (!!tpn) { - var st = (tpn.getTotalLength() / _tar.getSimpleDuration()) * _tar.getCurrentTime() / 125 * 0.8; + var tgsd = _tar.getSimpleDuration(); + if (tgsd === 0) { + tgsd = null; + return; + } + var st = (tpn.getTotalLength() / tgsd) * _tar.getCurrentTime() / 125 * 0.8; var p = tpn.getPointAtLength(st), trans = _tar.targetElement.transform; p = p.matrixTransform(_tar.targetElement.getScreenCTM()) - trans.animVal.getItem(trans.numberOfItmes-1).setTranslate(p.x, p.y); + trans.animVal.getItem(trans.animVal.numberOfItems-1).setTranslate(p.x, p.y); var base = trans.baseVal; trans.baseVal = trans.animVal; var evtt = _tar.ownerDocument.createEvent("MutationEvents"); evtt.initMutationEvent("DOMNodeInsertedIntoDocument", false, false, null, null, null, null, null); _tar.targetElement.dispatchEvent(evtt); trans.baseVal = base; - evtt = base = trans = null; + evtt = base = trans = st = tgsd = p = null; } } evt = trans = null; @@ -7240,7 +7396,12 @@ } tar._frame = function() { var _tar = tar, to = new SVGColor(), from = new SVGColor(); - var n = _tar._values.length - 1, t = _tar.getCurrentTime(), d = _tar.getSimpleDuration(), i = Math.floor((t*n) / d); + var d = _tar.getSimpleDuration(); + if (d === 0) { + d = null; + return; + } + var n = _tar._values.length - 1, t = _tar.getCurrentTime(), i = Math.floor((t*n) / d); to.setRGBColor(_tar._values[i+1]); from.setRGBColor(_tar._values[i]); if (!!!_tar._keyTimes) {