NAME

Curses::Toolkit::Object::Coordinates - simple coordinates class

VERSION

version 0.093020

DESCRIPTION

Trivial class to hold 2 points

+ and - are properly overloaded

CONSTRUCTOR

new

input  : x1 : top left x
         y1 : top left y
         x2 : right bottom x
         y2 : right bottom y
         [ normalize ] : optional, if false, won't normalize the coords (see below)
  OR
input  : x1 : top left x
         y1 : top left y
         width : width
         height : heigth
         [ normalize ] : optional, if false, won't normalize the coords (see below)
  OR
input  : x1 : sub { ... } # returns top left x
         y1 : sub { ... } # returns top left y
         x2 : sub { ... } # returns right bottom x
         y2 : sub { ... } # returns right bottom y
         [ normalize ] : optional, if false, won't normalize the coords (see below)
  OR
input  : a Curses::Toolkit::Object::Coordinates object

output : a Curses::Toolkit::Object::Coordinates object

Normalize option : if set to false, the coordinate will be untouched. If set to true (default), the coordinate will make sure x1 < x2 and y1 < y2, and that they are all integers, swapping or rounding them if necessary.

new_zero

Creates a new coordinates with all zero

input  : none
output : a Curses::Toolkit::Object::Coordinates object

METHODS

clone

clone an coordinates object

input  : none
output : a Curses::Toolkit::Object::Coordinates object

set

set attributes of the coordinate

input  : one or more of x1, x2, y1, y2, width, height
output : the coordinate object

width

returns the width represented by the coordinates

height

returns the height represented by the coordinates

x1, x2, y1, y2

These are helpers to retrieve the coordinates values

add

Add to the coordinate.

If the argument is a constant, it's added to all the components of the coordinate. If it's a Curses::Toolkit::Object::Coordinates, it's added side by side If it's a hashref, it's added side by side

input  : a CONSTANT
OR
input  : a Curses::Toolkit::Object::Coordinates
OR
input  : a HASHREF of 'x1', 'x2', 'y1', 'y2'

output : the Curses::Toolkit::Object::Coordinates object

substract

Substract from the coordinate (also overloads '-').

If the argument is a constant, it's substracted from all the components of the coordinate. If it's a Curses::Toolkit::Object::Coordinates, it's substracted side by side If it's a hashref, it's substracted side by side

input  : a CONSTANT
OR
input  : a Curses::Toolkit::Object::Coordinates
OR
input  : a HASHREF of 'x1', 'x2', 'y1', 'y2'

output : the Curses::Toolkit::Object::Coordinates object

restrict_to

Force the coordinate to be inside the passed coordinate.

input  : a Curses::Toolkit::Object::Coordinates object
output : the object

translate

Given a X value and a Y value, translates the coordinate accordingly

input  : x : value to translate the coord horizontally
         y : value to translate the coord vertically
output : the Curses::Toolkit::Object::Coordinates object

translate_up

Given a value, translates the coordinate up (value sign is ignored)

input  : value to translate the coord up
output : the Curses::Toolkit::Object::Coordinates object

translate_down

Given a value, translates the coordinate down (value sign is ignored)

input  : value to translate the coord down
output : the Curses::Toolkit::Object::Coordinates object

translate_left

Given a value, translates the coordinate left (value sign is ignored)

input  : value to translate the coord left
output : the Curses::Toolkit::Object::Coordinates object

translate_right

Given a value, translates the coordinate right (value sign is ignored)

input  : value to translate the coord right
output : the Curses::Toolkit::Object::Coordinates object

contains

Return true if the coordinates contains the given coordinates

my $boolean = $self->contains( $coord )

input  : a Curses::Toolkit::Object::Coordinates object : the coordinates
output : true or false

is_inside

Return true if the coordinates is inside the given coordinates

my $boolean = $self->is_inside( $coord )

input  : a Curses::Toolkit::Object::Coordinates object : the coordinates
output : true or false

is_in_widget

Return true if the coordinates is in side the give widget

input  : Curses::Toolkit::Widget : the widget
output : true or false

AUTHOR

Damien "dams" Krotkine

COPYRIGHT AND LICENSE

This software is copyright (c) 2008 by Damien "dams" Krotkine.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.