我的编程空间,编程开发者的网络收藏夹
学习永远不晚

为什么要重写Flex组件

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

为什么要重写Flex组件

这篇文章主要为大家展示了“为什么要重写Flex组件”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“为什么要重写Flex组件”这篇文章吧。

重写Flex组件

一、为什么要重写Flex组件

在Flex已有Flex组件无法满足业务需求,或是需要更改其可视化外观等特性时,直接进行继承扩展。举例,继承BUTTONFlex组件的长文本却不自动换行的自定义控件。

为了模块化设计或进一步重用,需要对Flex组件进行组合。比如一个包括TEXTAREA,BUTTON的复合控件。

二、重写Flex组件需要经常换位思考的三个角色

作为重写Flex组件的使用者,有哪些需求。比如需要在MXML标签和AS代码中暴露哪些属性及对应默认值、事件和事件的处理逻辑。

重写Flex组件一般需要使用Flex原有Flex组件,要站在原有开发者的角度了解设计规则。

作为重写Flex组件的设计者,在满足需求的情况下尽量做到可复用、低耦合易扩展等设计原则,让新Flex组件像Flex原Flex组件一样好用。

三、重写Flex组件AS方式和MXML方式的采用规则

MXML文件和AS文件***都会被编译成AS类,只不过MXML编译速度稍慢一些

如果MXML和AS都能完成的一个简单Flex组件,MXML更容易被创建和控制布局

当要覆盖Flex组件的某些方法时只能用AS方式

创建一个直接继承UIComponent的子类时只能用AS

创建非可视化Flex组件比如Formatter、validator、Effect……时,只能用AS

要为Flex组件添加日志功能时,只能用AS.

四、AS方式重写Flex组件常规步骤

如果有必要,为Flex组件创建所有基于标记(tag-based)的皮肤(skins)

创建ActionScript类文件

1)从一个基类扩展,比如UIComponent或者其他的Flex组件类

2)指定使用者能够通过MXML标记进行设置的属性

3)嵌入(Embed)所有的图片和皮肤文件,文件大小尽可能小

4)实现构造器,可以设置属性和样式的缺省值,或者初始化数据结构,比如数组

5)根据需要,确定是否覆盖以下五个方法:

(a)UIComponent.createChildren()方法,创建Flex组件的子Flex组件

(b)UIComponent.commitProperties()方法,提交Flex组件所有的属性变化,设置measure()方法可能使用的属性值。绝大多数情况下,都是对影响Flex组件如何在屏幕上显示的属性使用这个方法

(c)UIComponent.measure()方法,设置Flex组件的缺省size(measuredWidth、measuredHeight)和缺省的最小size(measuredMinWidth、measuredMinHeight)

(d)UIComponent.layoutChrome()方法,用于定义容器的边框区域和确定边框区域的位置,以及确定要在边框区域中显示的附加元素。例如,Panel容器使用layoutChrome()方法定义panel容器的title区域,这个区域用来包含title文本和close按钮。

通常,使用RectangularBorder类来定义容器区域的边框,而不是用图片资源去包围Flex组件。比如创建一个RectangularBorder对象,然后在重载的createChildren()方法中,将其作为一个内容子控件添加到Flex组件中,再用updateDisplayList()方法来确定其位置。

将容器的内容区域和容器边框区域分开处理的主要原因是为了应对Container.autoLayout

属性被设置为false的这种情况。当autoLayout(自动布局)属性使用默认值true时,只要容器子控件的大小和位置发生变化,容器及子控件就会进行度量和布局。而当其为false时,度量和布局只在子控件被添加或移出容器时才执行。分开处理让Flex在这两种情况下都执行layoutChrome(),从而在autoLayout属性为false的情况下,容器仍能够更新它的边框区域。

(e)UIComponent.updateDisplayList()方法,根据以前所设置的属性和样式来确定Flex组件的子Flex组件在屏幕上的大小(size)及位置(position),并且画出Flex组件所使用的所有皮肤(skins)及图形化元素。Flex组件的父容器负责确定Flex组件本身大小(size)。

要在updateDisplayList()方法中确定一个Flex组件的大小,当子Flex组件是UICOMPONENT时使用setActualSize()方法,而不是UICOMPONENT则使用与Flex组件大小相关的属性width和height。要确定Flex组件的位置,当子Flex组件是UICOMPONENT时使用move()方法,而不是UICOMPONENT则使用x和y属性。一个区别就是move()方法不仅改变了Flex组件位置,而且在调用这个方法之后立即分发了一个move事件,设置x和y属性也更改Flex组件的位置,但却在下一个屏幕更新事件中才会分发move事件。

Flex组件支持很多类型的可视元素,比如皮肤,样式和边框。在updateDisplayList()方法中,可以添加这些可视元素,并对它们进行一些控制。由于UICOMPONENT继承自SPRITE,所以可以使用Graphics对象中的Flash绘画APIs进行绘制图形,比如使用Graphics类去画边框水平线以及其他图形元素:

graphics.lineStyle(1,0x000000,1.0);   graphics.drawRect(0,0,unscaledWidth,unscaledHeight);

updateDisplayList()方法形式如下:

protectedfunctionupdateDisplayList(unscaledWidth:Number,unscaledHeight:Number):void()   {   }

以像素为单位的Flex组件坐标系中,unscaledWidth和unscaledHeight是由父容器确定的Flex组件大小,而不管Flex组件的scaleX,scaleY是多少。缩放发生在FlashPlayer或者AIR中,发生时机是在updateDisplayList()执行之后。比如一个Flex组件的unscaledHeight属性是100,而其scaleY属性是2.0,那么它在FlashPlayer或AIR中出现的高度为200像素。

需要注意的是,定义新Flex组件时不一定要重载所有的五个方法,只需重载实现Flex组件功能所必需的即可。比如实现一个自定义的Button控件,该控件使用新的机制来定义缺省大小(size)。在这种情况下,只需要重载measure()方法。或者,要实现VBox容器的一个新子类。新子类利用VBox类已有的所有有关设定大小(sizing)的逻辑,但是变更了VBox类的布局逻辑以实现从底部到顶部的方式来布局容器中的子控件,而不是自顶向下的布局。在这种情况下,只需要重载updateDisplayList()方法。

(6)增加属性(properties),方法(methods),样式(styles),事件(events)以及元数据

以ActionScript文件或者SWC文件的形式部署Flex组件

以上是“为什么要重写Flex组件”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

为什么要重写Flex组件

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

为什么要重写Flex组件

这篇文章主要为大家展示了“为什么要重写Flex组件”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“为什么要重写Flex组件”这篇文章吧。重写Flex组件一、为什么要重写Flex组件1、在Flex已
2023-06-17

如何使用AS方式重写Flex组件

小编给大家分享一下如何使用AS方式重写Flex组件,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!AS方式重写Flex组件常规步骤1、如果有必要,为Flex组件创建所有基于标记(tag-based)的皮肤(skins)2、创
2023-06-17

为什么要Flex模块化

这篇文章主要介绍了为什么要Flex模块化,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1:为什么要Flex模块化;Flex模块化提供了分离应用程序代码到不同的swf文件上以便
2023-06-17

Java中为什么重写equals()也需要重写hashCode方法

这篇文章主要介绍了Java中为什么重写equals()也需要重写hashCode(),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-17

为什么文件名要小写?

上周, 《中文技术文档写作规范》 加入了文件的命名规则。 "文件名建议只使用小写字母,不使用大写字母。" "为了醒目,某些说明文件的文件名,可以使用大写字母,比如README、LICENSE。" 网友看见了,就 提问 为什么文件名要小写?
2022-06-03

为什么要使用Flex模块化

这篇文章将为大家详细讲解有关为什么要使用Flex模块化,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1.为什么要Flex模块化Flex模块化提供了分离应用程序代码到不同的swf文件上以便减少下载时间和文件
2023-06-17

html5为什么只需要写

HTML5是一种新一代的Web语言,相较于以往的HTML语言,它具有更加强大的功能和更加便捷的设计方式。HTML5可以轻松创建各种类型和大小的Web应用程序,包括视频和音频播放、动画和游戏等。但是,与传统的HTML语言相比,HTML5的一个显著优点是只需要写一个文件来完成网页的构建。为什么HTML5只需要一个文件?在传统的HTML语言中,一般需要编写多个文件才能构建一个完整的网
2023-05-14

为什么要写Bash脚本

这篇文章主要介绍为什么要写Bash脚本,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!为什么要写Bash脚本其实关于Bash脚本最好的解释如下:The opposite of "its like riding a bi
2023-06-09

为什么修改equals方法时还要重写hashcode方法

这篇文章主要介绍为什么修改equals方法时还要重写hashcode方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!为何修改equals方法时还要重写hashcode方法虽然在实际开发中,我们已经使用到散列集合(如
2023-06-15

vue组件要什么条件

Vue是一个流行的JavaScript框架,设计用于开发交互性良好的网络应用程序。Vue的核心是组件化架构,这种架构允许我们将应用程序拆分为小型、可重用的组件。在这篇文章中,我们将探讨Vue组件的条件。作为Vue开发者,你需要了解这些条件,以确保你的组件能够正常地工作并展现出最佳效果。1. 模板Vue组件的第一个条件是一个模板或标记,这个模板或标记定义了Vue组件的外观和行为。
2023-05-14

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录