(PHP 5 >= 5.5.0, PHP 7, PHP 8, PECL >= 3.0.0a1)
IntlCalendar::setTimeZone — Define o fuso horário usado por este calendário
Estilo orientado a objetos
Estilo procedural
$calendar
, IntlTimeZone|DateTimeZone|string|null $timezone
): boolDefine um novo fuso horário para este calendário. O horário representado pelo objeto é preservado em detrimento dos valores de campo.
calendar
Uma instância de IntlCalendar.
timezone
O novo fuso horário a ser usado por este calendário. Pode ser especificado das seguintes maneiras:
null
, neste caso o fuso horário padrão será usado, como especificado na
configuração ini date.timezone ou
através da função date_default_timezone_set() e como
retornado por date_default_timezone_get().
Um objeto IntlTimeZone, que será usado diretamente.
Um objeto DateTimeZone. Seu identificador será extraído e um objeto de fuso horário ICU será criado; o fuso horário será apoiado pelo banco de dados da ICU, não pelo do PHP.
Uma string, que deve ser um identificador de fuso horário ICU válido.
Consulte a função IntlTimeZone::createTimeZoneIDEnumeration(). Deslocamentos
puros como "GMT+08:30"
também são aceitos.
Exemplo #1 IntlCalendar::setTimeZone()
<?php
ini_set('date.timezone', 'Europe/Lisbon');
ini_set('intl.default_locale', 'es_ES');
$cal = new IntlGregorianCalendar(2013, 5 /* maio */, 1, 12, 0, 0);
echo IntlDateFormatter::formatObject($cal, IntlDateFormatter::FULL), "\n";
echo "(instant {$cal->getTime()})\n";
$cal->setTimeZone(IntlTimeZone::getGMT());
echo IntlDateFormatter::formatObject($cal, IntlDateFormatter::FULL), "\n";
echo "(instant {$cal->getTime()})\n";
$cal->setTimeZone('GMT+03:33');
echo IntlDateFormatter::formatObject($cal, IntlDateFormatter::FULL), "\n";
echo "(instant {$cal->getTime()})\n";
O exemplo acima produzirá:
sábado, 1 de junio de 2013 12:00:00 Hora de verano de Europa occidental (instant 1370084400000) sábado, 1 de junio de 2013 11:00:00 GMT (instant 1370084400000) sábado, 1 de junio de 2013 14:33:00 GMT+03:33 (instant 1370084400000)