Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(60)

Side by Side Diff: Source/core/animation/LengthBoxStyleInterpolation.cpp

Issue 1304993002: Change Rect and Quad to be CSSValues (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@split_counter_out_attempt_3
Patch Set: Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "config.h" 5 #include "config.h"
6 #include "core/animation/LengthBoxStyleInterpolation.h" 6 #include "core/animation/LengthBoxStyleInterpolation.h"
7 7
8 #include "core/css/resolver/StyleBuilder.h" 8 #include "core/css/resolver/StyleBuilder.h"
9 9
10 namespace blink { 10 namespace blink {
11 11
12 namespace { 12 namespace {
13 13
14 bool onlyInterpolateBetweenLengthAndCSSValueAuto(Rect& startRect, Rect& endRect) 14 bool onlyInterpolateBetweenLengthAndCSSValueAuto(const CSSQuadValue& startRect, const CSSQuadValue& endRect)
15 { 15 {
16 return startRect.left()->isLength() != endRect.left()->isLength() 16 return startRect.left()->isLength() != endRect.left()->isLength()
17 && startRect.right()->isLength() != endRect.right()->isLength() 17 && startRect.right()->isLength() != endRect.right()->isLength()
18 && startRect.top()->isLength() != endRect.top()->isLength() 18 && startRect.top()->isLength() != endRect.top()->isLength()
19 && startRect.bottom()->isLength() != endRect.bottom()->isLength(); 19 && startRect.bottom()->isLength() != endRect.bottom()->isLength();
20 } 20 }
21 21
22 } // namespace 22 } // namespace
23 23
24 PassRefPtrWillBeRawPtr<LengthBoxStyleInterpolation> LengthBoxStyleInterpolation: :maybeCreateFrom(CSSValue& start, CSSValue& end, CSSPropertyID id) 24 PassRefPtrWillBeRawPtr<LengthBoxStyleInterpolation> LengthBoxStyleInterpolation: :maybeCreateFrom(CSSValue& start, CSSValue& end, CSSPropertyID id)
25 { 25 {
26 bool startRect = start.isPrimitiveValue() && toCSSPrimitiveValue(start).isRe ct(); 26 bool startRect = start.isQuadValue() && toCSSQuadValue(start).isRect();
27 bool endRect = end.isPrimitiveValue() && toCSSPrimitiveValue(end).isRect(); 27 bool endRect = end.isQuadValue() && toCSSQuadValue(end).isRect();
28 28
29 if (startRect && endRect) 29 if (startRect && endRect)
30 return adoptRefWillBeNoop(new LengthBoxStyleInterpolation(lengthBoxtoInt erpolableValue(start, end, false), lengthBoxtoInterpolableValue(end, start, true ), id, &start, &end)); 30 return adoptRefWillBeNoop(new LengthBoxStyleInterpolation(lengthBoxtoInt erpolableValue(start, end, false), lengthBoxtoInterpolableValue(end, start, true ), id, &start, &end));
31 return nullptr; 31 return nullptr;
32 } 32 }
33 33
34 PassOwnPtrWillBeRawPtr<InterpolableValue> LengthBoxStyleInterpolation::lengthBox toInterpolableValue(const CSSValue& lengthBox, const CSSValue& matchingValue, bo ol isEndInterpolation) 34 PassOwnPtrWillBeRawPtr<InterpolableValue> LengthBoxStyleInterpolation::lengthBox toInterpolableValue(const CSSValue& lengthBox, const CSSValue& matchingValue, bo ol isEndInterpolation)
35 { 35 {
36 const int numberOfSides = 4; 36 const int numberOfSides = 4;
37 OwnPtrWillBeRawPtr<InterpolableList> result = InterpolableList::create(numbe rOfSides); 37 OwnPtrWillBeRawPtr<InterpolableList> result = InterpolableList::create(numbe rOfSides);
38 Rect* rect = toCSSPrimitiveValue(lengthBox).getRectValue(); 38 const CSSQuadValue& rect = toCSSQuadValue(lengthBox);
39 Rect* matchingRect = toCSSPrimitiveValue(matchingValue).getRectValue(); 39 const CSSQuadValue& matchingRect = toCSSQuadValue(matchingValue);
40 CSSPrimitiveValue* side[numberOfSides] = { rect->left(), rect->right(), rect ->top(), rect->bottom() }; 40 CSSPrimitiveValue* side[numberOfSides] = { rect.left(), rect.right(), rect.t op(), rect.bottom() };
41 CSSPrimitiveValue* matchingSide[numberOfSides] = { matchingRect->left(), mat chingRect->right(), matchingRect->top(), matchingRect->bottom() }; 41 CSSPrimitiveValue* matchingSide[numberOfSides] = { matchingRect.left(), matc hingRect.right(), matchingRect.top(), matchingRect.bottom() };
42 42
43 for (size_t i = 0; i < numberOfSides; i++) { 43 for (size_t i = 0; i < numberOfSides; i++) {
44 if (side[i]->isValueID() || matchingSide[i]->isValueID()) { 44 if (side[i]->isValueID() || matchingSide[i]->isValueID()) {
45 result->set(i, InterpolableBool::create(isEndInterpolation)); 45 result->set(i, InterpolableBool::create(isEndInterpolation));
46 } else { 46 } else {
47 ASSERT(LengthStyleInterpolation::canCreateFrom(*side[i])); 47 ASSERT(LengthStyleInterpolation::canCreateFrom(*side[i]));
48 result->set(i, LengthStyleInterpolation::toInterpolableValue(*side[i ])); 48 result->set(i, LengthStyleInterpolation::toInterpolableValue(*side[i ]));
49 } 49 }
50 } 50 }
51 return result.release(); 51 return result.release();
52 } 52 }
53 53
54 bool LengthBoxStyleInterpolation::usesDefaultInterpolation(const CSSValue& start , const CSSValue& end) 54 bool LengthBoxStyleInterpolation::usesDefaultInterpolation(const CSSValue& start , const CSSValue& end)
55 { 55 {
56 if (!start.isPrimitiveValue() || !end.isPrimitiveValue()) 56 if (start.isPrimitiveValue() && end.isPrimitiveValue()) {
57 const CSSPrimitiveValue& startValue = toCSSPrimitiveValue(start);
58 const CSSPrimitiveValue& endValue = toCSSPrimitiveValue(end);
59 if ((startValue.isValueID() && startValue.getValueID() == CSSValueAuto)
60 || (endValue.isValueID() && endValue.getValueID() == CSSValueAuto))
61 return true;
57 return false; 62 return false;
58 const CSSPrimitiveValue& startValue = toCSSPrimitiveValue(start); 63 }
59 const CSSPrimitiveValue& endValue = toCSSPrimitiveValue(end); 64
60 if ((startValue.isValueID() && startValue.getValueID() == CSSValueAuto) 65 if (!start.isQuadValue() || !end.isQuadValue())
61 || (endValue.isValueID() && endValue.getValueID() == CSSValueAuto)) 66 return false;
62 return true; 67
63 return onlyInterpolateBetweenLengthAndCSSValueAuto(*startValue.getRectValue( ), *endValue.getRectValue()); 68 const CSSQuadValue& startValue = toCSSQuadValue(start);
69 const CSSQuadValue& endValue = toCSSQuadValue(end);
70 return onlyInterpolateBetweenLengthAndCSSValueAuto(startValue, endValue);
64 } 71 }
65 72
66 namespace { 73 namespace {
67 74
68 PassRefPtrWillBeRawPtr<CSSPrimitiveValue> indexedValueToLength(InterpolableList& lengthBox, size_t i, CSSPrimitiveValue* start[], CSSPrimitiveValue* end[]) 75 PassRefPtrWillBeRawPtr<CSSPrimitiveValue> indexedValueToLength(InterpolableList& lengthBox, size_t i, CSSPrimitiveValue* start[], CSSPrimitiveValue* end[])
69 { 76 {
70 if (lengthBox.get(i)->isBool()) { 77 if (lengthBox.get(i)->isBool()) {
71 if (toInterpolableBool(lengthBox.get(i))->value()) 78 if (toInterpolableBool(lengthBox.get(i))->value())
72 return end[i]; 79 return end[i];
73 return start[i]; 80 return start[i];
74 } 81 }
75 return LengthStyleInterpolation::fromInterpolableValue(*lengthBox.get(i), Ra ngeAll); 82 return LengthStyleInterpolation::fromInterpolableValue(*lengthBox.get(i), Ra ngeAll);
76 } 83 }
77 84
78 } 85 }
79 86
80 PassRefPtrWillBeRawPtr<CSSValue> LengthBoxStyleInterpolation::interpolableValueT oLengthBox(InterpolableValue* value, const CSSValue& originalStart, const CSSVal ue& originalEnd) 87 PassRefPtrWillBeRawPtr<CSSValue> LengthBoxStyleInterpolation::interpolableValueT oLengthBox(InterpolableValue* value, const CSSValue& originalStart, const CSSVal ue& originalEnd)
81 { 88 {
82 InterpolableList* lengthBox = toInterpolableList(value); 89 InterpolableList* lengthBox = toInterpolableList(value);
83 Rect* startRect = toCSSPrimitiveValue(originalStart).getRectValue(); 90 const CSSQuadValue& startRect = toCSSQuadValue(originalStart);
84 Rect* endRect = toCSSPrimitiveValue(originalEnd).getRectValue(); 91 const CSSQuadValue& endRect = toCSSQuadValue(originalEnd);
85 CSSPrimitiveValue* startSides[4] = { startRect->left(), startRect->right(), startRect->top(), startRect->bottom() }; 92 CSSPrimitiveValue* startSides[4] = { startRect.left(), startRect.right(), st artRect.top(), startRect.bottom() };
86 CSSPrimitiveValue* endSides[4] = { endRect->left(), endRect->right(), endRec t->top(), endRect->bottom() }; 93 CSSPrimitiveValue* endSides[4] = { endRect.left(), endRect.right(), endRect. top(), endRect.bottom() };
87 RefPtrWillBeRawPtr<Rect> result = Rect::create();
88 94
89 result->setLeft(indexedValueToLength(*lengthBox, 0, startSides, endSides)); 95 RefPtrWillBeRawPtr<CSSPrimitiveValue> left = indexedValueToLength(*lengthBox , 0, startSides, endSides);
90 result->setRight(indexedValueToLength(*lengthBox, 1, startSides, endSides)); 96 RefPtrWillBeRawPtr<CSSPrimitiveValue> right = indexedValueToLength(*lengthBo x, 1, startSides, endSides);
91 result->setTop(indexedValueToLength(*lengthBox, 2, startSides, endSides)); 97 RefPtrWillBeRawPtr<CSSPrimitiveValue> top = indexedValueToLength(*lengthBox, 2, startSides, endSides);
92 result->setBottom(indexedValueToLength(*lengthBox, 3, startSides, endSides)) ; 98 RefPtrWillBeRawPtr<CSSPrimitiveValue> bottom = indexedValueToLength(*lengthB ox, 3, startSides, endSides);
93 99
94 return CSSPrimitiveValue::create(result.release()); 100 return CSSQuadValue::createRect(top, right, bottom, left);
95 } 101 }
96 102
97 void LengthBoxStyleInterpolation::apply(StyleResolverState& state) const 103 void LengthBoxStyleInterpolation::apply(StyleResolverState& state) const
98 { 104 {
99 if (m_cachedValue.get()->isBool()) 105 if (m_cachedValue.get()->isBool())
100 StyleBuilder::applyProperty(m_id, state, toInterpolableBool(m_cachedValu e.get())->value() ? m_endCSSValue.get() : m_startCSSValue.get()); 106 StyleBuilder::applyProperty(m_id, state, toInterpolableBool(m_cachedValu e.get())->value() ? m_endCSSValue.get() : m_startCSSValue.get());
101 else 107 else
102 StyleBuilder::applyProperty(m_id, state, interpolableValueToLengthBox(m_ cachedValue.get(), *m_startCSSValue, *m_endCSSValue).get()); 108 StyleBuilder::applyProperty(m_id, state, interpolableValueToLengthBox(m_ cachedValue.get(), *m_startCSSValue, *m_endCSSValue).get());
103 } 109 }
104 110
105 DEFINE_TRACE(LengthBoxStyleInterpolation) 111 DEFINE_TRACE(LengthBoxStyleInterpolation)
106 { 112 {
107 StyleInterpolation::trace(visitor); 113 StyleInterpolation::trace(visitor);
108 visitor->trace(m_startCSSValue); 114 visitor->trace(m_startCSSValue);
109 visitor->trace(m_endCSSValue); 115 visitor->trace(m_endCSSValue);
110 } 116 }
111 117
112 } 118 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698