`
qujianfeng
  • 浏览: 78817 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

Flex中给对象加阴影的方法

    博客分类:
  • Flex
 
阅读更多

Flex中给对象加阴影的方法

1、 BorderContainerPanel等容器自带阴影

BorderContainer或者Panel等容器自带了阴影,这通过dropShadowVisible样式设定,此样式如果设为true,则显示阴影。BorderContainerdropShadowVisible默认为falsePanel 的默认为true

Panel的阴影效果如下:

2、 RectangularDropShadow专用来为矩形对象加阴影,如果对象是矩形,使用此类效率高

可以在程序中直接使用RectangularDropShadow为对象加阴影,但仅适用于对象外形是矩形的条件下。示例如下:

<s:Group x="302" y="62" width="217" height="200">

       <s:RectangularDropShadow blurX="20" blurY="20"

            alpha="0.32" distance="11"

            blRadius="5" brRadius="5"

           angle="90" color="#000000" left="0" top="0" right="0"

             bottom="0"/>

</s:Group>

效果如下:

 

3、 SkinnableContainer可以通过皮肤加阴影

可以为SkinnableContainer建一个皮肤类,在类中设置阴影,代码如下:

<s:SkinnableContainer x="575" y="62" width="200" height="200"

                       skinClass="MySkinableContainerWithShadowSkin">

</s:SkinnableContainer>

皮肤中的阴影程序为:

<!-- 通过RectangularDropShadow加阴影 -->

<s:RectangularDropShadow id="dropShadow" blurX="20" blurY="20" alpha="0.32" distance="11"

       blRadius="5" brRadius="5"

       angle="90" color="#000000" left="0" top="0" right="0"

         bottom="0"/>

这样的好处是阴影将不响应该对象的鼠标事件。

4、 如果对象外形不是矩形,就要使用DropShadowFilter滤镜

示例:

首先是滤镜的定义:

<fx:Declarations>

       <!-- 将非可视元素(例如服务、值对象)放在此处 -->

       <fx:Array id="myFilters">

           <s:DropShadowFilter alpha="0.32"

                            distance="11"

                            blurX="20" blurY="20"

                            angle="90" color="#000000"

                            >

           </s:DropShadowFilter>

       </fx:Array>

</fx:Declarations>

<s:Group x="297" y="339">

<!--下面是要显示阴影的组件:à

       <s:Path data="M 195.307 95.719 C 195.307 103.702 206.101 113.422 204.132 120.785 C 202.096 128.404 204.87 141.279 201.011 147.949 C 197.097 154.715 171.372 145.538 165.881 151.029 C 160.39 156.52 158.618 163.32 151.852 167.234 C 145.182 171.093 146.125 197.982 138.507 200.019 C 131.145 201.986 118.555 196.832 110.571 196.832 C 102.588 196.832 88.935 205.962 81.572 203.993 C 73.954 201.957 63.453 192.709 56.783 188.851 C 50.017 184.936 47.379 169.893 41.888 164.401 C 36.397 158.911 56.453 135.965 52.538 129.199 C 48.679 122.529 40.694 122.617 38.658 114.999 C 36.69 107.636 0 103.702 0 95.719 C 0 87.736 10.102 76.695 12.07 69.332 C 14.106 61.714 27.476 56.64 31.334 49.97 C 35.249 43.204 53.419 49.549 58.91 44.058 C 64.401 38.567 53.156 11.925 59.923 8.01 C 66.593 4.151 77.68 3.416 85.298 1.38 C 92.661 -0.588 102.588 0.133 110.571 0.133 C 118.555 0.133 123.642 17.522 131.005 19.489 C 138.624 21.526 143.709 22.891 150.379 26.751 C 157.145 30.665 166.349 28.961 171.839 34.452 C 177.331 39.943 169.701 52.574 173.615 59.34 C 177.475 66.01 187.039 67.06 189.075 74.678 C 191.044 82.041 195.307 87.736 195.307 95.719 Z"

              winding="nonZero" x="0.929" y="0.781"

              filters="{myFilters}" width="175.40123" height="172.30193">

           <s:stroke>

              <s:SolidColorStroke caps="none" color="#5380D0" joints="miter" miterLimit="4" weight="1"/>

           </s:stroke>

           <s:fill>

              <s:SolidColor color="#FFFFFF"/>

           </s:fill>

       </s:Path>

</s:Group>

此代码通过Path定义了一个不规则区域,通过DropShadowFilter滤镜添加了阴影。

效果如下:

 

总结:

总结起来就是两个东西,一个是RectangularDropShadow,一个是DropShadowFilterRectangularDropShadow为矩形对象添加阴影,DropShadowFilter可以为任意形状对象添加阴影。

BorderContainerPanel等容器使用的就是RectangularDropShadow

 

屈剑峰

20111124

  • 大小: 2.6 KB
  • 大小: 3.1 KB
  • 大小: 8.2 KB
分享到:
评论

相关推荐

    Flex中的各种滤镜

    在Flex这个强大的基于ActionScript 3.0的开源框架中,滤镜是为图形和文本添加视觉效果的重要工具。滤镜允许开发者创建出各种各样的视觉特效,如模糊、灰度、铅笔画等,极大地丰富了用户界面的视觉表现力。让我们深入...

    flex的生成工具套

    在Flex 3中,样式系统允许开发者自定义组件的外观,包括颜色、字体、边框、阴影等。通过这个工具,开发者可以直观地看到不同样式属性如何影响组件的显示,从而快速理解和应用样式。这对于创建符合品牌要求或个性化...

    Flex模拟Mac特效

    在本例中,我们关注的是如何使用Flex来模拟Mac操作系统的某些特效,特别是弹出框效果。 "Flex模拟Mac特效"这一主题主要涉及以下知识点: 1. Flex组件库:Flex提供了一系列预定义的UI组件,如Button、Label、...

    flex特效编辑器 开发flex游戏的利器

    2. **动画编辑**:允许开发者创建和编辑角色或对象的动作序列,使游戏中的角色和场景更加生动。 3. **光照和阴影**:提供对光照效果的控制,让游戏环境更具立体感和真实感。 4. **预览和调试**:在编辑过程中实时...

    Flex中使用滤镜

    在Flex开发中,滤镜(Filters)是一种强大的视觉效果工具,可以用来增强或者改变舞台上的显示对象的外观。本文将深入探讨如何在Flex中使用滤镜,并基于提供的两个文件名——"magnify.pbj"和"magnify.pbk",我们将...

    Flex 逼真海洋效果

    在Flex中实现逼真的海洋效果是一项挑战,但通过巧妙的图形处理和动画技术,可以创建出令人惊叹的视觉体验。本教程将深入探讨如何在Flex项目中创建一个生动、真实的海洋效果。 首先,我们需要了解Flex的基本组件和...

    flex圆形图表展示源码

    在压缩包文件名"DataConvertACToBubbleSeries"中,"ACToBubbleSeries"可能指的是将ActionScript对象转换为气泡系列图表的过程。气泡系列是图表的一种,它在二维平面上用不同大小的圆点表示数据,圆点的大小通常代表...

    flex 图片操作

    在Flex中,可以利用`rotate`属性或`transform`对象实现图片的旋转。`rotate`属性直接设置旋转角度,而`transform`对象提供了更复杂的变换功能,如矩阵变换。以下代码展示了如何使用`rotate`属性旋转图片: ```xml ...

    Flex仿苹果风格的滑块开关控件

    本篇文章将深入探讨如何在Flex中实现这样一个功能丰富的滑块控件,并分享一个实际的范例。 首先,我们要了解Flex的基础。Flex是Adobe开发的一个开源框架,主要用于构建富互联网应用程序(RIA)。它基于ActionScript...

    flex3 画相位图

    为了在Flex中绘制相位图,我们可以利用`mx.graphics`包中的`Graphics`类,它提供了绘制线条、曲线、填充等基本图形的方法。我们可以通过以下步骤实现: 1. **创建Flex项目**:启动Flex Builder或使用命令行工具创建...

    Flex 3D圆形隧道效果

    2. **使用Scene3D和ViewPort3D**:为了在Flex中构建3D场景,我们需要使用Scene3D来容纳3D对象,而ViewPort3D则负责将3D场景渲染到2D屏幕上。它们共同构成了3D渲染的基础。 3. **3D对象和转换**:在Flex中,我们使用...

    Flex 图片旋转 缩放 拖动 特效

    在Flex开发中,图片的旋转、缩放和拖动功能是常见的交互效果,尤其是在构建富互联网应用程序(RIA)时。Flex作为一个基于ActionScript 3.0的开源框架,提供了强大的图形处理和用户交互能力,使得实现这些特效成为...

    flex 超炫的3d效果+源码

    在本压缩包中,"超炫的3D效果"指的是使用Flex实现的三维视觉效果,这种效果可以为用户带来更为生动、立体的交互体验。 Flex中的3D效果主要通过Stage3D API来实现。Stage3D是Flash Player和Adobe AIR的一个底层图形...

    flex主题 vista风格 苹果风格11款漂亮主题

    2. **Vista风格**:在Flex中实现Vista风格,可能涉及到使用透明效果、玻璃质感、半透明层以及动态阴影等视觉元素。Vista的 Aero 主题强调平滑的动画过渡和高清晰度的图标,这些可以通过Flex的皮肤和组件库来实现。 ...

    flex as3 air ria 遮罩的使用例子

    在Flex AS3应用程序开发中,遮罩(Masking)是一种重要的图形处理技术,它允许开发者隐藏或显示特定的显示对象区域。遮罩可以用于创建复杂的交互式用户界面元素,如弹出窗口、动画效果和自定义组件。在这个“flex as...

    Demo.rar_3d_flex_flex Graphic._pv3d flex_pv3d fl

    描述中提到“利用PV3D做的flex DEMO 实现了#3D特效”,进一步确认了这个项目是使用Adobe Flex技术和Papervision3D(PV3D)库创建的一个3D效果展示。 Flex是一种基于ActionScript 3.0的开源框架,用于构建富互联网...

    starling-book-soft.zip_flex

    另一种方法是使用Flex的Graphics API,通过绘制额外的形状并调整其透明度和颜色来模拟阴影。 四、项目结构与源码解析 在"starling-book-soft.zip_flex"这个压缩包中,我们可以看到以下关键文件: 1. `....

    flex Papervision 3D 事例

    Flex Papervision 3D 是一个强大的开源框架,用于在Adobe Flex环境中构建三维(3D)图形和应用程序。这个框架允许开发者使用ActionScript 3.0来创建具有复杂3D场景、交互性和动画效果的Web应用程序。在Flex 3.0版本...

    flex主题皮肤源码

    1. **MXML和ActionScript**:Flex中的皮肤通常由MXML(标记语言)和ActionScript(面向对象的脚本语言)编写。MXML用于定义组件结构,而ActionScript则处理逻辑和交互。 2. **Skin Classes**:每个Flex组件都有一个...

    Flex做的按钮3D效果源码

    1. **3D转换(3D Transform)**:在Flex中,我们可以使用`Transform3D`对象来应用3D变换。这包括平移(translate)、旋转(rotate)和缩放(scale)。例如,`Transform3D.tween`方法允许我们平滑地在两个3D位置之间...

Global site tag (gtag.js) - Google Analytics