加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

flex4的Scroller滚动速度的控制

发布时间:2020-12-15 04:26:07 所属栏目:百科 来源:网络整理
导读:Scroller的viewport为Group时,滚动鼠标滑轮,Scroller滚动的速度很慢,Scroller的viewport为VGroup时, 滚动鼠标滑轮,Scroller滚动的速度很快,有没有什么办法控制 Scroller的滚动速度呢?解决方案如下:1.新建VScrollBar的子类MyVScrollerBar.aspackage{i

Scroller的viewport为Group时,滚动鼠标滑轮,Scroller滚动的速度很慢,Scroller的viewport为VGroup时, 滚动鼠标滑轮,Scroller滚动的速度很快,有没有什么办法控制 Scroller的滚动速度呢?解决方案如下:
1.新建VScrollBar的子类
MyVScrollerBar.as
package
{

import flash.events.MouseEvent;



import mx.core.mx_internal;



import spark.components.VScrollBar;

import spark.core.IViewport;



use namespace mx_internal;



[Style(name="movementDelta",inherit="yes",type="number",format="length")]

public class MyVScrollerBar extends VScrollBar

{

public function MyVScrollerBar()

{

setStyle("movementDelta",30);

}



override mx_internal function mouseWheelHandler(event:MouseEvent):void

{

var viewport:IViewport = this.viewport;

if ( viewport == null || !viewport.visible || event.isDefaultPrevented() )

return;



var direction:int = (event.delta > 0) ? -1 : (event.delta < 0) ? 1 : 0;

var movement:Number = getStyle("movementDelta");

viewport.verticalScrollPosition += movement * direction;

event.preventDefault();

}



}
}

2.新建外观类

MyVScrollerBarSkin.mxml
< ?xml version="1.0" encoding="utf-8"?>
< s:SparkSkin xmlns:fx="http://ns.adobe.com/mxml/2009" 

xmlns:s="library://ns.adobe.com/flex/spark" 

xmlns:local="*">

< fx:Metadata>

< ![CDATA[ 

[HostComponent("spark.components.Scroller")]

]]>

< /fx:Metadata> 



< fx:Script>

< ![CDATA[ 



override public function beginHighlightBitmapCapture() : Boolean

{

var needUpdate:Boolean = super.beginHighlightBitmapCapture();

graphics.beginFill(0);

graphics.drawRect(0,width,height);

graphics.endFill();



return needUpdate;

}



override public function endHighlightBitmapCapture() : Boolean

{

var needUpdate:Boolean = super.endHighlightBitmapCapture();

graphics.clear();

return needUpdate;

}

]]>

< /fx:Script>

< local:MyVScrollerBar id="verticalScrollBar" visible="false" />

< s:HScrollBar id="horizontalScrollBar" visible="false" />




< /s:SparkSkin>


3.将Scroller的skinClass设为刚刚新建的外观类MyVScrollerBarSkin
< ?xml version="1.0" encoding="utf-8"?>
< s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" 

xmlns:s="library://ns.adobe.com/flex/spark" 

xmlns:mx="library://ns.adobe.com/flex/mx">



< s:Scroller width="400" height="400" skinClass="MyVScrollerBarSkin">

< s:Group width="100%" height="100%">

< s:Rect width="100%" height="1200">

< s:fill>

< s:SolidColor color="0x338899"/>

< /s:fill>

< /s:Rect>

< /s:Group>

< /s:Scroller>
< /s:Application>

ok,困扰了两天的问题搞定。


通过研究,其实没有必要这么麻烦,以前的flex3的SDK直接设置一个步长就可以解决问题,而spark组建中的scroller组件把这个属性取消了,通过查找例子,发现都是转载的楼主的方法,这的确太麻烦了..
 
后来在一个国外网站搜到一个解决办法,每一个scroller都有一个mouseWheelChanging方法,当滚动鼠标中轮的时候调用,而后就可以在这个函数中进行判断,如下:
 我的滚动条id=mainScroller
 protected function mainScroller _mouseWheelChangingHandler(event:FlexMouseEvent):void
 {
         event.preventDefault();
         var modifier:int = 5;
         var delta:Number = Number(event.delta) * modifier;
         var viewport:IViewport = mainScroller.verticalScrollBar.viewport;
         var vPos:Number = viewport.verticalScrollPosition;
         var maximum:Number = mainScroller.verticalScrollBar.maximum;
                                 
        if (delta < 0) 
        {
                 mainScroller.verticalScrollBar.viewport.verticalScrollPosition =  Math.min(vPos - delta,maximum) ;        
        }
         else
         {
                 mainScroller.verticalScrollBar.viewport.verticalScrollPosition = Math.max(vPos - delta,0);
         }
 
}
 



转载:http://bbs.9ria.com/thread-114341-1-1.html

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读