svnno****@sourc*****
svnno****@sourc*****
2010年 11月 30日 (火) 22:11:43 JST
Revision: 2188 http://sourceforge.jp/projects/sie/svn/view?view=rev&revision=2188 Author: dhrname Date: 2010-11-30 22:11:43 +0900 (Tue, 30 Nov 2010) Log Message: ----------- Modified Paths: -------------- trunk/org/w3c/dom/css.js trunk/org/w3c/dom/events.js trunk/org/w3c/dom/svg.js Property Changed: ---------------- trunk/org/ trunk/org/w3c/ trunk/org/w3c/core.js trunk/org/w3c/dom/css.js trunk/org/w3c/dom/events.js trunk/org/w3c/dom/svg.js Property changes on: trunk/org ___________________________________________________________________ Modified: svn:mergeinfo - /branches/06x/061/org:1864-2067 /branches/06x/062/org:2071-2106 /branches/06x/org:1861-2155 + /branches/06x/061/org:1864-2067 /branches/06x/062/org:2071-2106 /branches/06x/063/org:2110-2146 /branches/06x/064/org:2149-2177 /branches/06x/org:1861-2187 Property changes on: trunk/org/w3c ___________________________________________________________________ Modified: svn:mergeinfo - /branches/06x/061/org/w3c:1864-2067 /branches/06x/062/org/w3c:2071-2106 /branches/06x/063/org/w3c:2110-2146 /branches/06x/org/w3c:1861-2155 /branches/ufltima:1621-1788 + /branches/06x/061/org/w3c:1864-2067 /branches/06x/062/org/w3c:2071-2106 /branches/06x/063/org/w3c:2110-2146 /branches/06x/064/org/w3c:2149-2177 /branches/06x/org/w3c:1861-2187 /branches/ufltima:1621-1788 Property changes on: trunk/org/w3c/core.js ___________________________________________________________________ Modified: svn:mergeinfo - /branches/06x/061/org/w3c/core.js:1864-2067 /branches/06x/062/org/w3c/core.js:2071-2106 /branches/06x/063/org/w3c/core.js:2110-2146 /branches/06x/org/w3c/core.js:1861-2155 /branches/ufltima/core.js:1621-1854 + /branches/06x/061/org/w3c/core.js:1864-2067 /branches/06x/062/org/w3c/core.js:2071-2106 /branches/06x/063/org/w3c/core.js:2110-2146 /branches/06x/064/org/w3c/core.js:2149-2177 /branches/06x/org/w3c/core.js:1861-2187 /branches/ufltima/core.js:1621-1854 Modified: trunk/org/w3c/dom/css.js =================================================================== --- trunk/org/w3c/dom/css.js 2010-11-30 13:09:58 UTC (rev 2187) +++ trunk/org/w3c/dom/css.js 2010-11-30 13:11:43 UTC (rev 2188) @@ -702,21 +702,43 @@ var style = this.defaultView.getComputedStyle(tar, "") s.setProperty = function(propertyName, value, priority) { var tar = elt, el = tar._tar, isFill = isStroke = false; + if ((tar.localName === "g") || (tar.localName === "a")) { + var sl = tar.getElementsByTagNameNS("http://www.w3.org/2000/svg", "*"); + if (sl) { + for (var i=0,sli=sl.length;i<sli;++i) { + var di = sl[i]; + NAIBU._setPaint(di, di.getScreenCTM()); + di = null; + } + sl = null; + } + el = null; + } + if (!el) { + setProp.call(s, propertyName, value, priority); + return; + } if (!!!tar._fillElement) { tar._fillElement = document.createElement("v:fill"); //キャッシュを作る } else { - /*あらかじめ消しおかないと、効果が出ない*/ - el.removeChild(tar._fillElement); + var tgebtfill = el.getElementsByTagName("fill"); + if (tgebtfill.length > 0) { + /*あらかじめ消しおかないと、効果が出ない*/ + el.removeChild(tgebtfill[0]); + } + tgebtfill = null; isFill = true; } if (!!!tar._strokeElement) { tar._strokeElement = document.createElement("v:stroke"); } else { - /*あらかじめ消しおかないと、効果が出ない*/ - el.removeChild(tar._strokeElement); + var tgebtstroke = el.getElementsByTagName("stroke") + if (tgebtstroke.length > 0) { + el.removeChild(tgebtstroke[0]); + } + tgebtstroke = null; isStroke = true; } - var fillElement = tar._fillElement, strokeElement = tar._strokeElement; setProp.call(s, propertyName, value, priority); if (propertyName === "fill-opacity") { Property changes on: trunk/org/w3c/dom/css.js ___________________________________________________________________ Modified: svn:mergeinfo - /branches/06x/061/org/w3c/dom/css.js:1864-2067 /branches/06x/062/org/w3c/dom/css.js:2071-2106 /branches/06x/063/org/w3c/dom/css.js:2110-2146 /branches/06x/org/w3c/dom/css.js:1861-2155 /branches/ufltima/dom/css.js:1621-1855 + /branches/06x/061/org/w3c/dom/css.js:1864-2067 /branches/06x/062/org/w3c/dom/css.js:2071-2106 /branches/06x/063/org/w3c/dom/css.js:2110-2146 /branches/06x/064/org/w3c/dom/css.js:2149-2177 /branches/06x/org/w3c/dom/css.js:1861-2187 /branches/ufltima/dom/css.js:1621-1855 Modified: trunk/org/w3c/dom/events.js =================================================================== --- trunk/org/w3c/dom/events.js 2010-11-30 13:09:58 UTC (rev 2187) +++ trunk/org/w3c/dom/events.js 2010-11-30 13:11:43 UTC (rev 2188) @@ -155,7 +155,7 @@ * */ for (var i=0, n=1, d=0, tce = null, sli = s.length, slii = sli*2-1;i<slii;++i){ - d = sli - i - 1; + var d = sli - i - 1; if (d === 0){ //イベントのターゲットに到着(折り返し地点) n = -1; evt.eventPhase = 2;//Event.AT_TARGET; Property changes on: trunk/org/w3c/dom/events.js ___________________________________________________________________ Modified: svn:mergeinfo - /branches/06x/061/org/w3c/dom/events.js:1864-2067 /branches/06x/062/org/w3c/dom/events.js:2071-2106 /branches/06x/063/org/w3c/dom/events.js:2110-2146 /branches/06x/org/w3c/dom/events.js:1861-2155 /branches/ufltima/dom/events.js:1621-1856 + /branches/06x/061/org/w3c/dom/events.js:1864-2067 /branches/06x/062/org/w3c/dom/events.js:2071-2106 /branches/06x/063/org/w3c/dom/events.js:2110-2146 /branches/06x/064/org/w3c/dom/events.js:2149-2177 /branches/06x/org/w3c/dom/events.js:1861-2187 /branches/ufltima/dom/events.js:1621-1856 Modified: trunk/org/w3c/dom/svg.js =================================================================== --- trunk/org/w3c/dom/svg.js 2010-11-30 13:09:58 UTC (rev 2187) +++ trunk/org/w3c/dom/svg.js 2010-11-30 13:11:43 UTC (rev 2188) @@ -1530,6 +1530,15 @@ NAIBU.doc.validateOnParse = false; NAIBU.doc.resolveExternals = false; NAIBU.doc.loadXML(str); + /*IE6-8のみで使えるupdateIntervalは、 + *描画間隔の調整が可能。デフォルトは0。 + *スクロール時にバグが起きるので、0に戻してやる必要がある。 + */ + screen.updateInterval = 999; + window.onscroll = function () { + screen.updateInterval = 0; + screen.updateInterval = 99; + } var objei = this._tar; if (/&[^;]+;/.test(str)) { /*以下の処理は、実体参照を使ったとき @@ -1551,6 +1560,9 @@ tar.viewport.left = 0; tar.viewport.width = objei.clientWidth; tar.viewport.height = objei.clientHeight; + if (tar.viewport.height < 24) { //IEの標準モードではclientHeightプロパティの値が小さくなることがある + tar.viewport.height = screen.width; + } var objw = objei.getAttribute("width"), objh = objei.getAttribute("height"); if (objw) { tar.setAttributeNS(null, "width", objw); @@ -2150,9 +2162,12 @@ /*以下では、スタイルシートを用いて、fill-とstroke-関連の *処理を行う。SVGPaintインターフェースをも用いる */ - var tod = tar.ownerDocument; + var tod = tar.ownerDocument, el = tar._tar; + if (!el) { + return; + } var style = tod.defaultView.getComputedStyle(tar, ""); - var el = tar._tar, fill = style.getPropertyCSSValue("fill"), stroke = style.getPropertyCSSValue("stroke"); + var fill = style.getPropertyCSSValue("fill"), stroke = style.getPropertyCSSValue("stroke"); if (fill.paintType === /*SVGPaint.SVG_PAINTTYPE_RGBCOLOR*/ 1 || fill.paintType === /*SVGPaint.SVG_PAINTTYPE_CURRENTCOLOR*/ 102) { if (fill.paintType === /*SVGPaint.SVG_PAINTTYPE_CURRENTCOLOR*/ 102) { /*再度、設定。css.jsのsetPropertyを参照*/ @@ -2160,8 +2175,12 @@ } if (!!tar._fillElement) { var fillElement = tar._fillElement; - /*あらかじめ消しおかないと、効果が出ない*/ - el.removeChild(fillElement); + var tgebtfill = el.getElementsByTagName("fill"); + if (tgebtfill.length > 0) { + /*あらかじめ消しおかないと、効果が出ない*/ + el.removeChild(tgebtfill[0]); + } + tgebtfill = null; } else { var fillElement = document.createElement("v:fill"); } @@ -2205,7 +2224,11 @@ } if (!!tar._strokeElement) { var strokeElement = tar._strokeElement; - el.removeChild(strokeElement); + var tgebtstroke = el.getElementsByTagName("stroke") + if (tgebtstroke.length > 0) { + el.removeChild(tgebtstroke[0]); + } + tgebtstroke = null; } else { var strokeElement = document.createElement("v:stroke"); } @@ -4634,10 +4657,10 @@ SVGAnimationElement.prototype._eventRegExp = /(mouse|activ|clic)[a-z]+/; SVGAnimationElement.prototype._timeRegExp = /[\-\d\.]+(h|min|s|ms)?/; SVGAnimationElement.prototype._unit = { - "h" : 2880000, + "h" : 2880000, "min" : 48000, - "s" : 800, - "ms" : 0.8 + "s" : 800, + "ms" : 0.8 }; /*どれだけズレの時間があるかを計測するメソッド *tに数値が使われていないときは0を返す @@ -4690,7 +4713,7 @@ *決して現在時刻ではない。要素のbeginイベントの発火したときが0sである。 */ /*float*/ SVGAnimationElement.prototype.getCurrentTime = function(){ - return (this._currentFrame * 125 / 0.8); + return (this._currentFrame * 125 * 0.8); }; /*float*/ SVGAnimationElement.prototype.getSimpleDuration = function(){ if (!!!this._simpleDuration && !!!this._end && this._simpleDuration !== 0) { @@ -4708,11 +4731,12 @@ Max : 7000, start : function() { if (NAIBU.Clip.length > 0) { + screen.updateInterval = 42; //24fpsとして描画処理 NAIBU.stop = setInterval( (function() { /* try{*/ var ntc = NAIBU.Time.currentFrame++; var nc = NAIBU.Clip; - var s = ntc * 125 / 0.8; //フレーム数ntcをミリ秒数sに変換 + var s = ntc * 125 * 0.8; //フレーム数ntcをミリ秒数sに変換 if (ntc > NAIBU.Time.Max) { clearInterval(NAIBU.stop); } @@ -4736,7 +4760,6 @@ } if (!!nci._frame) { nci._frame(); - nci._currentFrame++; } } nci = null; @@ -4745,7 +4768,7 @@ stlog.add(e, 4157); }*/ }), - 64 + 1 ); } } @@ -4762,6 +4785,15 @@ *機械が理解できる形で保管されているvalueの値の配列リスト */ this._valueList = []; + this._isDiscrete = false; + this.addEventListener("DOMAttrModified", function(evt){ + if (evt.eventPhase === Event.BUBBLING_PHASE) { + return; //強制終了させる + } + if ((evt.attrName === "calcMode") && (evt.newValue === "discrete")) { + evt.target._isDiscrete = true; + } + }, false); this.addEventListener("DOMNodeInserted", function(evt){ if (evt.eventPhase === Event.BUBBLING_PHASE) { return; //強制終了させる @@ -4778,7 +4810,7 @@ tar._values[0] = ttr.getAttributeNS(null, attrName) || ttr.style.getPropertyValue(attrName); } if (!!tta) { - ttr[attrName].animVal = vi[attrName].baseVal; + tta.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; @@ -4809,7 +4841,7 @@ vi = null; return; } - if ((tar._keyTimes[1] === 1) && (tar._valueList.length > 2)) { + if ((tar._keyTimes[1] === 1) && (tar._valueList.length > 2)) { //keyTimesが設定されていない場合、均等に時間を割り振る for (var i=0,n=0,tvli=tar._valueList.length-1;i<tvli;++i) { n += 1 / tvli; tar._keyTimes[i+1] = n; @@ -4839,13 +4871,16 @@ 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; + var v1 = tar._valueList[ii].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); + if (!tar._isDiscrete) { + var v2 = tar._valueList[ii+1].value, di = (tar._keyTimes[ii+1] - tar._keyTimes[ii]) * d, v = v1 + (v2-v1) * (tg-tar._keyTimes[ii]*d) / di; + } else { + var v = v1; + } tanim.newValueSpecifiedUnits(tanim.unitType, v); tta.baseVal = tanim; tanim = null; @@ -4855,25 +4890,29 @@ */ tta.animVal = tta.baseVal; tta.baseVal = base; + di = null; } 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); + var v1 = tar._valueList[ii].value, v2 = tar._valueList[ii+1].value, di = (tar._keyTimes[ii+1] - tar._keyTimes[ii]) * d; + if (!tar._isDiscrete) { + var v = v1 + (v2-v1) * (tg-tar._keyTimes[ii]*d) / di; + } else { + var v = v1; + } } else if ("animatedPoints" in ttr) { var base = ttr.points; ttr.points = ttr.animatedPoints; ttr.dispatchEvent(evt); - tta.animatedPoints = tta.points; - tta.points = base; + ttr.animatedPoints = ttr.points; + ttr.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; + ttr.animatedNormalizedPathSegList = ttr.normalizedPathSegList; + ttr.normalizedPathSegList = base; } - evt = v1 = v2 = v = null; + evt = v1 = v2 = v = d = n = ii = tg = null; }; evt = vir = null; }, false); @@ -5038,6 +5077,26 @@ function SVGAnimateColorElement() { SVGAnimationElement.apply(this); NAIBU.Clip[NAIBU.Clip.length] = this; + 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; + var fstyle = tar.ownerDocument.defaultView.getComputedStyle(ttr, ""); + if (!tar._values[0]) { + tar._values[0] = fstyle.getPropertyValue(attrName); + } + for (var i=0, tav=tar._values, tvli=tav.length;i<tvli;++i) { + var to = new SVGColor(); + to.setRGBColor(tar._values[i]); + tar._valueList[tar._valueList.length] = to; + to = null; + } + }, false); + }, false); this.addEventListener("beginEvent", function(evt) { var tar = evt.target, attrName = tar.getAttributeNS(null, "attributeName"); var style = tar.ownerDocument.getOverrideStyle(tar.targetElement, ""); @@ -5046,30 +5105,20 @@ style.setProperty(attrName, tar._values[0], null); } tar._frame = function() { - var _tar = tar, to = new SVGColor(), from = new SVGColor(); - var d = _tar.getSimpleDuration(); - if (d === 0) { - d = null; + var _tar = tar; + 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; } - 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) { - var ti = d / n, ki =ti; - if (n === 1) { - ti = 0; - } - } else { - var ti = parseFloat(_tar._keyTimes[i]) * d; - var ki = parseFloat(_tar._keyTimes[i+1])*d - ti; - } - var tc = to.rgbColor, fc = from.rgbColor, num = CSSPrimitiveValue.CSS_NUMBER, di = (t - ti) / ki; - var r = fc.red.getFloatValue(num) + (tc.red.getFloatValue(num) - fc.red.getFloatValue(num)) * di; - var g = fc.green.getFloatValue(num) + (tc.green.getFloatValue(num) - fc.green.getFloatValue(num)) * di; - var b = fc.blue.getFloatValue(num) + (tc.blue.getFloatValue(num) - fc.blue.getFloatValue(num)) * di; + var fc = _tar._valueList[ii].rgbColor, tc = _tar._valueList[ii+1].rgbColor, di = (_tar._keyTimes[ii+1] - _tar._keyTimes[ii]) * d, durd = (tg-tar._keyTimes[ii]*d) / di, num = CSSPrimitiveValue.CSS_NUMBER; + var fr = fc.red.getFloatValue(num), fg = fc.green.getFloatValue(num), fb = fc.blue.getFloatValue(num); + var r = fr + (tc.red.getFloatValue(num) - fr) * durd; + var g = fg + (tc.green.getFloatValue(num) - fg) * durd; + var b = fb + (tc.blue.getFloatValue(num) - fb) * durd; style.setProperty(attrName, "rgb(" +Math.ceil(r)+ "," +Math.ceil(g)+ "," +Math.ceil(b)+ ")", null); - _tar = t = to = from = fc = tc = num = r = g = b = null; + _tar = d = n = tg = fc = tc = fr = fg = fb = num = r = g = b = null; } }, false); this.addEventListener("endEvent", function(evt) { @@ -5341,6 +5390,8 @@ if ("stop" in NAIBU) { clearInterval(NAIBU.stop); } + window.dettachEvent("onload", NAIBU._main); + window.onscroll = NAIBU.emptyFunction; Element = SVGElement = Attr = NamedNodeMap = CSS2Properties = CSSValue = CSSPrimitiveValue = NAIBU.xmlhttp = Node = Event = NAIBU = stlog = STLog = document = null; Array = ActiveXObject = null; } catch(e) {} @@ -5440,6 +5491,7 @@ s = null; } } + xmlhttp = null; }); NAIBU.addEvent("load", NAIBU._main); NAIBU.utf16 = function ( /*string*/ s) { Property changes on: trunk/org/w3c/dom/svg.js ___________________________________________________________________ Modified: svn:mergeinfo - /branches/06x/061/org/w3c/dom/svg.js:1864-2067 /branches/06x/062/org/w3c/dom/svg.js:2071-2106 /branches/06x/063/org/w3c/dom/svg.js:2110-2146 /branches/06x/org/w3c/dom/svg.js:1861-2155 /branches/ufltima/dom/svg.js:1621-1856 + /branches/06x/061/org/w3c/dom/svg.js:1864-2067 /branches/06x/062/org/w3c/dom/svg.js:2071-2106 /branches/06x/063/org/w3c/dom/svg.js:2110-2146 /branches/06x/064/org/w3c/dom/svg.js:2149-2177 /branches/06x/065/org/w3c/dom/svg.js:2179-2181 /branches/06x/org/w3c/dom/svg.js:1861-2187 /branches/ufltima/dom/svg.js:1621-1856