point_in_triangle

Checks to see whether a given point falls within the defined triangular area.

Syntax:

point_in_triangle(px, py, x1, y1, x2, y2, x3, y3);


Argument Description
px The x coordinate of the point to check.
py The y coordinate of the point to check.
x1 The x coordinate of the first corner of the triangle to check.
y1 The y coordinate of the first corner of the triangle to check.
x2 The x coordinate of the second corner of the triangle to check.
y2 The y coordinate of the second corner of the triangle to check.
x3 The x coordinate of the third corner of the triangle to check.
y3 The y coordinate of the third corner of the triangle to check.


Returns: Boolean


Description

When using this function, you define a triangular area and GameMaker: Studio will work out whether the given point falls within its bounds or not. If the point falls within the defined triangle the function will return true otherwise the function will return false.


Example:

var inst = instance_nearest(x, y, obj_Player);
if instance_exists(inst)
   {
   var x1 = x + lengthdir_x(100, image_angle - 45);
   var y1 = y + lengthdir_y(100, image_angle - 45);
   var x2 = x + lengthdir_x(100, image_angle + 45);
   var y2 = y + lengthdir_y(100, image_angle + 45);
   if point_in_triangle(inst.x, inst.y, x, y, x1, y1, x2, y2)
      {
      can_see = true;
      }
   }

The above code uses the point_in_triangle function as a "cone of vision" to check for an instance of "obj_player", setting a variable to true should the objects x/y position fall within the defined triangle.


Back: Collision Checking
Next: point_in_circle