Measure/Number.php

Show: PublicProtectedPrivateinherited
Table of Contents
Zend Framework
LICENSE This source file is subject to the new BSD license that is bundled with this package in the file LICENSE.txt. It is also available through the world-wide-web at this URL: http://framework.zend.com/license/new-bsd If you did not receive a copy of the license and are unable to obtain it through the world-wide-web, please send an email to [email protected] so we can send you a copy immediately.
Category
Zend  
Copyright
Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)  
License
New BSD License  
Package
Zend_Measure  
Version
$Id$  

\Zend_Measure_Number

Package: Zend_Measure\Zend_Measure_Number
Class for handling number conversions
This class can only handle numbers without precision
Parent(s)
\Zend_Measure_Abstract
Category
Zend  
Copyright
Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)  
License
New BSD License  

Constants

>VConstant  STANDARD = 'DECIMAL'
>VConstant  BINARY = 'BINARY'
>VConstant  TERNARY = 'TERNARY'
>VConstant  QUATERNARY = 'QUATERNARY'
>VConstant  QUINARY = 'QUINARY'
>VConstant  SENARY = 'SENARY'
>VConstant  SEPTENARY = 'SEPTENARY'
>VConstant  OCTAL = 'OCTAL'
>VConstant  NONARY = 'NONARY'
>VConstant  DECIMAL = 'DECIMAL'
>VConstant  DUODECIMAL = 'DUODECIMAL'
>VConstant  HEXADECIMAL = 'HEXADECIMAL'
>VConstant  ROMAN = 'ROMAN'

Properties

>VPropertyprivatearray $_roman = array('I' => 1, 'A' => 4, 'V' => 5, 'B' => 9, 'X' => 10, 'E' => 40, 'L' => 50, 'F' => 90, 'C' => 100, 'G' => 400, 'D' => 500, 'H' => 900, 'M' => 1000, 'J' => 4000, 'P' => 5000, 'K' => 9000, 'Q' => 10000, 'N' => 40000, 'R' => 50000, 'W' => 90000, 'S' => 100000, 'Y' => 400000, 'T' => 500000, 'Z' => 900000, 'U' => 1000000)
static
Definition of all roman signs
Default valuearray('I' => 1, 'A' => 4, 'V' => 5, 'B' => 9, 'X' => 10, 'E' => 40, 'L' => 50, 'F' => 90, 'C' => 100, 'G' => 400, 'D' => 500, 'H' => 900, 'M' => 1000, 'J' => 4000, 'P' => 5000, 'K' => 9000, 'Q' => 10000, 'N' => 40000, 'R' => 50000, 'W' => 90000, 'S' => 100000, 'Y' => 400000, 'T' => 500000, 'Z' => 900000, 'U' => 1000000)Details
Type
array
>VPropertyprivatearray $_romanconvert = array('/_V/' => '/P/', '/_X/' => '/Q/', '/_L/' => '/R/', '/_C/' => '/S/', '/_D/' => '/T/', '/_M/' => '/U/', '/IV/' => '/A/', '/IX/' => '/B/', '/XL/' => '/E/', '/XC/' => '/F/', '/CD/' => '/G/', '/CM/' => '/H/', '/M_V/' => '/J/', '/MQ/' => '/K/', '/QR/' => '/N/', '/QS/' => '/W/', '/ST/' => '/Y/', '/SU/' => '/Z/')
static
Convertion table for roman signs
Default valuearray('/_V/' => '/P/', '/_X/' => '/Q/', '/_L/' => '/R/', '/_C/' => '/S/', '/_D/' => '/T/', '/_M/' => '/U/', '/IV/' => '/A/', '/IX/' => '/B/', '/XL/' => '/E/', '/XC/' => '/F/', '/CD/' => '/G/', '/CM/' => '/H/', '/M_V/' => '/J/', '/MQ/' => '/K/', '/QR/' => '/N/', '/QS/' => '/W/', '/ST/' => '/Y/', '/SU/' => '/Z/')Details
Type
array
>VPropertyprotectedarray $_units = array('BINARY' => array(2, '⑵'), 'TERNARY' => array(3, '⑶'), 'QUATERNARY' => array(4, '⑷'), 'QUINARY' => array(5, '⑸'), 'SENARY' => array(6, '⑹'), 'SEPTENARY' => array(7, '⑺'), 'OCTAL' => array(8, '⑻'), 'NONARY' => array(9, '⑼'), 'DECIMAL' => array(10, '⑽'), 'DUODECIMAL' => array(12, '⑿'), 'HEXADECIMAL' => array(16, '⒃'), 'ROMAN' => array(99, ''), 'STANDARD' => 'DECIMAL')
Calculations for all number units
Default valuearray('BINARY' => array(2, '⑵'), 'TERNARY' => array(3, '⑶'), 'QUATERNARY' => array(4, '⑷'), 'QUINARY' => array(5, '⑸'), 'SENARY' => array(6, '⑹'), 'SEPTENARY' => array(7, '⑺'), 'OCTAL' => array(8, '⑻'), 'NONARY' => array(9, '⑼'), 'DECIMAL' => array(10, '⑽'), 'DUODECIMAL' => array(12, '⑿'), 'HEXADECIMAL' => array(16, '⒃'), 'ROMAN' => array(99, ''), 'STANDARD' => 'DECIMAL')Details
Type
array

Methods

methodpublic__construct(integer $value, string $type, string | \Zend_Locale $locale = null) : void

Zend_Measure_Abstract is an abstract class for the different measurement types

Parameters
NameTypeDescription
$valueinteger

Value

$typestring

(Optional) A Zend_Measure_Number Type

$localestring | \Zend_Locale

(Optional) A Zend_Locale

Throws
ExceptionDescription
\Zend_Measure_ExceptionWhen language is unknown
\Zend_Measure_ExceptionWhen type is unknown
methodprivate_fromDecimal(integer $value, string $type) : string

Convert input to type value string

Parameters
NameTypeDescription
$valueinteger

Input string

$typestring

Type to convert to

Returns
TypeDescription
string
Throws
ExceptionDescription
\Zend_Measure_ExceptionWhen more than 200 digits are calculated
methodprivate_toDecimal(integer $input, string $type) : string

Convert input to decimal value string

Parameters
NameTypeDescription
$inputinteger

Input string

$typestring

Type from which to convert to decimal

Returns
TypeDescription
string
methodpublicconvertTo(string $type, integer $round = 0,  $locale = null) : string

Alias function for setType returning the converted unit Default is 0 as this class only handles numbers without precision

Parameters
NameTypeDescription
$typestring

Type to convert to

$roundinteger

(Optional) Precision to add, will always be 0

$locale
Returns
TypeDescription
string
methodpublicsetType(string $type) : void

Set a new type, and convert the value

Parameters
NameTypeDescription
$typestring

New type to set

Throws
ExceptionDescription
\Zend_Measure_ExceptionWhen a unknown type is given
methodpublicsetValue(integer $value, string $type = null, string | \Zend_Locale $locale = null) : void

Set a new value

Parameters
NameTypeDescription
$valueinteger

Value

$typestring

(Optional) A Zend_Measure_Number Type

$localestring | \Zend_Locale

(Optional) A Zend_Locale Type

Throws
ExceptionDescription
\Zend_Measure_Exception
Documentation was generated by phpDocumentor 2.2.0 .