flex VSlider 滑竿 (track) 宽度的改变

本文介绍如何通过自定义Flex框架中滑动条的轨道皮肤来改变滑动条轨道的宽度,包括创建两个自定义类HighWidthSliderSkin和WidthSliderSkin的具体实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    <mx:VSlider id="volumSlider" left="11" top="10" width="14" height="137" dataTipPrecision="0"
                maximum="100" minimum="0" showTrackHighlight="true" snapInterval="1"
                thumbSkin="@Embed(source='/assets/images/control.png')"
                trackHighlightSkin="com.webex.videosharing.skin.HighWidthSliderSkin"

                trackSkin="com.xxx.xxx.xxx.WidthSliderSkin" value="50"/>

要想改变其滑竿的宽度也就是track的宽度 必须自己 写两个类替换 默认的 trackSkin 和 trackHighSkin(高度的skin)

package com.xxx.xxx.xxx
{
    import flash.geom.Matrix;
    
    import mx.core.EdgeMetrics;
    import mx.skins.halo.SliderTrackSkin;

    public class HighWidthSliderSkin extends  SliderTrackSkin
    {
        public function HighWidthSliderSkin()
        {
        }
        override public function get measuredWidth():Number   
        {   
            return 7;
        }
        
        override public function get measuredHeight():Number   
        {   
            return 7;
        }
        
        override public function get height():Number   
        {   
            return 7;
        }
        
        override protected function drawRoundRect(x:Number, y:Number, width:Number, height:Number, cornerRadius:Object=null, color:Object=null, alpha:Object=null, gradientMatrix:Matrix=null, gradientType:String="linear", gradientRatios:Array=null, hole:Object=null):void
        {
            
            super.graphics.beginFill(0x09A2E0,1);
            super.drawRoundRect(x, y-1, width,height,null,0x09A2E0 , 1,  null, null, null, null);
            super.graphics.lineStyle(1,0x027FB8);
        }      
    
    }

}



package com.xxx.xxx.xxx
{
    import flash.geom.Matrix;
    
    import mx.core.EdgeMetrics;
    import mx.skins.halo.SliderTrackSkin;

    public class WidthSliderSkin extends  SliderTrackSkin
    {
        public function WidthSliderSkin()
        {
            
        }
        
        
        
        override public function get height():Number
        {
            
            return 7;
        }
        
        override public function get measuredHeight():Number   
        {   
            return 7;
        }
        
        override protected function drawRoundRect(x:Number, y:Number, width:Number, height:Number, cornerRadius:Object=null, color:Object=null, alpha:Object=null, gradientMatrix:Matrix=null, gradientType:String="linear", gradientRatios:Array=null, hole:Object=null):void
        {
            
            super.graphics.beginFill(0xE2E2E2)
            super.graphics.drawRect(x,y,width,height);
            super.graphics.lineStyle(1,0xE2E2E2);
            
            //super.drawRoundRect(x, y , width, height,null, 0xE2E2E2, alpha, null, null, null, null);
        }
       
    
    }
}

然后即可看到效果:





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值