May 30

原文地址http://blog.csdn.net/lentonnet/archive/2007/11/07/1872122.aspx

首先介绍一下SystemManager. SystemManager是Flex应用的主控者, 它控制着应用窗口, Application实例, 弹出窗口, cursors, 并管理着ApplicationDomain中的类. SystemManager是FlashPlayer实例化的第一个类, 它存储了主应用窗口的大小和位置信息, 保存其子组件比如:浮动弹出窗口和模态窗口的痕迹. 通过SystemManager可以获得内嵌字体,样式和document对象.
自定义的可视化组件(UIComponent的子类)只有在调用过addChild()后, 才会有一个SystemManager赋给他们, 之前是Null. 所以在自定义可视化组件的构造函数中不要使用SystemManager.

通常, Application对象创建时, 发生如下事件:
1. 实例化Application对象
2. 初始化Application.systemManager
3. Application在初始化过程之前, 派发预初始化事件.
4. 调用createChild(). 此时, 所有应用组件被创建, 所有组件的createChild()被调用.
5. Application派发初始化事件, 表明所有的组件初始化完毕.
6. 派发creationComplete事件
7. Application对象添加到显示列表中
8. 派发applicationComplete事件

大多数情况下, 我们使用<mx:Application>来创建application对象, 但如果使用ActionScript来创建的话, 那么建议不要在application的构造函数中创建组件, 推荐在crateChildren函数中, 主要是从性能方面考虑.

Flash包含的是一个时间线上的多个帧, 而Flex的SWF只包含2个帧. SystemManager, Preloader, DownloadProgressBar和少量工具类都在第一帧, 剩下的包括应用代码/ 内嵌资源全都在第二帧中. 当Flash Player下载下载SWF时, 只要接收到第一帧内足够的数据, 就会实例化SystemManager, 由它来创建Preloader, 然后创建DownloadProgressBar, 这两个对象会察看剩余字节的传输过程. 当第一帧的所有字节传输完毕后, SystemManager发送enterFrame到第二帧, 然后是其他事件. 最后Application对象派发applicationComplete事件. 

May 30

转载于http://blog.csdn.net/lentonnet/archive/2007/11/06/1869625.aspx

通常情况下,你可以从服务器上为tree控件取得XML数据 ,你也可以在<mx:Tree>Tag里直接定义格式良好的XML数据。

你可以使用<mx:XML>或者<mx:XMLList>Tag在mxml里定义XML数据。

你可以将XML object直接作为一个层级数据控件的dataProvider,however,if the object changes dynamically,你应该做如下处理:
1,将XML或者XMLList objects转换为XMLListCollection;
2,通过修改XMLListCollection数据来更新原始的XML数据;     更多……
Continue reading »

May 30

如果在AS代码写,可以如下:
var service:WebService=new WebService();
service.wsdl=”http://feeds.adobe.com/webservices/mxna2.cfc?wsdl“;
service.useProxy=false;
service.loadWSDL();
service.getMostPopularPosts.addEventListener(ResultEvent.RESULT,onRes);
service.getMostPopularPosts(8,8);

function onRes(e:ResultEvent):void{
    trace(e.result);
    dgTopPosts.dataProvider=e.result;
}

用flex 组件,代码如下:         更多……

Continue reading »

May 22

通常即时通信工具把消息放在一个消息框里并把最后收到的消息放在消息框的底部。
代码:
myTextArea.htmlText += “text”;
myTextArea.verticalScrollPosition = myTextArea.maxVerticalScrollPosition;

但这段代码执行的时候却没有flash(as2)中的效果。这个问题是因为Action Script是异步的方式执行的,当第一句执行后界面还没有来得及更新第二句就紧接着执行了。解决问题的办法就是在更新完成后再执行滚动操作。
myTextArea.addEventListener(FlexEvent.UPDATE_COMPLETE, onUpdateComplete);
private function onUpdateComplete(event:FlexEvent):void {
     myTextArea.verticalScrollPosition = txtMessages.maxVerticalScrollPosition;
}

May 21

function recFLV(){
    var ns:NetStream = new NetStream(nc);
    var cam:Camera =  Camera.getCamera();
    ns.attachCamera(cam);
    ns.publish (”name”,”record”);
}
这样的代码,不会在fms服务器上产生flv流.
而改成如下便可以.

var ns:NetStream;
function recFLV(){
    ns= new NetStream(nc);
    var cam:Camera =  Camera.getCamera();
    ns.attachCamera(cam);
    ns.publish (”name”,”record”);
}
原因是第一种写法中,NetStream对象是函数局部的,只要执行完recFLV函数最后一句话后,这个实例就会被清空,就没有连接了.

May 20

var xml:XML=< root>
< node id="1"> aa < /node>
< node id="2"> bb < /node>
< /root>
var node1:XML=xml.node[0];
var node2:XML=xml.node.(@id==”1″);
那么node1是引用xml的第一个节点,而node2则是第一个节点的副本.
所以,如果我们想要通过一个变量更改原来的XML的属性或者值,只能node1的方式.
如果不想更改原有的xml,则通过第二种方式.

May 15

懒的翻译,直接拷贝下来吧.
The Tree uses heirarchical data. That is, data that has levels: nodes that are branches and leaves. The DataGrid, by contrast, presents non-heirarchical data as does the List control.

XMLListCollection is an excellent dataProvider for the Tree and is the most commonly used class for this purpose. You can also use ArrayCollection and I’ll go into more detail on that later in this article.      更多……

Continue reading »

May 13

TabNavigator有个方法
getTabAt(index:int):Button
Returns the tab of the navigator’s TabBar control at the specified index.”

方法返回的是Button,所以只需要在这个编辑这个Button的样式就可以了.
例如:
var btn:Button=this.myTn.getTabAt(0);
btn.setStyle(”fillColors”,[0xFFFF00, 0xFFFF00]);
btn.setStyle(”fillAlphas”,[1, 1]);
btn.width=180;

最后效果如图:暂时未传.

May 13

转载过来的.没仔细找原始的地方.

在当前IE6 IE7 FifeFox三分天下的情况下,浏览器兼容性问题成为网页设计者需要考虑的问题.   
区别不同浏览器的CSS hack写法:
区别IE6与FF:
        background:orange;*background:blue;
区别IE6与IE7:
        background:green !important;background:blue;
区别IE7与FF:
        background:orange; *background:green;
区别FF,IE7,IE6:
        background:orange;*background:green !important;*background:blue;

注:IE都能识别*;标准浏览器(如FF)不能识别*;

IE6能识别*,但不能识别 !important,
IE7能识别*,也能识别!important;
FF不能识别*,但能识别!important;

  IE6 IE7 FF
* ×
!important ×

——————————————————
另外再补充一个,下划线”_”,
IE6支持下划线,IE7和firefox均不支持下划线。

于是大家还可以这样来区分IE6,IE7,firefox
: background:orange;*background:green;_background:blue;         更多……

Continue reading »

May 12

js代码如下:
<script language=”javascript”>
var obj;
function onover(target){
   target.style.backgroundColor=”#FF0000″;
}
function onout(target){
   target.style.backgroundColor=”#FFFFFF”;
}
function ondown(target){
   if(obj!=null){
       obj.style.backgroundColor=”#FFFFFF”;
       obj.onmouseover=obj.over;
       obj.onmouseout=obj.out;
       obj.onclick=obj.down;
   }
   target.style.backgroundColor=”#0000FF”;
   target.over=target.onmouseover;
   target.out=target.onmouseout;
   target.down=target.onclick;
   target.onmouseover=null;
   target.onmouseout=null;
   target.onclick=null;
   obj=target;
}
</script>
网页代码:          更多……

Continue reading »