Mercurial > public > ostc_companion
annotate ostc45_icon.cpp @ 11:6fba58c4964b
Minor changes done by automatic style checker
| author | Ideenmodellierer |
|---|---|
| date | Mon, 12 Jan 2026 13:57:24 +0000 |
| parents | 115cfa4a3239 |
| children |
| rev | line source |
|---|---|
| 5 | 1 #include "ostc45_icon.h" |
| 2 | |
| 3 //OSTC45_Icon::OSTC45_Icon() {} | |
| 4 | |
| 5 #pragma pack(push, 1) | |
| 6 struct BMPFileHeader | |
| 7 { | |
| 8 uint16_t bfType; | |
| 9 uint32_t bfSize; | |
| 10 uint16_t bfReserved1; | |
| 11 uint16_t bfReserved2; | |
| 12 uint32_t bfOffBits; | |
| 13 }; | |
| 14 | |
| 15 struct BMPInfoHeader | |
| 16 { | |
| 17 uint32_t biSize; | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
18 int32_t biWidth; |
|
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
19 int32_t biHeight; |
| 5 | 20 uint16_t biPlanes; |
| 21 uint16_t biBitCount; | |
| 22 uint32_t biCompression; | |
| 23 uint32_t biSizeImage; | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
24 int32_t biXPelsPerMeter; |
|
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
25 int32_t biYPelsPerMeter; |
| 5 | 26 uint32_t biClrUsed; |
| 27 uint32_t biClrImportant; | |
| 28 }; | |
| 29 #pragma pack(pop) | |
| 30 | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
31 BmpToArray::BmpToArray(const QString &filename) |
| 5 | 32 { |
| 33 loadBMP(filename); | |
| 34 } | |
| 35 | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
36 void BmpToArray::loadBMP(const QString &filename) |
| 5 | 37 { |
| 38 QFile file(filename); | |
| 39 int dstY; | |
| 40 QByteArray rowBuffer; | |
| 41 bool topDown = false; | |
| 42 BMPFileHeader fileHeader; | |
| 43 BMPInfoHeader infoHeader; | |
| 44 | |
| 45 if (!file.open(QIODevice::ReadOnly)) | |
| 46 throw std::runtime_error("Cannot open BMP file"); | |
| 47 | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
48 if (file.read(reinterpret_cast<char *>(&fileHeader), sizeof(BMPFileHeader)) |
|
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
49 != sizeof(BMPFileHeader)) |
| 5 | 50 throw std::runtime_error("Failed to read BMP file header"); |
| 51 | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
52 if (file.read(reinterpret_cast<char *>(&infoHeader), sizeof(BMPInfoHeader)) |
|
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
53 != sizeof(BMPInfoHeader)) |
| 5 | 54 throw std::runtime_error("Failed to read BMP info header"); |
| 55 | |
| 56 if (fileHeader.bfType != 0x4D42) | |
| 57 throw std::runtime_error("Not a valid BMP file"); | |
| 58 | |
| 59 if (infoHeader.biBitCount != 8) | |
| 60 throw std::runtime_error("Only 8-bit BMP supported"); | |
| 61 if (infoHeader.biCompression != 0) | |
| 62 throw std::runtime_error("Compressed BMP not supported"); | |
| 63 | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
64 if (infoHeader.biWidth > 800) |
| 5 | 65 throw std::runtime_error("Only BMP with 800 or less horizontal pixels supported"); |
| 66 | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
67 if (infoHeader.biHeight > 480) |
| 5 | 68 throw std::runtime_error("Only BMP with 480 or less vertical pixels supported"); |
| 69 | |
| 70 // Width / Height | |
| 71 width = infoHeader.biWidth; | |
| 72 height = infoHeader.biHeight; | |
| 73 | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
74 if ((int32_t) height < 0) { |
|
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
75 height = -((int32_t) height); |
| 5 | 76 topDown = true; |
| 77 } | |
| 78 | |
| 79 // Palette | |
| 80 uint32_t colorCount = infoHeader.biClrUsed; | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
81 if (colorCount == 0) |
|
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
82 colorCount = 256; |
|
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
83 if (colorCount > 256) |
|
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
84 colorCount = 256; |
| 5 | 85 |
| 86 clut.resize(colorCount); | |
| 87 | |
| 88 for (uint32_t i = 0; i < colorCount; ++i) | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
89 file.read(reinterpret_cast<char *>(&clut[i]), 4); |
| 5 | 90 |
| 91 // CLUT in 32-Bit transform 0x00RRGGBB | |
| 92 clut32.resize(255, 0); | |
| 93 | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
94 for (uint32_t i = 0; i < colorCount && i < 255; ++i) { |
|
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
95 clut32[i] = (clut[i].r << 16) | (clut[i].g << 8) | (clut[i].b); |
| 5 | 96 } |
| 97 | |
| 98 // Pixel-Data | |
| 99 if (!file.seek(fileHeader.bfOffBits)) | |
| 100 throw std::runtime_error("Failed to seek to pixel data"); | |
| 101 | |
| 102 pixelData.resize(width * height); | |
| 103 | |
| 104 size_t rowSize = (width + 3) & ~3; // 4-Byte alignment | |
| 105 | |
| 106 rowBuffer.resize(rowSize); | |
| 107 | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
108 for (int y = 0; y < height; ++y) { |
| 5 | 109 if (file.read(rowBuffer.data(), rowSize) != rowSize) |
| 110 throw std::runtime_error("Failed to read BMP pixel row"); | |
| 111 | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
112 if (topDown) { |
| 5 | 113 dstY = height - 1 - y; |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
114 } else { |
| 5 | 115 dstY = y; |
| 116 } | |
| 117 | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
118 for (int x = 0; x < width; ++x) { |
|
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
119 pixelData[x * height + dstY] = static_cast<uint8_t>(rowBuffer[x]); |
| 5 | 120 } |
| 121 } | |
| 122 } | |
| 123 QByteArray BmpToArray::getTransferBytes() const | |
| 124 { | |
| 125 QByteArray out; | |
| 126 | |
| 127 out.reserve(clut32.size() * 4 + pixelData.size()); | |
| 128 | |
| 129 // CLUT (32 Bit, Little Endian) | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
130 for (uint32_t color : clut32) { |
|
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
131 out.append(static_cast<char>(color & 0xFF)); |
|
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
132 out.append(static_cast<char>((color >> 8) & 0xFF)); |
| 5 | 133 out.append(static_cast<char>((color >> 16) & 0xFF)); |
| 134 out.append(static_cast<char>((color >> 24) & 0xFF)); | |
| 135 } | |
| 136 | |
| 137 // Pixel (8 Bit) | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
138 out.append(reinterpret_cast<const char *>(pixelData.data()), pixelData.size()); |
| 5 | 139 |
| 140 return out; | |
| 141 } | |
| 142 | |
|
11
6fba58c4964b
Minor changes done by automatic style checker
Ideenmodellierer
parents:
5
diff
changeset
|
143 void BmpToArray::getImageXY(uint32_t *x, uint32_t *y) |
| 5 | 144 { |
| 145 *x = width; | |
| 146 *y = height; | |
| 147 } |
