gpt4 book ai didi

apache-flex - Chrome 和 Firefox 中的鼠标滚轮

转载 作者:行者123 更新时间:2023-12-04 14:51:30 31 4
gpt4 key购买 nike

我正在尝试在 advancedDataGrid 中处理 mouseWheel 事件但没有成功。没有任何额外的代码,我的广告可以在 IE 中用鼠标滚动,但不能在 Firefox 和 Chrome 中滚动,为什么?为什么它在这些浏览器中表现不同?

然后我尝试了这段代码,但它不起作用:

protected function adgMouseWheelHandler(event:MouseEvent):void
{
event.delta = event.delta > 0 ? 1 : -1;
}

然后像这样在我的广告中设置事件 mouseWheel:
<mx:AdvancedDataGrid id="myADG" width="100%" height="100%" color="0x323232" 
dataProvider="{_currentDatosBusqueda}" verticalScrollPolicy="auto"
fontSize="11" fontFamily="Arial" fontStyle="normal"
fontWeight="normal" doubleClickEnabled="true"
itemDoubleClick="dobleClickFilaDataGridBusqueda(event);"
useRollOver="true" mouseWheel="adgMouseWheelHandler(event);"
>

有任何想法吗?

谢谢!

最佳答案

修复了当 wmode="opaque"时 Flex 应用程序中没有 MouseWheel 的问题(它实际上适用于 IE,但不适用于 Firefox 或 Chrome,也可能不适用于 Safari 或 Opera)。这也修复了 Firefox 和其他所有东西之间不同的 MouseWheel 滚动速率。

将此 JavaScript 添加到您的包装器中:
.

        if(window.addEventListener) {
var eventType = (navigator.userAgent.indexOf('Firefox') !=-1) ? "DOMMouseScroll" : "mousewheel";
window.addEventListener(eventType, handleWheel, false);
}

function handleWheel(event) {
var app = document.getElementById("YOUR_APPLICATION");
var edelta = (navigator.userAgent.indexOf('Firefox') !=-1) ? -event.detail : event.wheelDelta/40;
var o = {x: event.screenX, y: event.screenY,
delta: edelta,
ctrlKey: event.ctrlKey, altKey: event.altKey,
shiftKey: event.shiftKey}

app.handleWheel(o);
}

并将此支持类放入您的主 MXML 文件(Flex4 的声明):
.
package {
import flash.display.InteractiveObject;
import flash.display.Shape;
import flash.display.Stage;
import flash.events.MouseEvent;
import flash.external.ExternalInterface;
import flash.geom.Point;

import mx.core.FlexGlobals;
import mx.core.UIComponent;
import mx.events.FlexEvent;

public class MouseWheelSupport {

//--------------------------------------
// Constructor
//--------------------------------------

public function MouseWheelSupport() {
FlexGlobals.topLevelApplication.addEventListener(FlexEvent.APPLICATION_COMPLETE, attachMouseWheelHandler);
}

//------------------------------------------------------------------------------
//
// Functions
//
//------------------------------------------------------------------------------

//--------------------------------------
// Private
//--------------------------------------

private function attachMouseWheelHandler(event : FlexEvent) : void {
ExternalInterface.addCallback("handleWheel", handleWheel);
}

private function handleWheel(event : Object) : void {
var obj : InteractiveObject = null;
var applicationStage : Stage = FlexGlobals.topLevelApplication.stage as Stage;

var mousePoint : Point = new Point(applicationStage.mouseX, applicationStage.mouseY);
var objects : Array = applicationStage.getObjectsUnderPoint(mousePoint);

for (var i : int = objects.length - 1; i >= 0; i--) {
if (objects[i] is InteractiveObject) {
obj = objects[i] as InteractiveObject;
break;
}
else {
if (objects[i] is Shape && (objects[i] as Shape).parent) {
obj = (objects[i] as Shape).parent;
break;
}
}
}

if (obj) {
var mEvent : MouseEvent = new MouseEvent(MouseEvent.MOUSE_WHEEL, true, false,
mousePoint.x, mousePoint.y, obj,
event.ctrlKey, event.altKey, event.shiftKey,
false, Number(event.delta));
obj.dispatchEvent(mEvent);
}
}
}
}

JavaScript 示例:.
 <script type="text/javascript">
// For version detection, set to min. required Flash Player version, or 0 (or 0.0.0), for no version detection.
var swfVersionStr = "10.1.0";
// To use express install, set to playerProductInstall.swf, otherwise the empty string.
var xiSwfUrlStr = "playerProductInstall.swf";
var flashvars = {};
var params = {};
params.quality = "high";
params.bgcolor = "#ffffff";
params.allowscriptaccess = "sameDomain";
params.allowfullscreen = "true";
params.wmode = "opaque";
var attributes = {};
attributes.id = "YOURAPP";
attributes.name = "YOURAPP";
attributes.align = "middle";

if(window.addEventListener) {
var eventType = (navigator.userAgent.indexOf('Firefox') !=-1) ? "DOMMouseScroll" : "mousewheel";
window.addEventListener(eventType, handleWheel, false);
}

function handleWheel(event) {
var app = document.getElementById("YOURAPP");
var edelta = (navigator.userAgent.indexOf('Firefox') !=-1) ? -event.detail : event.wheelDelta/40;
var o = {x: event.screenX, y: event.screenY,
delta: edelta,
ctrlKey: event.ctrlKey, altKey: event.altKey,
shiftKey: event.shiftKey}

app.handleWheel(o);
}

swfobject.embedSWF(
"YOURAPP.swf", "flashContent",
"100%", "100%",
swfVersionStr, xiSwfUrlStr,
flashvars, params, attributes);
// JavaScript enabled so display the flashContent div in case it is not replaced with a swf object.
swfobject.createCSS("#flashContent", "display:block;text-align:left;");

</script>

关于apache-flex - Chrome 和 Firefox 中的鼠标滚轮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5485187/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com