[Table of Contents] [docx version]

VML Reference Material - VML

extrusion (3D Extrusion)

This element specifies a parallel or perspective extrusion of a 2-D shape, creating the appearance of a 3-D shape. Lighting is controlled via two independent point light sources. Extrusions are defined as either perspective or parallel.

[Example:

<v:polyline points="0pt,75pt 20pt,45pt 10pt,50pt 30pt,10pt

50pt,50pt 40pt,45pt 60pt,75pt 0pt,75pt" fillcolor="#00a000">

<o:extrusion on="t" backdepth="20pt"

lightposition="30000,10000,10000"/>

</v:polyline>

end example]

Parent Elements

arc6.1.2.1); background2.2.1); curve6.1.2.3); group6.1.2.7); hdrShapeDefaults2.15.1.50); image6.1.2.10); line6.1.2.12); object2.3.3.19); oval6.1.2.13); pict2.3.3.21); pict2.9.23); polyline6.1.2.15); rect6.1.2.16); roundrect6.1.2.17); shape6.1.2.19); shapedefaults6.2.2.27); shapeDefaults2.15.1.79); shapetype6.1.2.20)

 

Attributes

Description

autorotationcenter (Center of Rotation Toggle)

Specifies whether the center of rotation is the geometric center of the extrusion. Default is false. If true, the geometric center of an extruded shape is (0,0,0). If false, the center of rotation is determined by the rotationcenter attribute.

 

The possible values for this attribute are defined by the ST_TrueFalse simple type (§6.2.3.23).

backdepth (Backward Extrusion Depth)

Specifies the amount of backward extrusion. Default is 36 pt, default units are points.

[Example:

 

<o:extrusion on="true" backdepth="15pt">

</o:extrusion>

 

 

end example]

 

The possible values for this attribute are defined by the XML Schema string datatype.

brightness (Brightness)

Specifies the overall brightness of a scene. Default is 0.3. This numeric value may also be specified in 1/65536-ths if a trailing "f" is supplied (as "f" indicates the value is a fraction). For example, a value of "52429f" represents 52429/65536 or 0.8.

 

This quantity is not specified using units. The numeric values range from 0 to 1 (0f to 65536f), where 0 implies darkness and 1 implies light saturation.

 

[Example:

 

<o:extrusion on="true" brightness="0.4">

</o:extrusion>

 

brightness="0"

brightness="25000f"

brightness="0.4"

brightness="0.75"

 

end example]

 

The possible values for this attribute are defined by the XML Schema string datatype.

color (Extrusion Color)

Specifies the color of the extrusion faces. This attribute is only used when colormode is custom. Colors are typically specified as either a named color, such as red, or six hexadecimal digits representing the red, green and blue values of the color, such as #00FF30. Full details are specified in the simple type description.

 

[Example:

 

<o:extrusion on="true" color="lime"

colormode="custom">

</o:extrusion>

 

 

end example]

 

The possible values for this attribute are defined by the ST_ColorType simple type (§6.2.3.5).

colormode (Extrusion Color Mode)

Specifies whether the extrusion color is defined by the color attribute or is the same as the shape's fill color. Default is auto.

 

[Example:

 

<o:extrusion on="true" color="lime"

colormode="auto">

</o:extrusion>

 

 

end example]

 

The possible values for this attribute are defined by the ST_ColorMode simple type (§6.2.3.4).

diffusity (Diffuse Reflection)

Specifies the amount of diffusion of reflected light from an extruded shape, defined as the ratio of incident light to diffused reflected light. Default is 1. Normal values range from 0 to 1. This numeric value may also be specified in 1/65536-ths if a trailing "f" is supplied (as "f" indicates the value is a fraction). For example, a value of "52429f" represents 52429/65536 or 0.8.

 

This quantity is not specified using units. The numeric values range from 0 to 1 (0f to 65536f), where 0 implies all reflected light is diffuse and 1 implies no reflected light is diffuse.

 

Note that specularity and diffusity should be considered together as it is possible, though physically incorrect, to define more reflected light than incident light. This is the case if the amount of specularly reflected light and diffusely reflected light add up to more than the amount of incident light.

 

[Example:

 

<o:extrusion on="true" diffusity=".75">

</o:extrusion>

 

diffusity="0"

diffusity="0.5"

diffusity="0.75"

diffusity="1"

 

end example]

 

The possible values for this attribute are defined by the XML Schema string datatype.

edge (Simulated Bevel)

Specifies the apparent bevel of the extrusion edges. Default is 1 point.

 

[Example:

 

<o:extrusion on="true" edge="2pt">

</o:extrusion>

 

 

end example]

 

The possible values for this attribute are defined by the XML Schema string datatype.

ext (VML Extension Handling Behavior)

 

Namespace: urn:schemas-microsoft-com:vml

Specifies an optional value that indicates how applications that implement VML should interpret extensions not defined as part of the original specification of core VML.

 

[Rationale: This part of the original VML specification is included to assist applications that leverage existing VML support in implementing the Office Open XML Format. end rationale]

 

The possible values for this attribute are defined by the ST_Ext simple type (§6.1.3.3).

facet (Faceting Quality)

Specifies the quality with which the application approximates curved surfaces of an extrusion. A higher facet value produces shapes with smoother curves. A lower value reduces smoothing, resulting in curves with sharper, jagged edges. Default is 30000.

 

Valid values range from 1 to 65536, where 1 implies extremely low quality curve approximation and 65536 implies extremely high quality.

 

[Example:

 

<o:extrusion on="true" facet="65536">

</o:extrusion>

 

facet="65536"

facet="100"

 

end example]

 

The possible values for this attribute are defined by the XML Schema string datatype.

foredepth (Forward Extrusion)

Specifies the amount of forward extrusion. Default is 0 pt, default units are points.

[Example:

 

<o:extrusion on="true" foredepth="25pt">

</o:extrusion>

 

 

end example]

 

The possible values for this attribute are defined by the XML Schema string datatype.

lightface (Shape Face Lighting Toggle)

Specifies whether the front face of the extrusion responds to changes in the lighting. If false, the front face does not respond when a lighting value changes. Default is true.

 

[Example: The front face is colored as if the shape were not extruded and lit by a 3-D light source:

 

<o:extrusion on="true" lightface="false">

</o:extrusion>

 

 

end example]

 

The possible values for this attribute are defined by the ST_TrueFalse simple type (§6.2.3.23).

lightharsh (Primary Light Harshness Toggle)

Specifies whether the primary light source is harsh. If false, shadow boundaries are diffused. Default is true.

 

[Example: The secondary light source is turned off so only the primary has an effect:

 

<o:extrusion on="true" lightharsh="false"

lightlevel2="0">

</o:extrusion>

 

lightharsh="false"

lightharsh="true"

 

end example]

 

The possible values for this attribute are defined by the ST_TrueFalse simple type (§6.2.3.23).

lightharsh2 (Secondary Light Harshness Toggle)

Specifies whether the secondary light source is harsh. If false, shadow boundaries defined by the secondary light source are diffused. Default is false.

 

The possible values for this attribute are defined by the ST_TrueFalse simple type (§6.2.3.23).

lightlevel (Primary Light Intensity)

Specifies the intensity of the primary light source for the scene. Default is 0.6. This numeric value may also be specified in 1/65536-ths if a trailing "f" is supplied (as "f" indicates the value is a fraction). For example, a value of "52429f" represents 52429/65536 or 0.8.

 

This quantity is not specified using units. The numeric values range from 0 to 1 (0f to 65536f), where 0 implies no direct light and 1 implies saturated direct light.

 

[Example: The secondary light source is turned off so only the primary has an effect:

 

<o:extrusion on="true" lightlevel=".5"

lightlevel2="0">

</o:extrusion>

 

lightlevel="1"

lightlevel="0.5"

lightlevel="0"

 

end example]

 

The possible values for this attribute are defined by the XML Schema string datatype.

lightlevel2 (Secondary Light Intensity)

Specifies the intensity of the secondary light source for the scene. Default is 0.6. This numeric value may also be specified in 1/65536-ths if a trailing "f" is supplied (as "f" indicates the value is a fraction). For example, a value of "52429f" represents 52429/65536 or 0.8.

 

This quantity is not specified using units. The numeric values range from 0 to 1 (0f to 65536f), where 0 implies no direct light and 1 implies saturated direct light.

 

The possible values for this attribute are defined by the XML Schema string datatype.

lightposition (Primary Light Position)

Specifies the normalized X,Y,Z position of the primary light in a scene in 1/65536-ths. Default is "50000,0,10000". The use of a normalized vector from the shape origin effectively establishes the direction of the light relative to the shape. The distance of the light from the shape is irrelevant as the light source is treated as a directional light.

 

The position "0,0,0" is at the center of the shape. Positive numbers move the light to the right, down and toward the viewer, respectively.

 

[Example: The secondary light source is turned off so only the primary has an effect:

   

<o:extrusion on="true" lightlevel2="0"

lightposition="7000,-13000,20000">

</o:extrusion>

 

 

end example]

 

The possible values for this attribute are defined by the XML Schema string datatype.

lightposition2 (Secondary Light Position)

Specifies the X,Y,Z position of the secondary light in a scene in 1/65536-ths. Default is "-50000,0,10000". The use of a normalized vector from the shape origin effectively establishes the direction of the light relative to the shape. The distance of the light from the shape is irrelevant as the light source is treated as a directional light.

 

The position "0,0,0" is at the center of the shape. Positive numbers move the light to the right, down and toward the viewer, respectively.

 

The possible values for this attribute are defined by the XML Schema string datatype.

lockrotationcenter (Rotation Toggle)

Specifies whether the rotation of the extruded object is specified by the rotationangle attribute. If false, the rotation is specified by the orientation attribute. Default is true.

 

[Example: The following snippets are equivalent:

 

<o:extrusion lockrotationcenter="false"

orientationangle="45" orientation="0,1,0">

</o:extrusion>

 

<o:extrusion lockrotationcenter=true

rotationangle="45"/>

</o:extrusion>

 

end example]

 

The possible values for this attribute are defined by the ST_TrueFalse simple type (§6.2.3.23).

metal (Metallic Surface Toggle)

Specifies whether the surface of the extruded shape resembles metal. Default is false.

 

If true, this attribute causes the specularly reflected light to be the material color instead of the light source color, making the object seem more metallic. To further approximate a metallic material requires that specularity be relatively high (about 1.2) and diffusity be relatively low (about 0.6).

 

[Example:

 

<o:extrusion on="true" metal="true"

lightposition="10000,-10000,10000"

lightlevel2="0" specularity="1.2"

diffusity="0.6">

</o:extrusion>

 

metal="true"

metal="false"

 

end example]

 

The possible values for this attribute are defined by the ST_TrueFalse simple type (§6.2.3.23).

on (Extrusion Toggle)

Specifies whether an extrusion is displayed. Default is false.

 

[Example:

 

<v:rect style="width=50;height=50">

<o:extrusion />

</v:rect>

 

 

end example]

 

The possible values for this attribute are defined by the ST_TrueFalse simple type (§6.2.3.23).

orientation (Rotation Axis)

Specifies a vector in 3D space around which the shape is rotated, as given by the orientationangle attribute. Default is "100,0,0".

 

The position "0,0,0" is at the center of the shape. Positive numbers are to the right, down and toward the viewer, respectively.

 

[Example:

 

<o:extrusion ... orientation="200,0,0">

</o:extrusion>

 

end example]

 

The possible values for this attribute are defined by the XML Schema string datatype.

orientationangle (Rotation Around Axis)

Specifies the angle, in degrees, that an extrusion rotates around the orientation. Default is 0.

 

[Example:

 

<o:extrusion ... orientationangle="30">

</o:extrusion>

 

end example]

 

The possible values for this attribute are defined by the XML Schema float datatype.

plane (Extrusion Direction)

Specifies the plane that is at right angles to the extrusion. Default is xy. Allowed values are:

 

xy

zx

yz

 

[Example:

 

<o:extrusion on="true" plane="yz"

backdepth="100pt">

</o:extrusion>

 

 

end example]

 

The possible values for this attribute are defined by the ST_ExtrusionPlane simple type (§6.2.3.8).

render (Extrusion Render Mode)

Specifies the rendering mode of the extrusion. Default is solid. Allowed values are:

 

Value

Description

solid

Rendering displays a solid shape.

wireframe

Rendering displays a wireframe shape.

boundingcube

Rendering displays the bounding cube that contains the shape.

 

[Example:

 

<o:extrusion on="true" render="wireframe">

</o:extrusion>

 

 

end example]

 

The possible values for this attribute are defined by the ST_ExtrusionRender simple type (§6.2.3.9).

rotationangle (X-Y Rotation Angle)

Specifies the rotation of the object about the x- and y-axes, in degrees. Default is "0,0". Positive angles are measured clockwise around the axis (as if viewing from the positive axis).

 

The rotation of the object is defined by a rotation angle about the y-axis followed by the rotation angle about the x-axis. The z-axis angle is controlled by the value of the CSS style attribute's rotation property.

 

[Example:

 

<o:extrusion on="t" lockrotationcenter="true"

rotationangle="10,20">

</o:extrusion>

 

 

end example]

 

The possible values for this attribute are defined by the XML Schema string datatype.

rotationcenter (Rotation Center)

Specifies the center of rotation for a shape if autorotationcenter is false. The offset of the rotation is specified in terms of fractions of the shape's size. Default is "0,0,0".

 

The position "0,0,0" is at the center of the shape. Positive numbers are to the right, down and toward the viewer, respectively.

 

The possible values for this attribute are defined by the XML Schema string datatype.

shininess (Shininess)

Specifies the concentration of the reflected light on an extrusion surface. Default is 5. The range of values should be constrained to 0-10. Reflection intensity typically grows exponentially with the shininess value.

 

High values (8-10) approximate the shininess of a mirror and low values (2-3) approximate a speckled effect. Reflections do not mirror other objects; only pinpoint light sources are reflected.

 

The possible values for this attribute are defined by the XML Schema float datatype.

skewamt (Extrusion Skew)

Specifies the amount of skew, or length, of a parallel extrusion. Default is 50%. Applies only if the extrusion type is parallel. Note that this attribute and backdepth interact to create the actual extrusion length. Valid values range from 0 (0%) to 1 (100%).

 

[Example:

 

<o:extrusion on="true" skewamt="100%">

</o:extrusion>

 

 

end example]

 

The possible values for this attribute are defined by the XML Schema string datatype.

skewangle (Extrusion Skew Angle)

Specifies the angle of the skew of a parallel extrusion. Default is 225 degrees. Angles are measured in degrees, counterclockwise from the negative x-axis. Applies only if the extrusion type is parallel.

 

[Example:

 

<o:extrusion on="true" skewangle="25">

</o:extrusion>

 

 

end example]

 

The possible values for this attribute are defined by the XML Schema float datatype.

specularity (Specularity)

Specifies the specularity of an extruded shape, defined as the ratio of incident light to specularly reflected light. Default is 0. Normal values range from 0 to 1. This numeric value may also be specified in 1/65536-ths if a trailing "f" is supplied (as "f" indicates the value is a fraction). For example, a value of "52429f" represents 52429/65536 or 0.8.

 

Note that specularity and diffusity should be considered together as it is possible, though physically incorrect, to define more reflected light than incident light. This is the case if the amount of specularly reflected light and diffusely reflected light add up to more than the amount of incident light.

 

[Example: The secondary light source is turned off so only the primary has an effect. Although the effect is subtle, the first cylinder has a sharper specular reflection on its edge:

 

<o:extrusion on="true" specularity="1"

lightposition="10000,-10000,10000"

lightlevel2="0">

</o:extrusion>

 

specularity="1"

specularity="0"

 

end example]

 

The possible values for this attribute are defined by the XML Schema string datatype.

type (Extrusion Type)

Specifies the way that the shape is extruded. Default is parallel. Allowed values are:

 

Value

Description

parallel

Extrusion is rendered so that the center of projection is infinitely far away; that is, the extrusion lines do not converge (unlike perspective projections).

perspective

Extrusion is rendered to a center of projection, which is the same as the vanishing point for unrotated objects.

 

[Example:

 

<o:extrusion on="true" type="parallel"

backdepth="100pt">

</o:extrusion>

 

type="parallel"

type="perspective"

 

end example]

 

The possible values for this attribute are defined by the ST_ExtrusionType simple type (§6.2.3.10).

viewpoint (Extrusion Viewpoint)

Specifies the viewpoint of the observer in EMUs. This is effectively the end of a vector extending from the viewpointorigin.

 

The position "0,0,0" is at the center of the shape. Positive numbers are to the right, down and toward the viewer, respectively.

 

[Example:

 

<o:extrusion on="true" type="perspective"

viewpoint="500000,-100000,100000">

</o:extrusion>

 

 

end example]

 

The possible values for this attribute are defined by the XML Schema string datatype.

viewpointorigin (Extrusion Viewpoint Origin)

Specifies the origin of the viewpoint vector for perspective extrusions. This is the origin of the vector whose opposite end is given by the viewpoint attribute. This origin is always within the bounding box of the shape. Default is "0.5,-0.5".

 

The viewpoint is specified in terms of the x and y values of the original shape. The x and y values range from 0.5 to -0.5 (50% to -50% of the shape's coordinate origin). Larger numbers move the viewpoint outside the bounding box.

 

[Example:

 

<o:extrusion on="true" type="perspective"

viewpoint="500000,-100000,100000"

viewpointorigin="0,1">

</o:extrusion>

 

 

end example]

 

The possible values for this attribute are defined by the XML Schema string datatype.

The following XML Schema fragment defines the contents of this element:

<complexType name="CT_Extrusion">

   <attributeGroup ref="v:AG_Ext"/>

   <attribute name="on" type="ST_TrueFalse" use="optional"/>

   <attribute name="type" type="ST_ExtrusionType" default="parallel" use="optional"/>

   <attribute name="render" type="ST_ExtrusionRender" default="solid" use="optional"/>

   <attribute name="viewpointorigin" type="xsd:string" use="optional"/>

   <attribute name="viewpoint" type="xsd:string" use="optional"/>

   <attribute name="plane" type="ST_ExtrusionPlane" default="XY" use="optional"/>

   <attribute name="skewangle" type="xsd:float" use="optional"/>

   <attribute name="skewamt" type="xsd:string" use="optional"/>

   <attribute name="foredepth" type="xsd:string" use="optional"/>

   <attribute name="backdepth" type="xsd:string" use="optional"/>

   <attribute name="orientation" type="xsd:string" use="optional"/>

   <attribute name="orientationangle" type="xsd:float" use="optional"/>

   <attribute name="lockrotationcenter" type="ST_TrueFalse" use="optional"/>

   <attribute name="autorotationcenter" type="ST_TrueFalse" use="optional"/>

   <attribute name="rotationcenter" type="xsd:string" use="optional"/>

   <attribute name="rotationangle" type="xsd:string" use="optional"/>

   <attribute name="colormode" type="ST_ColorMode" use="optional"/>

   <attribute name="color" type="ST_ColorType" use="optional"/>

   <attribute name="shininess" type="xsd:float" use="optional"/>

   <attribute name="specularity" type="xsd:string" use="optional"/>

   <attribute name="diffusity" type="xsd:string" use="optional"/>

   <attribute name="metal" type="ST_TrueFalse" use="optional"/>

   <attribute name="edge" type="xsd:string" use="optional"/>

   <attribute name="facet" type="xsd:string" use="optional"/>

   <attribute name="lightface" type="ST_TrueFalse" use="optional"/>

   <attribute name="brightness" type="xsd:string" use="optional"/>

   <attribute name="lightposition" type="xsd:string" use="optional"/>

   <attribute name="lightlevel" type="xsd:string" use="optional"/>

   <attribute name="lightharsh" type="ST_TrueFalse" use="optional"/>

   <attribute name="lightposition2" type="xsd:string" use="optional"/>

   <attribute name="lightlevel2" type="xsd:string" use="optional"/>

   <attribute name="lightharsh2" type="ST_TrueFalse" use="optional"/>

</complexType>