首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >lua如何禁用触摸事件widget.newScrollView

lua如何禁用触摸事件widget.newScrollView
EN

Stack Overflow用户
提问于 2016-10-01 12:25:02
回答 1查看 635关注 0票数 1

我前面有一个widget.newScrollView组件和一个widget.newButton。不幸的是,当我点击我的按钮时,它也会调用我的ScrollView“点击”处理程序。我如何阻止我的ScrollView得到这个事件?下面是我使用的一些代码:

代码语言:javascript
代码运行次数:0
运行
复制
local function handleButtonEvent( event )
    if ( "ended" == event.phase ) then
        print( "Button was pressed and released" )
    end
    return true; **I tried this - but it had no effect**
end

添加了

代码语言:javascript
代码运行次数:0
运行
复制
local button1 = widget.newButton(
{
    label = "button",
    onEvent = handleButtonEvent,
    emboss = false,
    shape = "roundedRect",
    width = 400,
    height = 100,
    cornerRadius = 32,
    fillColor = { default={1,0,0,1}, over={1,0.1,0.7,1} },
    strokeColor = { default={1,0.4,0,1}, over={0.8,0.8,1,1} },
    strokeWidth = 4,
    fontSize=100;
}

我有一个display.NewImages阵列(行星)和我的处理器-如下所示:

代码语言:javascript
代码运行次数:0
运行
复制
local planets = {};
planets[1] = display.newImage( "planetHexs/001.png", _topLeft_x, _topLeft_y);
planets[2] = display.newImage( "planetHexs/002.png", _topLeft_x, _topLeft_y + _planet_height2 );
....

local scrollView = widget.newScrollView(
{
    top = 0,
    left = 0,
    width = display.actualContentWidth,
    height = display.actualContentHeight,
    scrollWidth = 0,
    scrollHeight = 0,
    backgroundColor = { 0, 0, 0, 0.5},
    verticalScrollDisabled=true;
}

for i = 1, #planets do
    local k = planets[i];
    scrollView:insert( k )
end

function PlanetTapped( num )
    print( "You touched the object!"..num );
end

for i = 1, #planets do
    local k = planets[i];
    k:addEventListener( "tap", function() PlanetTapped(i) end )
end

我得到了这个打印日志:

代码语言:javascript
代码运行次数:0
运行
复制
Button was pressed and released

You touched the object2
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-10-02 03:52:16

必须对事件函数返回true以防止传播。这从本质上告诉Corona,事件被正确地处理,并且不应该激发更多的事件侦听器。您可以在文档中阅读有关事件传播的更多信息。

"tap""touch"事件是由不同的侦听器处理的,因此,如果您希望在单击按钮时停止点击,那么您也可以向按钮中添加一个"tap"侦听器,这实际上只是返回true来防止,或者阻止点击事件到按钮后面的任何东西。

代码语言:javascript
代码运行次数:0
运行
复制
button1:addEventListener("tap", function() return true end)

因为按钮没有tap事件,所以tap事件只需经过按钮就可以到达它后面的任何有"tap"事件的对象。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39806579

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档