NAME
Location::Area::DoCoMo::iArea - Get NTT DoCoMo's i-Area from i-Area code or Geo coordinate
SYNOPSIS
use Location::Area::DoCoMo::iArea;
# Or, if you want to use adjusted Aura data,
use Location::Area::DoCoMo::iArea qw(useAdjustedAura);
#Create object
# Get i-Area object from Geo coordinate at WGS84 Datum
$oiArea = Location::Area::DoCoMo::iArea->create_coord("34/20/39.933","135/21/51.826","tokyo","mapion");
# or
$oiArea = Location::Area::DoCoMo::iArea->create_coord("342039.933","1352151.826","wgs84","dmsn");
# Get i-Area object from full area code
$oiArea = Location::Area::DoCoMo::iArea->create_iarea("152","00");
# or same
$oiArea = Location::Area::DoCoMo::iArea->create_iarea("15200");
#Get data
# Get full area code (5digit)
my $fid = $oiArea->full_areaid();
# Get main area code (3digit)
my $pid = $oiArea->areaid();
# Get sub area code (2digit)
my $sid = $oiArea->sub_areaid();
# Get area name (at EUC-JP character code)
my $name = $oiArea->name();
# Get prefecture name of this area (at EUC-JP character code)
my $pref = $oiArea->prefecture();
# Get region name of this area (at EUC-JP character code)
my $reg = $oiArea->region();
# Get aura (boundary square of area) object (Location::GeoTool::Aura)
my $oAura = $oiArea->get_aura;
# Get south, west, north, east limit of this area at WGS84 datum, gpsOne format
my ($slim,$wlim,$nlim,$elim) = $oAura->datum_wgs84->format_gpsone->array;
# Or at TOKYO datum, degree
my ($slim,$wlim,$nlim,$elim) = $oAura->datum_tokyo->format_degree->array;
# Get Aura's center point object (Location::GeoTool)
my ($clat,$clong) = $oiArea->get_center->array;
DESCRIPTION
CONSTRUCTOR
create_coord
Create Location::Area::DoCoMo::iArea object from coordinate.
Usage:
$obj = Location::Area::DoCoMo::iArea->create_coord($lat,$lon,$datum,$format);
Arguments:
$lat : Latitude (North are Positive).
$lon : Longitude (East are Positive).
$datum : Specify datum of $lat/$long. (See Location::GeoTool)
$format: Specify format of $lat/$long. (See Location::GeoTool)
or another way,
Usage:
$obj = Location::Area::DoCoMo::iArea->create_coord($point);
Arguments:
$point : Object of Location::GeoTool.
Return Values:
$obj : Location::Area::DoCoMo::iArea object. undef if can't bind coordinate to area.
create_iarea
Create Location::Area::DoCoMo::iArea object from full area code.
Usage:
$obj = Location::Area::DoCoMo::iArea->create_iarea($id,$sid);
Arguments:
$id : Set full area code or main area code
$lon : Set sub area code (needed if you give main area code as $id)
Return Values:
$obj : Location::Area::DoCoMo::iArea object. undef if can't bind code to area.
FIELDS
full_areaid
areaid
sub_areaid
Each fields return full area code, main area code or sub area code.
name
prefecture
region
Each fields return area name, prefecture name of this area or region name of this area. Each return values are described in EUC-JP character code.
METHODS
include_area
Check the point is included current area or not.
Usage:
$is_include = $obj->include_area($lat,$lon,$datum,$format);
# or
$is_include = $obj->include_area($point);
Return Values:
$is_include : Return 1 if included, 0 if not.
get_aura
Get aura (boundary square of area) object - Location::GeoTool::Aura.
Usage:
$oAura = $obj->get_aura;
The way to use Location::GeoTool::Aura object is like below:
#Specify datum or format:
$oAura->datum_wgs84->format_degree...
Names of methods are same with Location::GeoTool.
#Get boundary latitude/longitude array:
($sbound,$wbound,$nbound,$ebound) = $oAura->......->array;
Notice:
NTT DoCoMo's aura data contains a lot of inconsistencies.
There are differents between Aura boundary square, which is
defined by DoCoMo's summary data, and that is calcurated
from mesh data.
So, I add adjusted aura data which are calcurated from mesh,
you can use it.
If you want, you should use this module like this:
use Location::Area::DoCoMo::iArea qw(useAdjustedAura);
get_center
Get aura's center point by Location::GeoTool object.
Usage:
$cpoint = $obj->get_center;
To get coordinate of center point, like below:
($clat,$clong) = $cpoint->datum_wgs84->format_degree->array;
get_nextarea
Get i-Area object list which are next to this area.
Usage:
@next = $obj->getNextArea;
Return Values:
@next : i-Area object list of areas next to this area.
Notice:
1.If there is the sea between one area and another, they are not next area.
This definition is based on NTT DoCoMo's.
2.DoCoMo's official data contains a lot of inconsistencies.
So, this module adjusts them.
DEPENDENCIES
Carp
Location::GeoTool
SEE ALSO
i-Area data in this version is based on NTT DoCoMo's data, publicated in Mar. 29th, 2004.
You can get original data on
http://www.nttdocomo.co.jp/p_s/imode/iarea/iareadata040329.lzh.
And, next area data is based on NTT DoCoMo's web site,
http://www.nttdocomo.co.jp/p_s/imode/iarea/iareaweb/iarea_contents.html.
You should see these site.
Support this module in Kokogiko! web site : http://kokogiko.net/
AUTHOR
OHTSUKA Ko-hei, <kotsuka@spacetag.jp>
COPYRIGHT AND LICENSE
Copyright (C) 2004 by SpaceTag INC.,
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.0 or, at your option, any later version of Perl 5 you may have available.