| | <?php |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| |
|
| | namespace PHPQRCode; |
| |
|
| | class QRtools { |
| |
|
| | |
| | public static function binarize($frame) |
| | { |
| | $len = count($frame); |
| | foreach ($frame as &$frameLine) { |
| |
|
| | for($i=0; $i<$len; $i++) { |
| | $frameLine[$i] = (ord($frameLine[$i])&1)?'1':'0'; |
| | } |
| | } |
| |
|
| | return $frame; |
| | } |
| |
|
| | |
| | public static function tcpdfBarcodeArray($code, $mode = 'QR,L', $tcPdfVersion = '4.5.037') |
| | { |
| | $barcode_array = array(); |
| |
|
| | if (!is_array($mode)) |
| | $mode = explode(',', $mode); |
| |
|
| | $eccLevel = 'L'; |
| |
|
| | if (count($mode) > 1) { |
| | $eccLevel = $mode[1]; |
| | } |
| |
|
| | $qrTab = QRcode::text($code, false, $eccLevel); |
| | $size = count($qrTab); |
| |
|
| | $barcode_array['num_rows'] = $size; |
| | $barcode_array['num_cols'] = $size; |
| | $barcode_array['bcode'] = array(); |
| |
|
| | foreach ($qrTab as $line) { |
| | $arrAdd = array(); |
| | foreach(str_split($line) as $char) |
| | $arrAdd[] = ($char=='1')?1:0; |
| | $barcode_array['bcode'][] = $arrAdd; |
| | } |
| |
|
| | return $barcode_array; |
| | } |
| |
|
| | |
| | public static function clearCache() |
| | { |
| | self::$frames = array(); |
| | } |
| |
|
| | |
| | public static function buildCache() |
| | { |
| | QRtools::markTime('before_build_cache'); |
| |
|
| | $mask = new QRmask(); |
| | for ($a=1; $a <= Constants::QRSPEC_VERSION_MAX; $a++) { |
| | $frame = QRspec::newFrame($a); |
| | if (Constants::QR_IMAGE) { |
| | $fileName = Constants::QR_CACHE_DIR.'frame_'.$a.'.png'; |
| | QRimage::png(self::binarize($frame), $fileName, 1, 0); |
| | } |
| |
|
| | $width = count($frame); |
| | $bitMask = array_fill(0, $width, array_fill(0, $width, 0)); |
| | for ($maskNo=0; $maskNo<8; $maskNo++) |
| | $mask->makeMaskNo($maskNo, $width, $frame, $bitMask, true); |
| | } |
| |
|
| | QRtools::markTime('after_build_cache'); |
| | } |
| |
|
| | |
| | public static function log($outfile, $err) |
| | { |
| | if (Constants::QR_LOG_DIR !== false) { |
| | if ($err != '') { |
| | if ($outfile !== false) { |
| | file_put_contents(Constants::QR_LOG_DIR.basename($outfile).'-errors.txt', date('Y-m-d H:i:s').': '.$err, FILE_APPEND); |
| | } else { |
| | file_put_contents(Constants::QR_LOG_DIR.'errors.txt', date('Y-m-d H:i:s').': '.$err, FILE_APPEND); |
| | } |
| | } |
| | } |
| | } |
| |
|
| | |
| | public static function dumpMask($frame) |
| | { |
| | $width = count($frame); |
| | for($y=0;$y<$width;$y++) { |
| | for($x=0;$x<$width;$x++) { |
| | echo ord($frame[$y][$x]).','; |
| | } |
| | } |
| | } |
| |
|
| | |
| | public static function markTime($markerId) |
| | { |
| | list($usec, $sec) = explode(" ", microtime()); |
| | $time = ((float)$usec + (float)$sec); |
| |
|
| | if (!isset($GLOBALS['qr_time_bench'])) |
| | $GLOBALS['qr_time_bench'] = array(); |
| |
|
| | $GLOBALS['qr_time_bench'][$markerId] = $time; |
| | } |
| |
|
| | |
| | public static function timeBenchmark() |
| | { |
| | self::markTime('finish'); |
| |
|
| | $lastTime = 0; |
| | $startTime = 0; |
| | $p = 0; |
| |
|
| | echo '<table cellpadding="3" cellspacing="1"> |
| | <thead><tr style="border-bottom:1px solid silver"><td colspan="2" style="text-align:center">BENCHMARK</td></tr></thead> |
| | <tbody>'; |
| |
|
| | foreach($GLOBALS['qr_time_bench'] as $markerId=>$thisTime) { |
| | if ($p > 0) { |
| | echo '<tr><th style="text-align:right">till '.$markerId.': </th><td>'.number_format($thisTime-$lastTime, 6).'s</td></tr>'; |
| | } else { |
| | $startTime = $thisTime; |
| | } |
| |
|
| | $p++; |
| | $lastTime = $thisTime; |
| | } |
| |
|
| | echo '</tbody><tfoot> |
| | <tr style="border-top:2px solid black"><th style="text-align:right">TOTAL: </th><td>'.number_format($lastTime-$startTime, 6).'s</td></tr> |
| | </tfoot> |
| | </table>'; |
| | } |
| |
|
| | } |
| |
|
| | QRtools::markTime('start'); |
| |
|