friendica-addons/tesseract/tesseract.php

39 lines
1 KiB
PHP
Raw Normal View History

2024-01-14 20:21:08 +01:00
<?php
/**
* Name: Tesseract OCR
* Description: Use OCR to get text from images
* Version: 0.1
* Author: Michael Vogel <http://pirati.ca/profile/heluecht>
*/
use Friendica\Core\Hook;
use Friendica\Core\Logger;
use Friendica\Core\System;
use thiagoalessio\TesseractOCR\TesseractOCR;
require_once __DIR__ . DIRECTORY_SEPARATOR . 'vendor' . DIRECTORY_SEPARATOR . 'autoload.php';
function tesseract_install()
{
Hook::register('ocr-detection', __FILE__, 'tesseract_ocr_detection');
Logger::notice('installed tesseract');
}
function tesseract_ocr_detection(&$media)
{
$ocr = new TesseractOCR();
try {
2024-01-22 19:01:51 +01:00
$languages = $ocr->availableLanguages();
if ($languages) {
2024-12-10 00:08:31 +01:00
/** @phpstan-ignore-next-line ignore call of \thiagoalessio\TesseractOCR\Option::lang() */
2024-01-22 19:01:51 +01:00
$ocr->lang(implode('+', $languages));
}
2024-01-14 20:21:08 +01:00
$ocr->tempDir(System::getTempPath());
$ocr->imageData($media['img_str'], strlen($media['img_str']));
$media['description'] = $ocr->run();
} catch (\Throwable $th) {
Logger::info('Error calling TesseractOCR', ['message' => $th->getMessage()]);
2024-12-10 00:08:31 +01:00
}
2024-01-14 20:21:08 +01:00
}