From 14377d1e49133e4831aeba1edf451060f40e11f5 Mon Sep 17 00:00:00 2001 From: ArashPartow Date: Wed, 4 Sep 2019 03:12:37 +1000 Subject: [PATCH] C++ Bitmap Image Reader Writer Library http://partow.net/programming/bitmap/index.html --- bitmap_image.hpp | 30 +++++++++++++++++++----------- 1 file changed, 19 insertions(+), 11 deletions(-) diff --git a/bitmap_image.hpp b/bitmap_image.hpp index e7c7220..5cdcff6 100644 --- a/bitmap_image.hpp +++ b/bitmap_image.hpp @@ -434,7 +434,8 @@ class bitmap_image if (!stream) { - std::cerr << "bitmap_image::save_image(): Error - Could not open file " << file_name << " for writing!" << std::endl; + std::cerr << "bitmap_image::save_image(): Error - Could not open file " + << file_name << " for writing!" << std::endl; return; } @@ -1511,7 +1512,8 @@ class bitmap_image if (!stream) { - std::cerr << "bitmap_image::load_bitmap() ERROR: bitmap_image - file " << file_name_ << " not found!" << std::endl; + std::cerr << "bitmap_image::load_bitmap() ERROR: bitmap_image - " + << "file " << file_name_ << " not found!" << std::endl; return; } @@ -1529,36 +1531,41 @@ class bitmap_image if (bfh.type != 19778) { + std::cerr << "bitmap_image::load_bitmap() ERROR: bitmap_image - " + << "Invalid type value " << bfh.type << " expected 19778." << std::endl; + bfh.clear(); bih.clear(); stream.close(); - std::cerr << "bitmap_image::load_bitmap() ERROR: bitmap_image - Invalid type value " << bfh.type << " expected 19778." << std::endl; return; } if (bih.bit_count != 24) { + std::cerr << "bitmap_image::load_bitmap() ERROR: bitmap_image - " + << "Invalid bit depth " << bih.bit_count << " expected 24." << std::endl; + bfh.clear(); bih.clear(); stream.close(); - std::cerr << "bitmap_image::load_bitmap() ERROR: bitmap_image - Invalid bit depth " << bih.bit_count << " expected 24." << std::endl; - return; } if (bih.size != bih.struct_size()) { + std::cerr << "bitmap_image::load_bitmap() ERROR: bitmap_image - " + << "Invalid BIH size " << bih.size + << " expected " << bih.struct_size() << std::endl; + bfh.clear(); bih.clear(); stream.close(); - std::cerr << "bitmap_image::load_bitmap() ERROR: bitmap_image - Invalid BIH size " << bih.size << " expected " << bih.struct_size() << std::endl; - return; } @@ -1568,7 +1575,7 @@ class bitmap_image bytes_per_pixel_ = bih.bit_count >> 3; unsigned int padding = (4 - ((3 * width_) % 4)) % 4; - char padding_data[4] = {0,0,0,0}; + char padding_data[4] = { 0, 0, 0, 0 }; std::size_t bitmap_file_size = file_size(file_name_); @@ -1584,9 +1591,10 @@ class bitmap_image stream.close(); - std::cerr << "bitmap_image::load_bitmap() ERROR: bitmap_image - Mismatch between logical and physical sizes of bitmap. " << - "Logical: " << bitmap_logical_size << " " << - "Physical: " << bitmap_file_size << std::endl; + std::cerr << "bitmap_image::load_bitmap() ERROR: bitmap_image - " + << "Mismatch between logical and physical sizes of bitmap. " + << "Logical: " << bitmap_logical_size << " " + << "Physical: " << bitmap_file_size << std::endl; return; }