| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2008 Apple Inc. All rights reserved. | 2 * Copyright (C) 2008 Apple Inc. All rights reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
| 6 * are met: | 6 * are met: |
| 7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
| 8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
| 9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
| 10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
| (...skipping 13 matching lines...) Expand all Loading... |
| 24 */ | 24 */ |
| 25 | 25 |
| 26 #include "config.h" | 26 #include "config.h" |
| 27 #include "core/svg/animation/SVGSMILElement.h" | 27 #include "core/svg/animation/SVGSMILElement.h" |
| 28 | 28 |
| 29 #include "SVGNames.h" | 29 #include "SVGNames.h" |
| 30 #include "XLinkNames.h" | 30 #include "XLinkNames.h" |
| 31 #include "bindings/v8/ExceptionStatePlaceholder.h" | 31 #include "bindings/v8/ExceptionStatePlaceholder.h" |
| 32 #include "core/dom/Document.h" | 32 #include "core/dom/Document.h" |
| 33 #include "core/dom/EventListener.h" | 33 #include "core/dom/EventListener.h" |
| 34 #include "core/dom/EventSender.h" |
| 34 #include "core/platform/FloatConversion.h" | 35 #include "core/platform/FloatConversion.h" |
| 35 #include "core/svg/SVGDocumentExtensions.h" | 36 #include "core/svg/SVGDocumentExtensions.h" |
| 36 #include "core/svg/SVGSVGElement.h" | 37 #include "core/svg/SVGSVGElement.h" |
| 37 #include "core/svg/SVGURIReference.h" | 38 #include "core/svg/SVGURIReference.h" |
| 38 #include "core/svg/animation/SMILTimeContainer.h" | 39 #include "core/svg/animation/SMILTimeContainer.h" |
| 39 #include "wtf/MathExtras.h" | 40 #include "wtf/MathExtras.h" |
| 40 #include "wtf/StdLibExtras.h" | 41 #include "wtf/StdLibExtras.h" |
| 41 #include "wtf/Vector.h" | 42 #include "wtf/Vector.h" |
| 42 | 43 |
| 43 using namespace std; | 44 using namespace std; |
| 44 | 45 |
| 45 namespace WebCore { | 46 namespace WebCore { |
| 46 | 47 |
| 48 static SMILEventSender& smilEndEventSender() |
| 49 { |
| 50 DEFINE_STATIC_LOCAL(SMILEventSender, sender, ("endEvent")); |
| 51 return sender; |
| 52 } |
| 53 |
| 47 // This is used for duration type time values that can't be negative. | 54 // This is used for duration type time values that can't be negative. |
| 48 static const double invalidCachedTime = -1.; | 55 static const double invalidCachedTime = -1.; |
| 49 | 56 |
| 50 class ConditionEventListener : public EventListener { | 57 class ConditionEventListener : public EventListener { |
| 51 public: | 58 public: |
| 52 static PassRefPtr<ConditionEventListener> create(SVGSMILElement* animation,
SVGSMILElement::Condition* condition) | 59 static PassRefPtr<ConditionEventListener> create(SVGSMILElement* animation,
SVGSMILElement::Condition* condition) |
| 53 { | 60 { |
| 54 return adoptRef(new ConditionEventListener(animation, condition)); | 61 return adoptRef(new ConditionEventListener(animation, condition)); |
| 55 } | 62 } |
| 56 | 63 |
| (...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 126 , m_cachedRepeatCount(invalidCachedTime) | 133 , m_cachedRepeatCount(invalidCachedTime) |
| 127 , m_cachedMin(invalidCachedTime) | 134 , m_cachedMin(invalidCachedTime) |
| 128 , m_cachedMax(invalidCachedTime) | 135 , m_cachedMax(invalidCachedTime) |
| 129 { | 136 { |
| 130 resolveFirstInterval(); | 137 resolveFirstInterval(); |
| 131 } | 138 } |
| 132 | 139 |
| 133 SVGSMILElement::~SVGSMILElement() | 140 SVGSMILElement::~SVGSMILElement() |
| 134 { | 141 { |
| 135 clearResourceReferences(); | 142 clearResourceReferences(); |
| 143 smilEndEventSender().cancelEvent(this); |
| 136 disconnectConditions(); | 144 disconnectConditions(); |
| 137 if (m_timeContainer && m_targetElement && hasValidAttributeName()) | 145 if (m_timeContainer && m_targetElement && hasValidAttributeName()) |
| 138 m_timeContainer->unschedule(this, m_targetElement, m_attributeName); | 146 m_timeContainer->unschedule(this, m_targetElement, m_attributeName); |
| 139 } | 147 } |
| 140 | 148 |
| 141 void SVGSMILElement::clearResourceReferences() | 149 void SVGSMILElement::clearResourceReferences() |
| 142 { | 150 { |
| 143 ASSERT(document()); | 151 ASSERT(document()); |
| 144 document()->accessSVGExtensions()->removeAllTargetReferencesForElement(this)
; | 152 document()->accessSVGExtensions()->removeAllTargetReferencesForElement(this)
; |
| 145 } | 153 } |
| (...skipping 898 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1044 // Animation does not contribute during the active time if it is past its re
peating duration and has fill=remove. | 1052 // Animation does not contribute during the active time if it is past its re
peating duration and has fill=remove. |
| 1045 return (m_activeState == Active && (fill() == FillFreeze || elapsed <= m_int
ervalBegin + repeatingDuration())) || m_activeState == Frozen; | 1053 return (m_activeState == Active && (fill() == FillFreeze || elapsed <= m_int
ervalBegin + repeatingDuration())) || m_activeState == Frozen; |
| 1046 } | 1054 } |
| 1047 | 1055 |
| 1048 bool SVGSMILElement::progress(SMILTime elapsed, SVGSMILElement* resultElement, b
ool seekToTime) | 1056 bool SVGSMILElement::progress(SMILTime elapsed, SVGSMILElement* resultElement, b
ool seekToTime) |
| 1049 { | 1057 { |
| 1050 ASSERT(resultElement); | 1058 ASSERT(resultElement); |
| 1051 ASSERT(m_timeContainer); | 1059 ASSERT(m_timeContainer); |
| 1052 ASSERT(m_isWaitingForFirstInterval || m_intervalBegin.isFinite()); | 1060 ASSERT(m_isWaitingForFirstInterval || m_intervalBegin.isFinite()); |
| 1053 | 1061 |
| 1054 if (!m_conditionsConnected) | |
| 1055 connectConditions(); | |
| 1056 | |
| 1057 if (!m_intervalBegin.isFinite()) { | 1062 if (!m_intervalBegin.isFinite()) { |
| 1058 ASSERT(m_activeState == Inactive); | 1063 ASSERT(m_activeState == Inactive); |
| 1059 m_nextProgressTime = SMILTime::unresolved(); | 1064 m_nextProgressTime = SMILTime::unresolved(); |
| 1060 return false; | 1065 return false; |
| 1061 } | 1066 } |
| 1062 | 1067 |
| 1063 if (elapsed < m_intervalBegin) { | 1068 if (elapsed < m_intervalBegin) { |
| 1064 ASSERT(m_activeState != Active); | 1069 ASSERT(m_activeState != Active); |
| 1065 if (m_activeState == Frozen) { | 1070 if (m_activeState == Frozen) { |
| 1066 if (this == resultElement) | 1071 if (this == resultElement) |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1103 if (animationIsContributing) { | 1108 if (animationIsContributing) { |
| 1104 if (oldActiveState == Inactive) | 1109 if (oldActiveState == Inactive) |
| 1105 startedActiveInterval(); | 1110 startedActiveInterval(); |
| 1106 | 1111 |
| 1107 updateAnimation(percent, repeat, resultElement); | 1112 updateAnimation(percent, repeat, resultElement); |
| 1108 m_lastPercent = percent; | 1113 m_lastPercent = percent; |
| 1109 m_lastRepeat = repeat; | 1114 m_lastRepeat = repeat; |
| 1110 } | 1115 } |
| 1111 | 1116 |
| 1112 if (oldActiveState == Active && m_activeState != Active) { | 1117 if (oldActiveState == Active && m_activeState != Active) { |
| 1118 smilEndEventSender().dispatchEventSoon(this); |
| 1113 endedActiveInterval(); | 1119 endedActiveInterval(); |
| 1114 if (m_activeState != Frozen && this == resultElement) | 1120 if (m_activeState != Frozen && this == resultElement) |
| 1115 clearAnimatedType(m_targetElement); | 1121 clearAnimatedType(m_targetElement); |
| 1116 } | 1122 } |
| 1117 | 1123 |
| 1124 // Triggering all the pending events if the animation timeline is changed. |
| 1125 if (seekToTime) { |
| 1126 if (m_activeState == Inactive || m_activeState == Frozen) |
| 1127 smilEndEventSender().dispatchEventSoon(this); |
| 1128 } |
| 1129 |
| 1118 m_nextProgressTime = calculateNextProgressTime(elapsed); | 1130 m_nextProgressTime = calculateNextProgressTime(elapsed); |
| 1119 return animationIsContributing; | 1131 return animationIsContributing; |
| 1120 } | 1132 } |
| 1121 | 1133 |
| 1122 void SVGSMILElement::notifyDependentsIntervalChanged(NewOrExistingInterval newOr
Existing) | 1134 void SVGSMILElement::notifyDependentsIntervalChanged(NewOrExistingInterval newOr
Existing) |
| 1123 { | 1135 { |
| 1124 ASSERT(m_intervalBegin.isFinite()); | 1136 ASSERT(m_intervalBegin.isFinite()); |
| 1125 DEFINE_STATIC_LOCAL(HashSet<SVGSMILElement*>, loopBreaker, ()); | 1137 DEFINE_STATIC_LOCAL(HashSet<SVGSMILElement*>, loopBreaker, ()); |
| 1126 if (!loopBreaker.add(this).isNewEntry) | 1138 if (!loopBreaker.add(this).isNewEntry) |
| 1127 return; | 1139 return; |
| (...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1184 SMILTime elapsed = this->elapsed(); | 1196 SMILTime elapsed = this->elapsed(); |
| 1185 addBeginTime(elapsed, elapsed); | 1197 addBeginTime(elapsed, elapsed); |
| 1186 } | 1198 } |
| 1187 | 1199 |
| 1188 void SVGSMILElement::endedActiveInterval() | 1200 void SVGSMILElement::endedActiveInterval() |
| 1189 { | 1201 { |
| 1190 clearTimesWithDynamicOrigins(m_beginTimes); | 1202 clearTimesWithDynamicOrigins(m_beginTimes); |
| 1191 clearTimesWithDynamicOrigins(m_endTimes); | 1203 clearTimesWithDynamicOrigins(m_endTimes); |
| 1192 } | 1204 } |
| 1193 | 1205 |
| 1206 void SVGSMILElement::dispatchPendingEvent(SMILEventSender* eventSender) |
| 1207 { |
| 1208 ASSERT(eventSender == &smilEndEventSender()); |
| 1209 const AtomicString& eventType = eventSender->eventType(); |
| 1210 dispatchEvent(Event::create(eventType)); |
| 1194 } | 1211 } |
| 1212 |
| 1213 } |
| OLD | NEW |