NAME
    Zodiac::Angle - Class for zodiac_angle manipulation.

SYNOPSIS
     use Zodiac::Angle;

     my $obj = Zodiac::Angle->new(%params);
     my $zodiac_angle = $obj->angle2zodiac($angle, $opts_hr);
     my $angle = $obj->zodiac2angle($zodiac_angle);

METHODS
  "new"
     my $obj = Zodiac::Angle->new(%params);

    Constructor.

    Returns instance of 'Zodiac::Angle'.

  "angle2zodiac"
     my $zodiac_angle = $obj->angle2zodiac($angle, $opts_hr);

    Convert angle to Zodiac angle.

    Options defined $opts_hr control output. Possible keys in reference to
    hash are: minute (0/1 print minutes, default 1), second (0/1 print
    second, default 0), second_round (number of round numbers, default 4),
    sign_type (sign, ascii and struct, default sign).

    Default value of $opts_hr is { minute => 1 }.

    Returns zodiac angle string.

  "zodiac2angle"
     my $angle = $obj->zodiac2angle($zodiac_angle);

    Convert Zodiac angle to angle.

    Returns angle.

ERRORS
     new():
             From Class::Utils::set_params():
                     Unknown parameter '%s'.

     angle2zodiac():
             Parameter 'sign_type' is bad. Possible values are 'sign', 'ascii' and 'struct'.

EXAMPLE1
     use strict;
     use warnings;

     use Zodiac::Angle;
     use Unicode::UTF8 qw(encode_utf8);

     # Object.
     my $obj = Zodiac::Angle->new;

     if (@ARGV < 1) {
             print STDERR "Usage: $0 angle\n";
             exit 1;
     }
     my $angle = $ARGV[0];

     my $zodiac_angle = Zodiac::Angle->new->angle2zodiac($angle);

     # Print out.
     print 'Angle: '.$angle."\n";
     print 'Zodiac angle: '.encode_utf8($zodiac_angle)."\n";

     # Output without arguments:
     # Usage: __SCRIPT__ angle

     # Output with '0.5' argument:
     # Angle: 0.5
     # Zodiac angle: 0°♈30′

EXAMPLE2
     use strict;
     use warnings;

     use Zodiac::Angle;
     use Unicode::UTF8 qw(encode_utf8);

     # Object.
     my $obj = Zodiac::Angle->new;

     if (@ARGV < 1) {
             print STDERR "Usage: $0 angle\n";
             exit 1;
     }
     my $angle = $ARGV[0];

     my $zodiac_angle = Zodiac::Angle->new->angle2zodiac($angle, {
             'minute' => 0,
     });

     # Print out.
     print 'Angle: '.$angle."\n";
     print 'Zodiac angle: '.encode_utf8($zodiac_angle)."\n";

     # Output without arguments:
     # Usage: __SCRIPT__ angle

     # Output with '0.5' argument:
     # Angle: 0.5
     # Zodiac angle: 0°♈

EXAMPLE3
     use strict;
     use warnings;

     use Zodiac::Angle;
     use Unicode::UTF8 qw(encode_utf8);

     # Object.
     my $obj = Zodiac::Angle->new;

     if (@ARGV < 1) {
             print STDERR "Usage: $0 angle\n";
             exit 1;
     }
     my $angle = $ARGV[0];

     my $zodiac_angle = Zodiac::Angle->new->angle2zodiac($angle, {
             'minute' => 1,
             'second' => 1,
             'second_round' => 4,
     });

     # Print out.
     print 'Angle: '.$angle."\n";
     print 'Zodiac angle: '.encode_utf8($zodiac_angle)."\n";

     # Output without arguments:
     # Usage: __SCRIPT__ angle

     # Output with '0.5' argument:
     # Angle: 0.5
     # Zodiac angle: 0°♈30′0.0000′′

EXAMPLE4
     use strict;
     use warnings;

     use Zodiac::Angle;
     use Unicode::UTF8 qw(encode_utf8);

     # Object.
     my $obj = Zodiac::Angle->new;

     if (@ARGV < 1) {
             print STDERR "Usage: $0 angle\n";
             exit 1;
     }
     my $angle = $ARGV[0];

     my $zodiac_angle = Zodiac::Angle->new->angle2zodiac($angle, {
             'minute' => 1,
             'second' => 1,
             'second_round' => 4,
             'sign_type' => 'ascii',
     });

     # Print out.
     print 'Angle: '.$angle."\n";
     print 'Zodiac angle: '.encode_utf8($zodiac_angle)."\n";

     # Output without arguments:
     # Usage: __SCRIPT__ angle

     # Output with '0.5' argument:
     # Angle: 0.5
     # Zodiac angle: 0° ar 30'0.0000''

EXAMPLE5
     use strict;
     use warnings;

     use Zodiac::Angle;
     use Unicode::UTF8 qw(encode_utf8);

     # Object.
     my $obj = Zodiac::Angle->new;

     if (@ARGV < 1) {
             print STDERR "Usage: $0 angle\n";
             exit 1;
     }
     my $angle = $ARGV[0];

     my $zodiac_angle = Zodiac::Angle->new->angle2zodiac($angle, {
             'minute' => 1,
             'second' => 1,
             'second_round' => 4,
             'sign_type' => 'struct',
     });

     # Print out.
     print 'Angle: '.$angle."\n";
     print 'Zodiac angle: '.encode_utf8($zodiac_angle)."\n";

     # Output without arguments:
     # Usage: __SCRIPT__ angle

     # Output with '0.5' argument:
     # Angle: 0.5
     # Zodiac angle: 0°|aries|30′|0.0000′′

DEPENDENCIES
    Class::Utils, Error::Pure, List::Util, Readonly, Unicode::UTF8.

SEE ALSO
    angle2zodiac
        Script to convert angle to zodiac string.

    App::Angle2Zodiac
        Base class for angle2zodiac script.

    Zodiac::Angle::SwissEph
        Class for zodiac_angle manipulation based on SwissEph.

REPOSITORY
    <https://github.com/michal-josef-spacek/Zodiac-Angle>

AUTHOR
    Michal Josef Špaček <mailto:skim@cpan.org>

    <http://skim.cz>

LICENSE AND COPYRIGHT
    © 2020-2024 Michal Josef Špaček

    BSD 2-Clause License

VERSION
    0.07