将Flex 3应用程序移植到Flex 4.5中 第3部分:Spark组件及皮肤制作简介 (一)

本系列主要讲述将Flex 开发者中心提供的Flex3仪表盘显示应用程序导入Flash Builder4.5,然后再将该应用程序移植到Flex 4.5中以充分利用Flex 4.5Spark结构和组件的优势。本系列分成四部分,本文为其中的第三部分。

虽然Flex 4.5的主要特征之一是支持在Flex创立移动应用程序,但本系列文章内容不涵盖将仪表盘应用程序转换为移动应用程序。关于创立移动仪表盘应用程序的内容将在另一系列的文章中阐述。

本系列第一部分讲述如何将Flex 3仪表盘导入Flash Builder 4.5中,作出相应的改变使之转化并正常运行。第二部分阐述如何通过改变应用程序背景及TabBar控件将仪表盘密码移植到Flex 4.5中,从而使用新的Flex 4.5 Spark组件的功能。第三部分(本文)继续讲述移植的过程及改变程序使得ViewStack容器能正常使用新的Flex 4.5 Spark NavigatorContent容器。

如果您完成第一二部分的步骤有一会儿了,您或许会迫不及待地一览关于仪表盘应用程序介绍、转换以及接下来的步骤的一些要点等相关的文章的开头部分了。

本文的样本文件仪表盘-第三部分-开篇,fxp可供读者作为学习后续步骤的起点。Flex工程文件包括了该系列文章第二部分所有的步骤。

使ViewStack容器使用NavigatorContent

Flex 4.5本身不具备Spark导航容器,所以仍需要使用MX ViewStack。并且不能直接用Spark容器打开ViewStack的视图,而要在使用ViewStack视图之前用Spark NavigatorContent容器或者在MX容器里打包Spark容器。

Flex 3仪表盘应用程序使用的是MX Canvas容器来打开ViewStack视图,需在main mxml下的onResultHttpService()功能菜单下进行初始化,这样就能把NavigatorContent容器代替Canvas容器。

在main mxml文件中修改onResultHttpService()功能

1.        打开main mxml

2.        在onResultHttpService()功能菜单中输入以下命令

var canvas:Canvas = new Canvas();

3.        用以下命令代替上述命令:

var canvas:NavigatorContent = new NavigatorContent();

虽然当前使用的是NavigatorContent容器,但成员名称仍保持canvas不变,以免导致成员名称使用上的细微变化。

4.        在main mxml顶上导入以下命令:

import spark.components.NavigatorContent;

5.        删除以下命令,由于密码不再属于Canvas类

import mx.containers.Canvas;

6. 返回onResultHttpService(),删除以下两行命令。因为如果不刻意添加的话,Flex 4.5 Spark容器是不具备滚动条组件的,所以不需要以下两行:

canvas.horizontalScrollPolicy = "off";

canvas.verticalScrollPolicy = "off";

7.        保存编程数据

修改Pod布局类管理器使用NavigatorContent

因为当前用于视图的是NavigatorContent容器,所以当您创建项目时main mxml会出现报错,这是因为Pod布局管理器仍预期Canvas容器打开。为解决这个问题,我们需要做些修改,将NavigatorContent容器取代Canvas容器。

1.        打开文件src\com.esria.samples.dashboard\managers\PodLayoutManager.as.

2.        输入以下命令:

private var _container:Canvas;

3. 用以下命令代替:

private var _container:NavigatorContent;

4.        在Pod布局管理器顶端导入以下命令:

import spark.components.NavigatorContent;

5. 删除以下命令,由于密码不再属于Canvas类

import mx.containers.Canvas;

6. 修改赋值和取值功能以使用NavigatorContent容器

应做些修改避免运行错误,因为NavigatorContent容器和Canvas容器API(应用程序编程接口)方式和变量上存在着差异(详见表一)。

表一:NavigatorContent容器和Canvas容器应用程序编程接口相关差异

Canvas

NavigatorContent

描述

addChild()

addElement()

在容器中添加项目

setChildIndex()

setElementIndex()

在容器中设置项目索引

numChildren

numElements

容器中项目数量

7.在PodLayoutManager.as中将container.addChild(pod)改为container.addElement(pod)

7.        将container.addChild(dragHighlight)改成container.addElement(dragHighlight)

8.        将container.setChildIndex(pod,container.numChildren - 1)改成container.setElementIndex(pod,container.numElements - 1) .

9.        将container.setChildIndex(dragHighlight,i)改成container.setElementIndex(dragHighlight, i) .

10.    保存修改

将Pod类修改成使用NavigatorContent

应做些适当的修改,因为NavigatorContent和Canvas两类容器在应用程序编程接口上存在着差异。

1.        打开src\com.esria.samples.dashboard\view\Pod.as输入onMouseDown()功能。

2.        将parent.setChildIndex(this,parent.numChildren - 1)改成Group(parent).setElementIndex(this,Group(parent).numElements - 1)

需要提醒的是,应该铸件Group父类而不是NavigatorContent,因为Pod实际父类是NavigatorContentGroup皮肤部分,同属于Group。

3.        在Pod顶端导入以下命令:

 importspark.components.Group;      

4.        保存修改,建立程序

这个时候应该不存在任何错误了,可以安装仪表盘应用程序,不会出现程序编译错误和运行错误。

注意,如果点击Pod中的ComboBox,其可能会打开又迅速关闭,此类问题可以通过使用Flex 4.5 Spark ComboBox控件来解决,其产生的原因是因为MouseDown() 事件处理器中的ChartContent和FormContent组件正在处理mouseDown事件,从而阻止了ComboBox接收该事件。

使用Pod类管理器以延展Spark组件面板

当前使用Spark NavigatorContent 打开的ViewStack页面包含了仪表盘应用程序中真正的pod管理器。本小节介绍如何修改Pod类管理器以延展Spark组件面板,从而取代MX面板容器,使之延伸使用在Flex3仪表盘应用程序中。

1.        打开Pod.as.

2.        导入Spark面板取代MX面板,用Spark组件面板取代mx容器面板

由于MX和Spark面板运行时的差异,以上操作将导致一系列错误(见图一),这些错误将在后续的步骤中得以解决。


图一:使用Pod类管理器以延展Spark组件面板出现的错误

大多数问题的产生是因为Spark面板无法执行titleBar属性,因此需要使用自定义皮肤来运行标题栏区域。Spark面板同时也无法执行titleTextField属性,同样需要自定义皮肤来是实现。

与rawChildren属性相关的错误是由Spark组件架构变化而引起的。MX面板所承接的MX类容器具备rawChildren属性,使其能链接诸如停靠容器等容器浏览器,此功能可通过Pod类管理器使用自定义皮肤来实现。

3. 在Pod构造器功能中删除以下命令,因为如果不刻意添加的话,Flex 4.5Spark容器是不具备滚动条组件的,所以不需要以下命令:

horizontalScrollPolicy = "off"; 



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源
大学生在线租房平台管理系统按照操作主体分为管理员和用户。管理员的功能包括报修管理、报修评价管理、字典管理、房东管理、房屋管理、房屋收藏管理、房屋留言管理、房屋租赁管理、租房论坛管理、公告信息管理、留言板管理、用户管理、管理员管理。用户的功能等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 大学生在线租房平台管理系统可以提高大学生在线租房平台信息管理问题的解决效率,优化大学生在线租房平台信息处理流程,保证大学生在线租房平台信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理公告,管理大学生在线租房平台信息,包括房屋管理,培训管理,报修管理,薪资管理等,可以管理公告。 房屋管理界面,管理员在房屋管理界面可以对界面显示,可以对房屋信息的房屋状态进行查看,可以添加新的房屋信息等。报修管理界面,管理员在报修管理界面查看报修种类信息,报修描述信息,新增报修信息等。公告管理界面,管理员在公告管理界面新增公告,可以删除公告。公告类型管理界面,管理员在公告类型管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息。
基于hal库的OLED显示屏驱动C语言实现源码.zip 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我! 基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值