Skip to content

Commit

Permalink
Address feedback by ruediger on PR ruediger#75
Browse files Browse the repository at this point in the history
  • Loading branch information
Geoffrey-A committed Jun 21, 2020
1 parent 3a10420 commit a19e141
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 15 deletions.
2 changes: 1 addition & 1 deletion CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ include(CheckCXXSourceCompiles)
include(CheckCXXSourceRuns)

set(CMAKE_C_FLAGS "-std=gnu99")
set(CMAKE_CXX_FLAGS "-ansi -pedantic -Wall -Wextra -Wno-long-long -std=gnu++11")
set(CMAKE_CXX_FLAGS "-ansi -pedantic -Wall -Wextra -Wno-long-long -std=gnu++11 -DINVERT_IMAGES")

set(CMAKE_CXX_FLAGS_RELEASE "-O3 -mtune=native -march=native -DNDEBUG -fomit-frame-pointer -ffast-math") # TODO -Ofast GCC 4.6
set(CMAKE_C_FLAGS_RELEASE ${CMAKE_CXX_FLAGS_RELEASE})
Expand Down
34 changes: 20 additions & 14 deletions src/vobsub2srt.c++
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,19 @@ using namespace tesseract;
#define TESSERACT_DATA_PATH TESSERACT_DEFAULT_PATH
#endif

struct ImageInverter {
ImageInverter(const unsigned char* image, size_t image_size)
: inverted_image(new unsigned char[image_size])
{
for (size_t i = 0; i < image_size; ++i) {
inverted_image[i] = 255 - image[i];
}
}
~ImageInverter() { delete[] inverted_image; }

unsigned char* inverted_image;
};

int main(int argc, char **argv) {
bool dump_images = false;
bool verb = false;
Expand Down Expand Up @@ -265,24 +278,17 @@ int main(int argc, char **argv) {
<< start_pts << ")\n";
}


// While tesseract version 3.05 (and older) handle inverted image (dark background and light text) without problem, for 4.x version use dark text on light background.
// While tesseract version 3.05 (and older) handle inverted image (dark
// background and light text) without problem, for 4.x version use dark
// text on light background.
// https://github.com/tesseract-ocr/tesseract/wiki/ImproveQuality#inverting-images

bool inverting_images = true;
#ifdef INVERT_IMAGES

if (inverting_images) {
int size_r = width * height;
unsigned char* image_rev = new unsigned char[size_r];
for (int i = 0; i < size_r; i++)
{
int val = static_cast<int>(image[i]);
unsigned char cz = (255 - val);
image_rev[i] = cz;
}
ImageInverter inverter(image, width*height);
image = inverter.inverted_image;

image = image_rev;
}
#endif // INVERT_IMAGES

if(dump_images) {
dump_pgm(subname, sub_counter, width, height, stride, image, image_size);
Expand Down

0 comments on commit a19e141

Please sign in to comment.