Форум программистов, компьютерный форум CyberForum.ru

Класс 8-битное bmp изображение - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Бинарный поиск (бинарным поиском найти вводимую с клавиатуры букву) http://www.cyberforum.ru/cpp-beginners/thread886569.html
Дан текстовый файл. Необходимо бинарным поиском найти, вводимую с клавиатуры букву.
C++ надо найти и исправить ошибку Car.h #pragma once #include <string> using namespace std; class Car { protected: string marka; string model; http://www.cyberforum.ru/cpp-beginners/thread886568.html
Поменять местами максимальный и минимальный элементы в массиве C++
помогите пожалуйста, никак не получаются задачки... 2) Записать элементы массива Х, удовлетворяющие условию 1≤Xi≤2, подряд в массив Y. Поменять местами максимальный и минимальный элементы в массиве Y.
C++ Строковый массив (объявить пустой глобальный строковый массив из 16 элементов)
Подскажите, как объявить пустой глобальный строковый массив из 16 элементов? в качестве элементов будут указаны пути к графическим файлам на компьютере
C++ Функции. Переписать числа из файла f в файл g, проверяя число на удовлетворение какого-либо условия http://www.cyberforum.ru/cpp-beginners/thread886551.html
Необходимо переписать числа из файла f в файл g, проверяя число на удовлетворение какого-либо условия. Как осуществляется проверка условия? С массивами все понятно, а вот с файлами нет. Объясните пожалуйста.
C++ Не могу счтиать файлдо конца Здравствуйте,есть программа для передачи символов в азбуку Морзе,с клавиатурным вводомвсе хорошо но если считывать с файла ,то считывает только 1ю строку .Подскажите, пожалуйста как считать файл до конца с последующей заменой.Очень надо #include <iostream> #include <fstream> #include <string> using namespace std; int main() { char z; int b; подробнее

Показать сообщение отдельно
compl
1 / 1 / 0
Регистрация: 23.10.2012
Сообщений: 70
31.05.2013, 19:14     Класс 8-битное bmp изображение
Нужно написать класс, который красит bmp-файл в цвета российского флага. Сейчас красит только красный, что нужно изменить в этом куске:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
unsigned int n = h.bih.biHeight/3;
    unsigned int m = h.bih.biWidth;
 
    
    BYTE *a=new BYTE [3*n*m];
 
    for(int i=0;i<n*m;i++)
        a[i] = 0x4F;
    for(int i=n*m;i<2*n*m;i++)
        a[i] = 0xD2;
    for(int i=2*n*m;i<3*n*m;i++)
        a[i] = 0x4F;
    
    BMPfile.seekg(h.bh.bfOffbits, ios::beg);
    int counter = 0;
 
    while(counter != h.bih.biHeight)
    {
        BMPfile.write((char*)a, h.bih.biHeight);
        counter ++;
    }
Весь код:
bmp_structs.h

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
typedef unsigned short int word; 
typedef unsigned int dword;
#pragma pack(push)
#pragma pack(1)
 
struct BitMapHeader
{
word bfType;
dword bfSize;
word bfReserved1; 
word bfReserved2; 
dword bfOffbits;
};
typedef unsigned short int word; 
typedef unsigned int dword;
struct BitMapInfoHeader
{
dword biSize ; 
dword biWidth;
dword biHeight; 
word biPlanes; 
word biBitCount; 
dword biCompression; 
dword biSizeImage; 
dword biXPelPerMeter;
dword biYPelPerMeter;
dword biClrUsed; 
dword biClrImportant;
};
typedef unsigned char BYTE;
 
#pragma pack(pop)
 
struct tagRGBQUAD {
BYTE rgbBlue;
BYTE rgbGreen;
BYTE rgbRed;
BYTE rgbReserved;
};
BMP.h

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
#pragma once
#include <iostream>
#include <stdlib.h>
#include <fstream>
#include "bmp_structs.h"
using namespace std;
 
class BMP
{
public:
    BitMapHeader bh;
    BitMapInfoHeader bih;
    tagRGBQUAD RGBQuad[256];
public:
    BMP();
    void ReadQuad(tagRGBQUAD* RGB, int biSize, char* filename);
    void WriteQuad(tagRGBQUAD* RGB, int biSize, char* filename);
    void France_flag(char* filename);
 
    void read_BMP_info(char* filename);
    friend istream& operator >>(istream &binf, BMP &helpBMP);
    friend ostream& operator <<(ostream &binf, BMP &helpBMP);
    
    friend struct BitMapHeader;
    friend struct BitMapInfoHeader;
    friend struct tagRGBQUAD;
    ~BMP();
    
};
BMP.cpp

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#include "StdAfx.h"
#include "BMP.h"
 
 
BMP::BMP()
{
}
 
 
void BMP::ReadQuad(tagRGBQUAD* RGB, int biSize, char* filename)
{
    fstream f(filename, ios::binary | ios::out | ios::in | ios::ate);
    f.seekg(biSize, SEEK_SET);
    f.read((char*)RGB, sizeof(RGB));
    f.close();
}
void BMP::WriteQuad(tagRGBQUAD* RGB, int biSize, char* filename)
{
    fstream f(filename, ios::binary | ios::out | ios::in | ios::ate);
    f.seekg(biSize, SEEK_SET);
    f.write((char*)RGB, sizeof(RGB));
    f.close();
}
void BMP::read_BMP_info(char* filename)
{
    fstream f(filename, ios::binary | ios::out | ios::in);
    f.seekg(0, ios::beg);
    f.read((char*)& this->bh,sizeof(bh));
    f.read((char*)& this->bih,sizeof(bih));
    this->ReadQuad(RGBQuad, this->bih.biSize + 14, filename);
    f.close();
    
}
void BMP::flag(char* filename)
{
    BMP h;
 
    fstream BMPfile(filename, ios::binary | ios::out | ios::in);
    h.read_BMP_info(filename);
 
    unsigned int n = h.bih.biHeight/3;
    unsigned int m = h.bih.biWidth;
 
    
    BYTE *a=new BYTE [3*n*m];
 
    for(int i=0;i<n*m;i++)
        a[i] = 0x4F;
    for(int i=n*m;i<2*n*m;i++)
        a[i] = 0xD2;
    for(int i=2*n*m;i<3*n*m;i++)
        a[i] = 0x4F;
    
    BMPfile.seekg(h.bh.bfOffbits, ios::beg);
    int counter = 0;
 
    while(counter != h.bih.biHeight)
    {
        BMPfile.write((char*)a, h.bih.biHeight);
        counter ++;
    }
    
    BMPfile.close();
}
 
BMP::~BMP()
{
}
C++
1
2
3
4
5
6
7
8
9
#include "stdafx.h"
#include "BMP.h"
 
int _tmain(int argc, _TCHAR* argv[])
{
    BMP h;
    h.flag("1.bmp");
    return 0;
}
Добавлено через 1 час 22 минуты
Не надо, я уже сделал
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 08:20. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru