Difference between revisions of "Sprite:hitTestPoint"

From GiderosMobile
(added example)
m
 
(7 intermediate revisions by 2 users not shown)
Line 5: Line 5:
 
=== Description ===
 
=== Description ===
 
Checks whether the given coordinates (in global coordinate system) is in bounds of the sprite.
 
Checks whether the given coordinates (in global coordinate system) is in bounds of the sprite.
<source lang="lua">
+
<syntaxhighlight lang="lua">
(bool) = Sprite:hitTestPoint(x,y,shapeFlag)
+
(bool) = Sprite:hitTestPoint(x,y,onlyvisible,ref)
</source>
+
</syntaxhighlight>
  
 
=== Parameters ===
 
=== Parameters ===
 
'''x''': (number)  the x coordinate to test<br/>
 
'''x''': (number)  the x coordinate to test<br/>
 
'''y''': (number)  the y coordinate to test<br/>
 
'''y''': (number)  the y coordinate to test<br/>
'''shapeFlag''': (bool) is hidden, clipping/masking, taken into consideration when testing hit point? '''optional'''<br/>
+
'''onlyvisible''': (bool) hit test only for visible sprite (clipping/masking) '''optional, default = false'''<br/>
 +
'''ref''': (Sprite) specifies which sprite is the reference of x,y coordinates. If nil global coordinates are assumed '''optional, default = nil''', '''new Gideros 2023.2'''<br/>
  
 
=== Return values ===
 
=== Return values ===
Line 19: Line 20:
 
=== Example ===
 
=== Example ===
 
'''Moves a pixel with the mouse'''
 
'''Moves a pixel with the mouse'''
<source lang="lua">
+
<syntaxhighlight lang="lua">
 
local pixel = Pixel.new(0xff0000, 1, 32, 32)
 
local pixel = Pixel.new(0xff0000, 1, 32, 32)
 
local x0, y0, focus
 
local x0, y0, focus
Line 46: Line 47:
 
end
 
end
 
end)
 
end)
</source>
+
</syntaxhighlight>
  
 
{{Sprite}}
 
{{Sprite}}

Latest revision as of 05:28, 23 April 2024

Available since: Gideros 2011.6
Class: Sprite

Description

Checks whether the given coordinates (in global coordinate system) is in bounds of the sprite.

(bool) = Sprite:hitTestPoint(x,y,onlyvisible,ref)

Parameters

x: (number) the x coordinate to test
y: (number) the y coordinate to test
onlyvisible: (bool) hit test only for visible sprite (clipping/masking) optional, default = false
ref: (Sprite) specifies which sprite is the reference of x,y coordinates. If nil global coordinates are assumed optional, default = nil, new Gideros 2023.2

Return values

Returns (bool) true if the given global coordinates are in bounds of the sprite, false otherwise

Example

Moves a pixel with the mouse

local pixel = Pixel.new(0xff0000, 1, 32, 32)
local x0, y0, focus
pixel:addEventListener(Event.MOUSE_DOWN, function(e)
	if pixel:hitTestPoint(e.x, e.y) then
		focus = true
		x0, y0 = e.x, e.y
		e:stopPropagation()
	end
end)
pixel:addEventListener(Event.MOUSE_MOVE, function(e)
	if focus then
		local dx = e.x - x0
		local dy = e.y - y0
		pixel:setX(self.camera:getX() + dx)
		pixel:setY(self.camera:getY() + dy)
		x0 = e.x
		y0 = e.y
		e:stopPropagation()
	end
end)
pixel:addEventListener(Event.MOUSE_UP, function(e)
	if focus then
		focus = false
		e:stopPropagation()
	end
end)