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

Чтение BMP файла - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Двухпутевое слияние)))си++ http://www.cyberforum.ru/cpp/thread201268.html
#include <conio.h> #include <iostream.h> #include <stdlib.h> void clrscr(void); void main() { clrscr(); randomize(); int i,j,n,l,r,temp,split,mas, mas2; for(i=0;i<12;i++)
C++ Невырожденный треугольник Дан набор из N отрезков различной длины. Сколькими способами можно выбрать из этих отрезков три, из которых можно составить (невырожденный) треугольник? Длины сторон невырожденного треугольника связаны следующими неравенствами: a<b+c b<c+a c<a+b Программа должна вывести одно число - искомое количество способов. Собственно вопрос в следующем: количество отрезков и длину ввести не... http://www.cyberforum.ru/cpp/thread200942.html
с++ такое k, для которого можно построить множество C++
Помогите пожалуйста решить задачу с++!!! Задано семейство множеств букв. Найти такое k, для которого можно построить множество, состоящее из k букв, причем каждая из них принадлежит ровно k множествам заданного семейства. Рекомендации. (Паскаль) Для каждой буквы заведем отдельный 'черпак', в который будем 'складывать' букву. Это можно сделать, используя массив А из 255 элементов. При этом...
C++ Работа с IP
Необходимо написать программму, которая сканит заданное количество ип одновременно, и имеет свой конфиг + интерфейс.....под винду....парни, как задать сканирование? с интерфейсом и конфигом разберусь...а вот с ип не сталкивался в с++
C++ С++ не разобраться http://www.cyberforum.ru/cpp/thread198733.html
Помогите разобраться с задачей!!!!Задали на контрольную я ее сделал по шаблону она идет но я не все поня вней!!Кто че знает напишите плиз!!Заранее спосибо Условие: Написать программу обработки файла типа запись, содержащую следующие пункты меню: «Создание», «Просмотр», «Коррекция» (добавление новых данных или редактирование старых), «Решение индивидуального задания». Каждая запись должна...
C++ Вычисление налога Требуется составить отладить и выполнить программу, которая вычисляет налог на предлагаемый в индивидуальном задании уча¬сток, содержащий земельные угодья и пруды. Программу следует разработать в форме проекта. Для выполнения работы необходимо: 1) разделить предлагаемый участок на фрагменты простой формы (прямоугольник, треугольник, трапеция); 2) составить функции, вычисляющие площади... подробнее

Показать сообщение отдельно
solyr
1 / 1 / 0
Регистрация: 14.05.2010
Сообщений: 12

Чтение BMP файла - C++

01.12.2010, 16:52. Просмотров 6010. Ответов 1
Метки (Все метки)

Пишу программу в которой необходимо считать заголовок BMP файла. Файл безпалитровый, глубина цвета 24, то есть по 8 бит каждой составляющей RGB. Заголовок считывается не правильно почему то. Структура заголовка у меня объявлена правильно.

Считываю вызовом fread(&BMPHeader,sizeof(TBMPHeader),1,f);

Мне надо сохранить каждый канал изображения (красный, зеленый и синий) как отдельное растровое изображение.

Создаю три файла и записываю в них считанный заголовок, далее для каждого отдельного канала обнуляю две составляющии RGB, что получить одноканальное изображение. У меня все правильно записывается тока размеры файлов почему огромные. За 100 мегабит превышают, хотя исходный файл считывается весит всего 2-3 метра.

Формат заголовка:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
struct TBMPHeader{
    //заголовок файла
    short Type;          //сигнатура BM 0x4D42
    long  Size;          //размер файла в байтах 3*H*W+54
    long  Reserved;      //зарезервировано 0
    long  OffsetBits;    //смещение изображения от начала файла 54
    //информационный заголовок
    long  SizeH;         //размер заголовка 40 информационного заголовка
    long  Width;         //ширина изображения
    long  Height;        //высота изображения   
    short Planes;        //число плоскостей 1
    short BitCount;      //глубина цвета, бит на точку 24
    long  Compression;   //тип еомпрессии(0 - несжатое изображение)
    long  SizeImage;     //разиер изображения, байт 3*W*H
    long  XPelsPerMeter; //горизонтальное разрешение, точка на метр 0
    long  YPelsPerMeter; //вертикальное разрешение, точка на метр 0
    long  ColorUsed;     //число используемых цветов 0
    long  ColorImportant;//число основных цветов 0
};
Привожу исходный код процедуры: Проца пока реализована без выравнивания по щирине. Там кратность 4 не пока не учитывается. Засылаю входной файл сразу кратный 4 ем ширине. После допишу что нужно, но вот ошибка с размером и чет заголок не правильно считывается

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
void ConvertBMPFile(char *fname){
    TBMPHeader BMPHeader;
    FILE *f,*rf,*gf,*bf;
    if ((f = fopen(fname,"rb")) == NULL){
        cout<<"Ошибка открытия файла";
        return;
    }
    fread(&BMPHeader,sizeof(TBMPHeader),1,f);
    //if (Header.BitCount == 24) {
        if ((rf = fopen("red.bmp","wb")) == NULL){
            cout<<"Ошибка открытия файла";
            return;
        }
        if ((gf = fopen("green.bmp","wb")) == NULL){
            cout<<"Ошибка открытия файла";
            return;
        }
        if ((bf = fopen("blue.bmp","wb")) == NULL){
            cout<<"Ошибка открытия файла";
            return;
        }
        fwrite(&BMPHeader,sizeof(TBMPHeader),1,rf);
        fwrite(&BMPHeader,sizeof(TBMPHeader),1,gf);
        fwrite(&BMPHeader,sizeof(TBMPHeader),1,bf);
        
        TBGR *inBGR  = new TBGR[BMPHeader.Width]; //массив указателей на слова
        TBGR *inBGRr = new TBGR[BMPHeader.Width];
        TBGR *inBGRg = new TBGR[BMPHeader.Width];
        TBGR *inBGRb = new TBGR[BMPHeader.Width];
 
        cout<<"Ждем ...";
 
        while(!feof(f)){
            fread(inBGR,3*BMPHeader.Width,1,f);
            for(int i=0;i<BMPHeader.Width-1;i++){
                inBGRr[i] = inBGR[i];
                inBGRg[i] = inBGR[i];
                inBGRb[i] = inBGR[i];
            }   
            for(int i=0;i<BMPHeader.Width-1;i++){
                inBGRr[i].B = 0;
                inBGRr[i].G = 0;
            }   
            for(int i=0;i<BMPHeader.Width-1;i++){
                inBGRg[i].B = 0;
                inBGRg[i].R = 0;
            }   
            for(int i=0;i<BMPHeader.Width-1;i++){
                inBGRb[i].R = 0;
                inBGRb[i].G = 0;
            }   
            fwrite(inBGRr,3*BMPHeader.Width,1,rf);
            fwrite(inBGRg,3*BMPHeader.Width,1,gf);
            fwrite(inBGRb,3*BMPHeader.Width,1,bf);
        }
        fclose(rf);
        fclose(gf);
        fclose(bf);
    //} else {
    //  cout<<"Файл палитровый !!!";
    //}
    fclose(f);
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru