为什么这个Corona SDK代码不能用于基于触摸点的居中视图?

时间:2015-04-27 06:45:20

标签: corona

任何建议如何修复我下面的代码使它工作?我希望能够在放大或缩小(即点击或双击)后定位moveableGroup,以便点击的点将移动到fixedGroup中的十字准线的中心。我正在弄清楚是否正确使用群组缩放,移动等等。

display.setStatusBar( display.HiddenStatusBar )
system.setTapDelay( 0.3 )

local function moveableMapTouchListener( event )
    local moveableView = event.target
    if event.phase == "began" then
        moveableView.markX = moveableView.x    -- store x location of object
        moveableView.markY = moveableView.y    -- store y location of object
    elseif event.phase == "moved" then
        local x = (event.x - event.xStart) + moveableView.markX
        local y = (event.y - event.yStart) + moveableView.markY
        moveableView.x, moveableView.y = x, y    -- move object based on calculations above
    elseif event.phase == "ended" then
    end

    return true
end

local function moveableViewTapListener(event) 
    local moveableView = event.target

    -- Calculate Scale Ratio
    local scaleRatio 
    if event.numTaps == 1 then
        -- Single Tap
        scaleRatio = 0.8
    elseif event.numTaps == 2 then
        scaleRatio = 1/0.8
    end

    -- Note Pivot Point (where user clicked) and current Centre
    local pivotXLocal, pivotYLocal =  event.target:contentToLocal( event.x, event.y )
    local centreX, centreY = -moveableView.x, -moveableView.y

    -- Scale Image
    moveableView:scale(scaleRatio, scaleRatio)

    -- ↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓
    -- Move to Centre Around Pivot Point  *** HOW TO DO THIS ??? - THIS DOESN'T WORK ***
    local pivotXContent, pivotYContent =  event.target:localToContent( pivotXLocal, pivotYLocal )
    local zeroXContent, zeroYContent =  event.target:localToContent( 0,0 )
    moveableView.x, moveableView.y = pivotXContent - zeroXContent, pivotYContent - zeroYContent
    -- ↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑

    return true
end

---------------------------------
-- Implementation
---------------------------------

-- Moveable Group
local moveableGroup = display.newGroup()
local internalContents = display.newRect(moveableGroup, 50,80,  300,300)
internalContents.strokeWidth = 3
internalContents:setFillColor  ( 1, 0.5 ,1, 0.5 )
internalContents:setStrokeColor( 0, 0, 1, 1 )

-- Fixedup Group (with crosshairs)
local mainFixedGroup = display.newGroup()
local _w, _h = 0.8 * display.contentWidth, 0.8 * display.contentHeight
local myRectangle = display.newRect(mainFixedGroup, 0, 0,  _w, _h )
myRectangle.strokeWidth = 3
myRectangle:setFillColor  ( 1, 0 ,0, 0 )
myRectangle:setStrokeColor( 0, 0, 1, 1 )
-- Cross Haris
local crossHari1 = display.newLine(mainFixedGroup, -_w/2, -_h/2, _w/2, _h/2 )
crossHari1:setStrokeColor(  0, 0, 1, 1  )
crossHari1.strokeWidth = 1
local crossHari2 = display.newLine(mainFixedGroup, -_w/2, _h/2, _w/2, -_h/2 )
crossHari2:setStrokeColor(  0, 0, 1, 1  )
crossHari2.strokeWidth = 1
mainFixedGroup.x, mainFixedGroup.y = display.contentWidth/2, display.contentHeight/2

-- Insert Moveable Group into Fixed Group
mainFixedGroup:insert(moveableGroup)
moveableGroup.x = -50
moveableGroup.y = -50

-- Add Listeners (to move / scale the moveable Group)
moveableGroup:addEventListener( "touch", moveableMapTouchListener )
moveableGroup:addEventListener( "tap", moveableViewTapListener)

1 个答案:

答案 0 :(得分:0)

这似乎解决了这个问题:

display.setStatusBar( display.HiddenStatusBar )
system.setTapDelay( 0.3 )

local function showPoint(parent, x, y)
    local myCircle = display.newCircle(parent, x,y, 8 )
    myCircle:setFillColor( 0.5,0,1 )
    myCircle.strokeWidth = 0
end

local function moveableMapTouchListener( event )
    local moveableView = event.target
    if event.phase == "began" then
        moveableView.markX = moveableView.x    -- store x location of object
        moveableView.markY = moveableView.y    -- store y location of object
    elseif event.phase == "moved" then
        local x = (event.x - event.xStart) + moveableView.markX
        local y = (event.y - event.yStart) + moveableView.markY
        moveableView.x, moveableView.y = x, y    -- move object based on calculations above
    elseif event.phase == "ended" then
    end

    return true
end

local function moveableViewTapListener(event) 
    local moveableView = event.target

    -- Calculate Scale Ratio
    local scaleRatio 
    if event.numTaps == 1 then
        -- Single Tap
        scaleRatio = 0.8
    elseif event.numTaps == 2 then
        scaleRatio = 1/0.8
    end

    -- -- Note Pivot Point (where user clicked) and current Centre
    -- local pivotXLocal, pivotYLocal =  event.target:contentToLocal( event.x, event.y )
    -- local centreX, centreY = -moveableView.x, -moveableView.y

     -- Note Pivot Point (where user clicked) and current Centre
    local pivotXL, pivotYL =  moveableView:contentToLocal( event.x, event.y )
    local myCircle = display.newCircle(moveableView, pivotXL, pivotYL, 8 )
    myCircle:setFillColor( 0.5,0,1 )
    myCircle.strokeWidth = 0


    -- Scale Image
    moveableView:scale(scaleRatio, scaleRatio)

    -- ↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓

    local ox, oy = moveableView.parent:contentToLocal( display.contentWidth/2, display.contentHeight/2 )
    local txc, tyc = moveableView:localToContent(myCircle.x, myCircle.y)
    local tx, ty = moveableView.parent:contentToLocal( txc, tyc)
    showPoint(moveableView.parent, ox, oy)
    local dx, dy = tx-ox, ty-oy
    moveableView.x, moveableView.y = moveableView.x - dx, moveableView.y - dy

    -- -- Move to Centre Around Pivot Point  *** HOW TO DO THIS ??? - THIS DOESN'T WORK ***
    -- local pivotXContent, pivotYContent =  event.target:localToContent( pivotXLocal, pivotYLocal )
    -- local zeroXContent, zeroYContent =  event.target:localToContent( 0,0 )
    -- moveableView.x, moveableView.y = pivotXContent - zeroXContent, pivotYContent - zeroYContent
    -- ↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑

    return true
end

---------------------------------
-- Implementation
---------------------------------

-- Moveable Group
local moveableGroup = display.newGroup()
local internalContents = display.newRect(moveableGroup, 50,80,  300,300)
internalContents.strokeWidth = 3
internalContents:setFillColor  ( 1, 0.5 ,1, 0.5 )
internalContents:setStrokeColor( 0, 0, 1, 1 )

-- Fixedup Group (with crosshairs)
local mainFixedGroup = display.newGroup()
local _w, _h = 0.8 * display.contentWidth, 0.8 * display.contentHeight
local myRectangle = display.newRect(mainFixedGroup, 0, 0,  _w, _h )
myRectangle.strokeWidth = 3
myRectangle:setFillColor  ( 1, 0 ,0, 0 )
myRectangle:setStrokeColor( 0, 0, 1, 1 )
-- Cross Haris
local crossHari1 = display.newLine(mainFixedGroup, -_w/2, -_h/2, _w/2, _h/2 )
crossHari1:setStrokeColor(  0, 0, 1, 1  )
crossHari1.strokeWidth = 1
local crossHari2 = display.newLine(mainFixedGroup, -_w/2, _h/2, _w/2, -_h/2 )
crossHari2:setStrokeColor(  0, 0, 1, 1  )
crossHari2.strokeWidth = 1
mainFixedGroup.x, mainFixedGroup.y = display.contentWidth/2, display.contentHeight/2

-- Insert Moveable Group into Fixed Group
mainFixedGroup:insert(moveableGroup)
moveableGroup.x = -50
moveableGroup.y = -50
moveableGroup:rotate( 45 )


-- Add Listeners (to move / scale the moveable Group)
moveableGroup:addEventListener( "touch", moveableMapTouchListener )
moveableGroup:addEventListener( "tap", moveableViewTapListener)