Map::Tube::Kiev - Interface to the Kiev Metro Map.
use Map::Tube::Kiev; my $obj = Map::Tube::Kiev->new; my $routes_ar = $obj->get_all_routes($from, $to); my $line = $obj->get_line_by_id($line_id); my $line = $obj->get_line_by_name($line_name); my $lines_ar = $obj->get_lines; my $station = $obj->get_node_by_id($station_id); my $station = $obj->get_node_by_name($station_name); my $route = $obj->get_shortest_route($from, $to); my $stations_ar = $obj->get_stations($line); my $metro_name = $obj->name; my $xml_file = $obj->xml;
It currently provides functionality to find the shortest route between the two given nodes.
For more information about Kiev Map, click here.
new
my $obj = Map::Tube::Kiev->new;
Constructor.
Returns instance of object.
get_all_routes
my $routes_ar = $obj->get_all_routes($from, $to);
Get all routes from station to station.
Returns reference to array with Map::Tube::Route objects.
get_line_by_id
my $line = $obj->get_line_by_id($line_id);
Get line object defined by id.
Returns Map::Tube::Line object.
get_line_by_name
my $line = $obj->get_line_by_name($line_name);
Get line object defined by name.
get_lines
my $lines_ar = $obj->get_lines;
Get lines in metro map.
Returns reference to unsorted array with Map::Tube::Line objects.
get_node_by_id
my $station = $obj->get_node_by_id($station_id);
Get station node by id.
Returns Map::Tube::Node object.
get_node_by_name
my $station = $obj->get_node_by_name($station_name);
Get station node by name.
get_shortest_route
my $route = $obj->get_shortest_route($from, $to);
Get shortest route between $from and $to node names. Node names in $from and $to are case insensitive.
$from
$to
Returns Map::Tube::Route object.
get_stations
my $stations_ar = $obj->get_stations($line);
Get list of stations for concrete metro line.
Returns reference to array with Map::Tube::Node objects.
name
my $metro_name = $obj->name;
Get metro name.
Returns string with metro name.
xml
my $xml_file = $obj->xml;
Get XML specification of Kiev metro.
Returns string with XML.
use strict; use warnings; use Encode qw(decode_utf8 encode_utf8); use Map::Tube::Kiev; # Object. my $obj = Map::Tube::Kiev->new; # Get route. my $route = $obj->get_shortest_route(decode_utf8('Берестейська'), decode_utf8('Оболонь')); # Print out type. print "Route: ".encode_utf8($route)."\n"; # Output: # Route: Берестейська (Святошинсько-Броварська лінія), Шулявська (Святошинсько-Броварська лінія), Політехнічний інститут (Святошинсько-Броварська лінія), Вокзальна (Святошинсько-Броварська лінія), Університет (Святошинсько-Броварська лінія), Театральна (Святошинсько-Броварська лінія), Хрещатик (Святошинсько-Броварська лінія), Поштова площа (Куренівсько-Червоноармійська лінія), Контрактова площа (Куренівсько-Червоноармійська лінія), Тараса Шевченка (Куренівсько-Червоноармійська лінія), Петрівка (Куренівсько-Червоноармійська лінія), Оболонь (Куренівсько-Червоноармійська лінія)
use strict; use utf8; use warnings; use Map::Tube::Kiev; # Object. my $obj = Map::Tube::Kiev->new; # Get XML file. my $xml_file = $obj->xml; # Print out XML file. print "XML file: $xml_file\n"; # Output like: # XML file: .*/kiev-map.xml
use strict; use warnings; use Map::Tube::GraphViz; use Map::Tube::GraphViz::Utils qw(node_color_without_label); use Map::Tube::Kiev; # Object. my $obj = Map::Tube::Kiev->new; # GraphViz object. my $g = Map::Tube::GraphViz->new( 'callback_node' => \&node_color_without_label, 'driver' => 'neato', 'tube' => $obj, ); # Get graph to file. $g->graph('Kiev.png'); # Print file. system "ls -l Kiev.png"; # Output like: # -rw-r--r-- 1 skim skim 163162 Jan 10 14:20 Kiev.png
use strict; use warnings; use Encode qw(encode_utf8); use Map::Tube::Kiev; # Object. my $obj = Map::Tube::Kiev->new; # Get lines. my $lines_ar = $obj->get_lines; # Print out. map { print encode_utf8($_->name)."\n"; } sort @{$lines_ar}; # Output: # Куренівсько-Червоноармійська лінія # Святошинсько-Броварська лінія # Сирецько-Печерська лінія
use strict; use warnings; use Encode qw(decode_utf8 encode_utf8); use Map::Tube::Kiev; # Arguments. if (@ARGV < 1) { print STDERR "Usage: $0 line\n"; exit 1; } my $line = decode_utf8($ARGV[0]); # Object. my $obj = Map::Tube::Kiev->new; # Get stations for line. my $stations_ar = $obj->get_stations($line); # Print out. map { print encode_utf8($_->name)."\n"; } @{$stations_ar}; # Output: # Usage: __PROG__ line # Output with 'foo' argument. # Map::Tube::get_stations(): ERROR: Invalid Line Name [foo]. (status: 105) file __PROG__ on line __LINE__ # Output with 'Сирецько-Печерська лінія' argument. # Сирець # Дорогожичі # Лук'янівська # Золоті ворота # Палац спорту # Кловська # Печерська # Дружби народів # Видубичі # Славутич # Осокорки # Позняки # Харківська # Вирлиця # Бориспільська # Червоний хутір
File::Share, Map::Tube, Moo, namespace::clean.
Core library as Role (Moo) to process map data.
Install the Map::Tube modules.
Install the Map::Tube concrete metro modules.
https://github.com/michal-josef-spacek/Map-Tube-Kiev
Michal Josef Špaček mailto:skim@cpan.org
http://skim.cz
© 2014-2023 Michal Josef Špaček
Artistic License
BSD 2-Clause License
0.06
To install Map::Tube::Kiev, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Map::Tube::Kiev
CPAN shell
perl -MCPAN -e shell install Map::Tube::Kiev
For more information on module installation, please visit the detailed CPAN module installation guide.