zoukankan      html  css  js  c++  java
  • Flex RIA的ArcIMS WebGIS之路(五)自定义组件

    WebGIS功能有些啥,与桌面的功能相比WebGIS就简单多了,总的来说就是俩字--好看,图面效果要好,界面要炫,当然也要足够傻瓜。功能嘛,大概就是地图浏览,属性,空间的查询定位,查询结果的统计分析一类的了。WebGIS核心是地图,地图图面怎么才好看,主要就是标注与符号。现在偶们就看看标注,说到标注总的来说就是字体,大小,位置,颜色,角度这些了,说起Web下面的字体选择与C/S相比就逊色多了,不能够像Office那样所见即所得,现在Flex可以解决这个问题啦!,下面就说说怎么通过继承实现Office风格的字体选择下拉框。

        首先我们需要继承一个ComboBox

    public class FontChooser extends ComboBox
        {
            public function FontChooser()
            {
                super();
                var fonts:Array = Font.enumerateFonts(true);
                this.dataProvider = fonts;
                this.labelField = "fontName";
                this.addEventListener(  flash.events.Event.CHANGE , SelectChanged);
            }
           
            protected function SelectChanged(e:flash.events.Event):void
            {
                this.setStyle("fontFamily", (this.selectedItem as Font).fontName);
            }
            public function get SelectedFont():Font
            {
                return this.data as Font;
            }
           
        }

    然后要做些啥呢,那就是写个Renderer了,用来渲染每一个字体名称

    public class FontChooserItemRenderer extends ListItemRenderer
        {
            public function FontChooserItemRenderer()
            {
                super();
            }
            override protected function updateDisplayList(unscaledWidth:Number, unscaledHeight:Number):void
            {
                 super.updateDisplayList(unscaledWidth, unscaledHeight);
                 this.setStyle("fontFamily", (this.data as Font).fontName);
                 this.toolTip= (this.data as Font).fontName;
            }
        }

    最后就是要将渲染器挂上Combobox了,在FontChooser中加上

    this.itemRenderer = new ClassFactory(FontChooserItemRenderer);

  • 相关阅读:
    android 权限大全
    Android限定EditText的输入类型为数字或者英文(包括大小写),EditText,TextView只能输入两位小数
    Android Application 对象介绍
    数据库关键字
    SQLite数据库增删改查操作
    【转】html之<meta> 标签
    javascript剔除数组重复元素的简单方法
    jQuery性能最佳实践
    css学习笔记
    【转】必须避免的html标签十宗罪
  • 原文地址:https://www.cnblogs.com/Brune/p/655765.html
Copyright © 2011-2022 走看看