blob: 90d0100ca2c483e651d3afdd94df7e7db0bcd8d2 [file] [log] [blame]
/*
* Copyright (C) 2013 Google Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
*
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the following disclaimer
* in the documentation and/or other materials provided with the
* distribution.
* * Neither the name of Google Inc. nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "core/animation/css/CSSAnimatableValueFactory.h"
#include "core/CSSValueKeywords.h"
#include "core/animation/LengthPropertyFunctions.h"
#include "core/animation/animatable/AnimatableClipPathOperation.h"
#include "core/animation/animatable/AnimatableColor.h"
#include "core/animation/animatable/AnimatableDouble.h"
#include "core/animation/animatable/AnimatableDoubleAndBool.h"
#include "core/animation/animatable/AnimatableFilterOperations.h"
#include "core/animation/animatable/AnimatableImage.h"
#include "core/animation/animatable/AnimatableLength.h"
#include "core/animation/animatable/AnimatableLengthBox.h"
#include "core/animation/animatable/AnimatableLengthBoxAndBool.h"
#include "core/animation/animatable/AnimatableLengthPoint.h"
#include "core/animation/animatable/AnimatableLengthPoint3D.h"
#include "core/animation/animatable/AnimatableLengthSize.h"
#include "core/animation/animatable/AnimatablePath.h"
#include "core/animation/animatable/AnimatableRepeatable.h"
#include "core/animation/animatable/AnimatableSVGPaint.h"
#include "core/animation/animatable/AnimatableShadow.h"
#include "core/animation/animatable/AnimatableShapeValue.h"
#include "core/animation/animatable/AnimatableStrokeDasharrayList.h"
#include "core/animation/animatable/AnimatableTransform.h"
#include "core/animation/animatable/AnimatableUnknown.h"
#include "core/animation/animatable/AnimatableVisibility.h"
#include "core/css/CSSCalculationValue.h"
#include "core/css/CSSIdentifierValue.h"
#include "core/css/CSSPrimitiveValue.h"
#include "core/css/CSSPrimitiveValueMappings.h"
#include "core/css/CSSPropertyMetadata.h"
#include "core/style/ComputedStyle.h"
#include "platform/Length.h"
#include "platform/LengthBox.h"
#include "wtf/StdLibExtras.h"
namespace blink {
static PassRefPtr<AnimatableValue> createFromLengthWithZoom(
const Length& length,
float zoom) {
switch (length.type()) {
case Fixed:
case Percent:
case Calculated:
return AnimatableLength::create(length, zoom);
case Auto:
case MinContent:
case MaxContent:
case FillAvailable:
case FitContent:
return AnimatableUnknown::create(CSSValue::create(length, 1));
case MaxSizeNone:
return AnimatableUnknown::create(CSSValueNone);
case ExtendToZoom: // Does not apply to elements.
case DeviceWidth:
case DeviceHeight:
NOTREACHED();
return nullptr;
}
NOTREACHED();
return nullptr;
}
static PassRefPtr<AnimatableValue> createFromLength(
const Length& length,
const ComputedStyle& style) {
return createFromLengthWithZoom(length, style.effectiveZoom());
}
static PassRefPtr<AnimatableValue> createFromPropertyLength(
CSSPropertyID property,
const ComputedStyle& style) {
Length length;
bool success = LengthPropertyFunctions::getLength(property, style, length);
DCHECK(success);
return createFromLength(length, style);
}
static PassRefPtr<AnimatableValue> createFromUnzoomedLength(
const UnzoomedLength& unzoomedLength) {
return createFromLengthWithZoom(unzoomedLength.length(), 1);
}
static PassRefPtr<AnimatableValue> createFromLineHeight(
const Length& length,
const ComputedStyle& style) {
if (length.type() == Percent) {
double value = length.value();
// -100% is used to represent "normal" line height.
if (value == -100)
return AnimatableUnknown::create(CSSValueNormal);
return AnimatableDouble::create(value);
}
return createFromLength(length, style);
}
inline static PassRefPtr<AnimatableValue> createFromDouble(double value) {
return AnimatableDouble::create(value);
}
inline static PassRefPtr<AnimatableValue> createFromLengthBox(
const LengthBox& lengthBox,
const ComputedStyle& style) {
return AnimatableLengthBox::create(
createFromLength(lengthBox.left(), style),
createFromLength(lengthBox.right(), style),
createFromLength(lengthBox.top(), style),
createFromLength(lengthBox.bottom(), style));
}
static PassRefPtr<AnimatableValue> createFromBorderImageLength(
const BorderImageLength& borderImageLength,
const ComputedStyle& style) {
if (borderImageLength.isNumber())
return createFromDouble(borderImageLength.number());
return createFromLength(borderImageLength.length(), style);
}
inline static PassRefPtr<AnimatableValue> createFromBorderImageLengthBox(
const BorderImageLengthBox& borderImageLengthBox,
const ComputedStyle& style) {
return AnimatableLengthBox::create(
createFromBorderImageLength(borderImageLengthBox.left(), style),
createFromBorderImageLength(borderImageLengthBox.right(), style),
createFromBorderImageLength(borderImageLengthBox.top(), style),
createFromBorderImageLength(borderImageLengthBox.bottom(), style));
}
inline static PassRefPtr<AnimatableValue> createFromLengthBoxAndBool(
const LengthBox lengthBox,
const bool flag,
const ComputedStyle& style) {
return AnimatableLengthBoxAndBool::create(
createFromLengthBox(lengthBox, style), flag);
}
inline static PassRefPtr<AnimatableValue> createFromDoubleAndBool(
double number,
const bool flag,
const ComputedStyle& style) {
return AnimatableDoubleAndBool::create(number, flag);
}
inline static PassRefPtr<AnimatableValue> createFromLengthPoint(
const LengthPoint& lengthPoint,
const ComputedStyle& style) {
return AnimatableLengthPoint::create(
createFromLength(lengthPoint.x(), style),
createFromLength(lengthPoint.y(), style));
}
inline static PassRefPtr<AnimatableValue> createFromTransformOrigin(
const TransformOrigin& transformOrigin,
const ComputedStyle& style) {
return AnimatableLengthPoint3D::create(
createFromLength(transformOrigin.x(), style),
createFromLength(transformOrigin.y(), style),
createFromLength(Length(transformOrigin.z(), Fixed), style));
}
inline static PassRefPtr<AnimatableValue> createFromLengthSize(
const LengthSize& lengthSize,
const ComputedStyle& style) {
return AnimatableLengthSize::create(
createFromLength(lengthSize.width(), style),
createFromLength(lengthSize.height(), style));
}
inline static PassRefPtr<AnimatableValue> createFromStyleImage(
StyleImage* image) {
if (image) {
if (CSSValue* cssValue = image->cssValue())
return AnimatableImage::create(cssValue);
}
return AnimatableUnknown::create(CSSValueNone);
}
inline static PassRefPtr<AnimatableValue> createFromFillSize(
const FillSize& fillSize,
const ComputedStyle& style) {
switch (fillSize.type) {
case SizeLength:
return createFromLengthSize(fillSize.size, style);
case Contain:
case Cover:
case SizeNone:
return AnimatableUnknown::create(
CSSIdentifierValue::create(fillSize.type));
default:
NOTREACHED();
return nullptr;
}
}
inline static PassRefPtr<AnimatableValue> createFromBackgroundPosition(
const Length& length,
bool originIsSet,
BackgroundEdgeOrigin origin,
const ComputedStyle& style) {
if (!originIsSet || origin == LeftEdge || origin == TopEdge)
return createFromLength(length, style);
return createFromLength(length.subtractFromOneHundredPercent(), style);
}
template <CSSPropertyID property>
inline static PassRefPtr<AnimatableValue> createFromFillLayers(
const FillLayer& fillLayers,
const ComputedStyle& style) {
Vector<RefPtr<AnimatableValue>> values;
for (const FillLayer* fillLayer = &fillLayers; fillLayer;
fillLayer = fillLayer->next()) {
if (property == CSSPropertyBackgroundImage ||
property == CSSPropertyWebkitMaskImage) {
if (!fillLayer->isImageSet())
break;
values.push_back(createFromStyleImage(fillLayer->image()));
} else if (property == CSSPropertyBackgroundPositionX ||
property == CSSPropertyWebkitMaskPositionX) {
if (!fillLayer->isXPositionSet())
break;
values.push_back(createFromBackgroundPosition(
fillLayer->xPosition(), fillLayer->isBackgroundXOriginSet(),
fillLayer->backgroundXOrigin(), style));
} else if (property == CSSPropertyBackgroundPositionY ||
property == CSSPropertyWebkitMaskPositionY) {
if (!fillLayer->isYPositionSet())
break;
values.push_back(createFromBackgroundPosition(
fillLayer->yPosition(), fillLayer->isBackgroundYOriginSet(),
fillLayer->backgroundYOrigin(), style));
} else if (property == CSSPropertyBackgroundSize ||
property == CSSPropertyWebkitMaskSize) {
if (!fillLayer->isSizeSet())
break;
values.push_back(createFromFillSize(fillLayer->size(), style));
} else {
NOTREACHED();
}
}
return AnimatableRepeatable::create(values);
}
PassRefPtr<AnimatableValue> CSSAnimatableValueFactory::createFromColor(
CSSPropertyID property,
const ComputedStyle& style) {
Color color = style.colorIncludingFallback(property, false);
Color visitedLinkColor = style.colorIncludingFallback(property, true);
return AnimatableColor::create(color, visitedLinkColor);
}
inline static PassRefPtr<AnimatableValue> createFromShapeValue(
ShapeValue* value) {
if (value)
return AnimatableShapeValue::create(value);
return AnimatableUnknown::create(CSSValueNone);
}
static PassRefPtr<AnimatableValue> createFromPath(StylePath* path) {
return AnimatablePath::create(path);
}
static double fontStretchToDouble(FontStretch fontStretch) {
return static_cast<unsigned>(fontStretch);
}
static PassRefPtr<AnimatableValue> createFromFontStretch(
FontStretch fontStretch) {
return createFromDouble(fontStretchToDouble(fontStretch));
}
static PassRefPtr<AnimatableValue> createFromTransformProperties(
PassRefPtr<TransformOperation> transform,
double zoom,
PassRefPtr<TransformOperation> initialTransform) {
TransformOperations operation;
operation.operations().push_back(transform ? transform : initialTransform);
return AnimatableTransform::create(operation, transform ? zoom : 1);
}
static double fontWeightToDouble(FontWeight fontWeight) {
switch (fontWeight) {
case FontWeight100:
return 100;
case FontWeight200:
return 200;
case FontWeight300:
return 300;
case FontWeight400:
return 400;
case FontWeight500:
return 500;
case FontWeight600:
return 600;
case FontWeight700:
return 700;
case FontWeight800:
return 800;
case FontWeight900:
return 900;
}
NOTREACHED();
return 400;
}
static PassRefPtr<AnimatableValue> createFromFontWeight(FontWeight fontWeight) {
return createFromDouble(fontWeightToDouble(fontWeight));
}
static SVGPaintType normalizeSVGPaintType(SVGPaintType paintType) {
// If the <paint> is 'currentColor', then create an AnimatableSVGPaint with
// a <rgbcolor> type. This is similar in vein to the handling of colors.
return paintType == SVG_PAINTTYPE_CURRENTCOLOR ? SVG_PAINTTYPE_RGBCOLOR
: paintType;
}
PassRefPtr<AnimatableValue> CSSAnimatableValueFactory::create(
CSSPropertyID property,
const ComputedStyle& style) {
DCHECK(CSSPropertyMetadata::isInterpolableProperty(property));
switch (property) {
case CSSPropertyBackgroundColor:
return createFromColor(property, style);
case CSSPropertyBackgroundImage:
return createFromFillLayers<CSSPropertyBackgroundImage>(
style.backgroundLayers(), style);
case CSSPropertyBackgroundPositionX:
return createFromFillLayers<CSSPropertyBackgroundPositionX>(
style.backgroundLayers(), style);
case CSSPropertyBackgroundPositionY:
return createFromFillLayers<CSSPropertyBackgroundPositionY>(
style.backgroundLayers(), style);
case CSSPropertyBackgroundSize:
return createFromFillLayers<CSSPropertyBackgroundSize>(
style.backgroundLayers(), style);
case CSSPropertyBaselineShift:
switch (style.svgStyle().baselineShift()) {
case BS_SUPER:
return AnimatableUnknown::create(
CSSIdentifierValue::create(CSSValueSuper));
case BS_SUB:
return AnimatableUnknown::create(
CSSIdentifierValue::create(CSSValueSub));
default:
return createFromLength(style.baselineShiftValue(), style);
}
case CSSPropertyBorderBottomColor:
return createFromColor(property, style);
case CSSPropertyBorderBottomLeftRadius:
return createFromLengthSize(style.borderBottomLeftRadius(), style);
case CSSPropertyBorderBottomRightRadius:
return createFromLengthSize(style.borderBottomRightRadius(), style);
case CSSPropertyBorderBottomWidth:
return createFromPropertyLength(property, style);
case CSSPropertyBorderImageOutset:
return createFromBorderImageLengthBox(style.borderImageOutset(), style);
case CSSPropertyBorderImageSlice:
return createFromLengthBoxAndBool(style.borderImageSlices(),
style.borderImageSlicesFill(), style);
case CSSPropertyBorderImageSource:
return createFromStyleImage(style.borderImageSource());
case CSSPropertyBorderImageWidth:
return createFromBorderImageLengthBox(style.borderImageWidth(), style);
case CSSPropertyBorderLeftColor:
return createFromColor(property, style);
case CSSPropertyBorderLeftWidth:
return createFromPropertyLength(property, style);
case CSSPropertyBorderRightColor:
return createFromColor(property, style);
case CSSPropertyBorderRightWidth:
return createFromPropertyLength(property, style);
case CSSPropertyBorderTopColor:
return createFromColor(property, style);
case CSSPropertyBorderTopLeftRadius:
return createFromLengthSize(style.borderTopLeftRadius(), style);
case CSSPropertyBorderTopRightRadius:
return createFromLengthSize(style.borderTopRightRadius(), style);
case CSSPropertyBorderTopWidth:
return createFromPropertyLength(property, style);
case CSSPropertyBottom:
return createFromLength(style.bottom(), style);
case CSSPropertyBoxShadow:
return AnimatableShadow::create(style.boxShadow(), style.color());
case CSSPropertyClip:
if (style.hasAutoClip()) {
return AnimatableUnknown::create(
CSSIdentifierValue::create(CSSValueAuto));
}
return createFromLengthBox(style.clip(), style);
case CSSPropertyColor:
return createFromColor(property, style);
case CSSPropertyFillOpacity:
return createFromDouble(style.fillOpacity());
case CSSPropertyFill:
return AnimatableSVGPaint::create(
normalizeSVGPaintType(style.svgStyle().fillPaintType()),
normalizeSVGPaintType(style.svgStyle().visitedLinkFillPaintType()),
style.svgStyle().fillPaintColor(),
style.svgStyle().visitedLinkFillPaintColor(),
style.svgStyle().fillPaintUri(),
style.svgStyle().visitedLinkFillPaintUri());
case CSSPropertyFlexGrow:
return createFromDouble(style.flexGrow());
case CSSPropertyFlexShrink:
return createFromDouble(style.flexShrink());
case CSSPropertyFlexBasis:
return createFromLength(style.flexBasis(), style);
case CSSPropertyFloodColor:
return createFromColor(property, style);
case CSSPropertyFloodOpacity:
return createFromDouble(style.floodOpacity());
case CSSPropertyFontSize:
// Must pass a specified size to setFontSize if Text Autosizing is
// enabled, but a computed size if text zoom is enabled (if neither is
// enabled it's irrelevant as they're probably the same).
// FIXME: Should we introduce an option to pass the computed font size
// here, allowing consumers to enable text zoom rather than Text
// Autosizing? See http://crbug.com/227545.
return createFromDouble(style.specifiedFontSize());
case CSSPropertyFontSizeAdjust:
return style.hasFontSizeAdjust()
? createFromDouble(style.fontSizeAdjust())
: AnimatableUnknown::create(CSSValueNone);
case CSSPropertyFontStretch:
return createFromFontStretch(style.fontStretch());
case CSSPropertyFontWeight:
return createFromFontWeight(style.fontWeight());
case CSSPropertyHeight:
return createFromLength(style.height(), style);
case CSSPropertyLightingColor:
return createFromColor(property, style);
case CSSPropertyListStyleImage:
return createFromStyleImage(style.listStyleImage());
case CSSPropertyLeft:
return createFromLength(style.left(), style);
case CSSPropertyLetterSpacing:
return createFromPropertyLength(property, style);
case CSSPropertyLineHeight:
return createFromLineHeight(style.specifiedLineHeight(), style);
case CSSPropertyMarginBottom:
return createFromLength(style.marginBottom(), style);
case CSSPropertyMarginLeft:
return createFromLength(style.marginLeft(), style);
case CSSPropertyMarginRight:
return createFromLength(style.marginRight(), style);
case CSSPropertyMarginTop:
return createFromLength(style.marginTop(), style);
case CSSPropertyMaxHeight:
return createFromLength(style.maxHeight(), style);
case CSSPropertyMaxWidth:
return createFromLength(style.maxWidth(), style);
case CSSPropertyMinHeight:
return createFromLength(style.minHeight(), style);
case CSSPropertyMinWidth:
return createFromLength(style.minWidth(), style);
case CSSPropertyObjectPosition:
return createFromLengthPoint(style.objectPosition(), style);
case CSSPropertyOpacity:
return createFromDouble(style.opacity());
case CSSPropertyOrphans:
return createFromDouble(style.orphans());
case CSSPropertyOutlineColor:
return createFromColor(property, style);
case CSSPropertyOutlineOffset:
return createFromPropertyLength(property, style);
case CSSPropertyOutlineWidth:
return createFromPropertyLength(property, style);
case CSSPropertyPaddingBottom:
return createFromLength(style.paddingBottom(), style);
case CSSPropertyPaddingLeft:
return createFromLength(style.paddingLeft(), style);
case CSSPropertyPaddingRight:
return createFromLength(style.paddingRight(), style);
case CSSPropertyPaddingTop:
return createFromLength(style.paddingTop(), style);
case CSSPropertyRight:
return createFromLength(style.right(), style);
case CSSPropertyStrokeWidth:
return createFromUnzoomedLength(style.strokeWidth());
case CSSPropertyStopColor:
return createFromColor(property, style);
case CSSPropertyStopOpacity:
return createFromDouble(style.stopOpacity());
case CSSPropertyStrokeDasharray:
return AnimatableStrokeDasharrayList::create(style.strokeDashArray(),
style.effectiveZoom());
case CSSPropertyStrokeDashoffset:
return createFromLength(style.strokeDashOffset(), style);
case CSSPropertyStrokeMiterlimit:
return createFromDouble(style.strokeMiterLimit());
case CSSPropertyStrokeOpacity:
return createFromDouble(style.strokeOpacity());
case CSSPropertyStroke:
return AnimatableSVGPaint::create(
normalizeSVGPaintType(style.svgStyle().strokePaintType()),
normalizeSVGPaintType(style.svgStyle().visitedLinkStrokePaintType()),
style.svgStyle().strokePaintColor(),
style.svgStyle().visitedLinkStrokePaintColor(),
style.svgStyle().strokePaintUri(),
style.svgStyle().visitedLinkStrokePaintUri());
case CSSPropertyTextDecorationColor:
return createFromColor(property, style);
case CSSPropertyTextIndent:
return createFromLength(style.textIndent(), style);
case CSSPropertyTextShadow:
return AnimatableShadow::create(style.textShadow(), style.color());
case CSSPropertyTop:
return createFromLength(style.top(), style);
case CSSPropertyWebkitBorderHorizontalSpacing:
return createFromPropertyLength(property, style);
case CSSPropertyWebkitBorderVerticalSpacing:
return createFromPropertyLength(property, style);
case CSSPropertyClipPath:
if (ClipPathOperation* operation = style.clipPath())
return AnimatableClipPathOperation::create(operation);
return AnimatableUnknown::create(CSSValueNone);
case CSSPropertyColumnCount:
if (style.hasAutoColumnCount())
return AnimatableUnknown::create(CSSValueAuto);
return createFromDouble(style.columnCount());
case CSSPropertyColumnGap:
return createFromPropertyLength(property, style);
case CSSPropertyColumnRuleColor:
return createFromColor(property, style);
case CSSPropertyColumnRuleWidth:
return createFromPropertyLength(property, style);
case CSSPropertyColumnWidth:
if (style.hasAutoColumnWidth())
return AnimatableUnknown::create(CSSValueAuto);
return createFromPropertyLength(property, style);
case CSSPropertyFilter:
return AnimatableFilterOperations::create(style.filter());
case CSSPropertyBackdropFilter:
return AnimatableFilterOperations::create(style.backdropFilter());
case CSSPropertyWebkitMaskBoxImageOutset:
return createFromBorderImageLengthBox(style.maskBoxImageOutset(), style);
case CSSPropertyWebkitMaskBoxImageSlice:
return createFromLengthBoxAndBool(style.maskBoxImageSlices(),
style.maskBoxImageSlicesFill(), style);
case CSSPropertyWebkitMaskBoxImageSource:
return createFromStyleImage(style.maskBoxImageSource());
case CSSPropertyWebkitMaskBoxImageWidth:
return createFromBorderImageLengthBox(style.maskBoxImageWidth(), style);
case CSSPropertyWebkitMaskImage:
return createFromFillLayers<CSSPropertyWebkitMaskImage>(
style.maskLayers(), style);
case CSSPropertyWebkitMaskPositionX:
return createFromFillLayers<CSSPropertyWebkitMaskPositionX>(
style.maskLayers(), style);
case CSSPropertyWebkitMaskPositionY:
return createFromFillLayers<CSSPropertyWebkitMaskPositionY>(
style.maskLayers(), style);
case CSSPropertyWebkitMaskSize:
return createFromFillLayers<CSSPropertyWebkitMaskSize>(style.maskLayers(),
style);
case CSSPropertyPerspective:
if (style.perspective() == 0) {
return AnimatableUnknown::create(
CSSIdentifierValue::create(CSSValueNone));
}
return createFromPropertyLength(property, style);
case CSSPropertyPerspectiveOrigin:
return createFromLengthPoint(style.perspectiveOrigin(), style);
case CSSPropertyShapeOutside:
return createFromShapeValue(style.shapeOutside());
case CSSPropertyShapeMargin:
return createFromLength(style.shapeMargin(), style);
case CSSPropertyShapeImageThreshold:
return createFromDouble(style.shapeImageThreshold());
case CSSPropertyWebkitTextStrokeColor:
return createFromColor(property, style);
case CSSPropertyTransform:
return AnimatableTransform::create(style.transform(),
style.effectiveZoom());
case CSSPropertyTranslate: {
DEFINE_STATIC_REF(TranslateTransformOperation, initialTranslate,
TranslateTransformOperation::create(
Length(0, Fixed), Length(0, Fixed), 0,
TransformOperation::Translate3D));
return createFromTransformProperties(
style.translate(), style.effectiveZoom(), initialTranslate);
}
case CSSPropertyRotate: {
DEFINE_STATIC_REF(RotateTransformOperation, initialRotate,
RotateTransformOperation::create(
0, 0, 1, 0, TransformOperation::Rotate3D));
return createFromTransformProperties(
style.rotate(), style.effectiveZoom(), initialRotate);
}
case CSSPropertyScale: {
DEFINE_STATIC_REF(ScaleTransformOperation, initialScale,
ScaleTransformOperation::create(
1, 1, 1, TransformOperation::Scale3D));
return createFromTransformProperties(style.scale(), style.effectiveZoom(),
initialScale);
}
case CSSPropertyOffsetAnchor:
return createFromLengthPoint(style.offsetAnchor(), style);
case CSSPropertyOffsetDistance:
return createFromLength(style.offsetDistance(), style);
case CSSPropertyOffsetPosition:
return createFromLengthPoint(style.offsetPosition(), style);
case CSSPropertyOffsetRotate:
case CSSPropertyOffsetRotation:
return createFromDoubleAndBool(
style.offsetRotation().angle,
style.offsetRotation().type == OffsetRotationAuto, style);
case CSSPropertyTransformOrigin:
return createFromTransformOrigin(style.transformOrigin(), style);
case CSSPropertyWebkitPerspectiveOriginX:
return createFromLength(style.perspectiveOriginX(), style);
case CSSPropertyWebkitPerspectiveOriginY:
return createFromLength(style.perspectiveOriginY(), style);
case CSSPropertyWebkitTransformOriginX:
return createFromLength(style.transformOriginX(), style);
case CSSPropertyWebkitTransformOriginY:
return createFromLength(style.transformOriginY(), style);
case CSSPropertyWebkitTransformOriginZ:
return createFromPropertyLength(property, style);
case CSSPropertyWidows:
return createFromDouble(style.widows());
case CSSPropertyWidth:
return createFromLength(style.width(), style);
case CSSPropertyWordSpacing:
return createFromPropertyLength(property, style);
case CSSPropertyVerticalAlign:
if (style.verticalAlign() == EVerticalAlign::Length)
return createFromLength(style.getVerticalAlignLength(), style);
return AnimatableUnknown::create(
CSSIdentifierValue::create(style.verticalAlign()));
case CSSPropertyVisibility:
return AnimatableVisibility::create(style.visibility());
case CSSPropertyD:
return createFromPath(style.svgStyle().d());
case CSSPropertyCx:
return createFromLength(style.svgStyle().cx(), style);
case CSSPropertyCy:
return createFromLength(style.svgStyle().cy(), style);
case CSSPropertyX:
return createFromLength(style.svgStyle().x(), style);
case CSSPropertyY:
return createFromLength(style.svgStyle().y(), style);
case CSSPropertyR:
return createFromLength(style.svgStyle().r(), style);
case CSSPropertyRx:
return createFromLength(style.svgStyle().rx(), style);
case CSSPropertyRy:
return createFromLength(style.svgStyle().ry(), style);
case CSSPropertyZIndex:
if (style.hasAutoZIndex())
return AnimatableUnknown::create(CSSValueAuto);
return createFromDouble(style.zIndex());
default:
NOTREACHED();
return nullptr;
}
}
} // namespace blink