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

Размер файла в байтах - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Какую лучше установить программу на С++? http://www.cyberforum.ru/cpp-beginners/thread625550.html
Кто сможет подсказать? Я работаю со старой версией Borland C++ version 3.1. Соответственно, у меня все программы написаны на С++ и находятся в этой версии. Вопрос, какой новый программный пакет лучше установить, чтобы можно было использовать имеющие программы старой версии (Borland 3.1) подошли к новой версии?
C++ Вычислить произведение элементов массива, расположенных между максимальным и минимальным элементами В одномерном массиве, состоящем из n вещественных элементов, вычислить: 2) произведение элементов массива, расположенных между максимальным и минимальным элементами. Упорядочить элементы массива по возрастанию. http://www.cyberforum.ru/cpp-beginners/thread625536.html
Ошибка с выводом окончательного результата C++
написал мего простой код. при отладки программы нащёл очень большой баг. сейчас я расскажу в чём он заключается. программа спрашивает имя и фамилию. если ввод происходит на русском то вывод получается корявым. в чём проблема? int main() { setlocale(LC_ALL, "Russian"); string res; //возращение ответа string f; //возращение ответа cout << "Введите ваше имя: "; cin >>...
Разделение потоков C++
Нужно в главном потоке запустить 3 потока,дождаться их завершения,потом запустить ещё 3 и тоже дождаться их завершения,однако на деле идёт ожидание лишь одного потока. функция главного потока int i; //------------------------------------------------ //получаем данные //------------------------------------------------ for(i = 0;i < THREADCOUNT;i++) {
C++ Передача функциям строк http://www.cyberforum.ru/cpp-beginners/thread625468.html
Нужно отсортировать массив строк методом выбора. Вот функция которую я побровал написать, но она не проходит компиляцию. void SelectSort( char c, int size ) { int i, j, k; char x; for(i = 0; i < size; i++) // Номер текущего шага { k = i; x = c;
C++ Фракталы http://www.youtube.com/watch?v=n7JLHxBm0eY&feature=relmfu Как это делают? Да и вообще возможно ли написать код для увеличения фрактала в огромное количество раз? Сколько не пробовал (с программой ультра фрактал) - не больше 1020, - а дальше глючит! Вот вопрос: можно ли нарисовать красочное множество мандельброта, как здесь и в разрешении 19200х10800 сохранить в формате png:... подробнее

Показать сообщение отдельно
alsav22
5284 / 4803 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
19.07.2012, 09:10     Размер файла в байтах
Копирование файла из массива нормально проходит. Если функцию не вызывать, а в main() сделать так:
C++
1
2
ofstream bm("3.bmp", ios::binary);
bm.write(arr, sizef);
Проверил такую вещь:
C++
1
2
3
ofstream bm("3.bmp", ios::binary);
bm.write(arr, 54);
bm.write(pol, sizef - 54);
Тоже всё нормально копируется в файл. Значит ошибка происходит при заполнении полей в функции.

Добавлено через 2 часа 41 минуту
Четвёртое поле заголовка файла неправильно: там должно быть смещение от начала файла и до битов изображения, т.е. размер файла - (32 * 32). Поэтому нужно написать так:
C++
1
2
unsigned int offset = (n + 54) - (x * y);
bm.write(reinterpret_cast<char*>(&offset), 4);
Добавлено через 52 минуты
Поле разрешений вот так надо:
C++
1
2
unsigned int resollutions[2]={0, 0};  
bm.write(reinterpret_cast<char*>(resollutions),8);
Добавлено через 9 минут
У меня работает.
КОД
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
#include <stdio.h>
#include <fstream>
#include <iostream>
using namespace std;
 
void f1(void)
{
    ofstream bm;
    bm.open("2.bmp");
 
    //заголовок файла
    unsigned char signature[2]={'B','M'};
    bm.write(reinterpret_cast<char*>(signature),2);
    unsigned int fileSize=14+40+32*32;
    bm.write(reinterpret_cast<char*>(&fileSize),4);
    unsigned int reserved=0;
    bm.write(reinterpret_cast<char*>(&reserved),4);
    unsigned int offset=14+40;
    bm.write(reinterpret_cast<char*>(&offset),4);
    //заголовок изображения 
    unsigned int headerSize=40;
    bm.write(reinterpret_cast<char*>(&headerSize),4);
    unsigned int picSize[2]={32,32};
    bm.write(reinterpret_cast<char*>(picSize),8);
    unsigned short colorPlane=1;
    bm.write(reinterpret_cast<char*>(&colorPlane),2);
    unsigned int bitPerPixel=8;
    bm.write(reinterpret_cast<char*>(&bitPerPixel),2);
    unsigned int tipeOfComp=0;
    bm.write(reinterpret_cast<char*>(&tipeOfComp),4);
    unsigned int imgSize=32*32;
    bm.write(reinterpret_cast<char*>(&imgSize),4);
    unsigned int resollutions[2]={2795,2795};
    bm.write(reinterpret_cast<char*>(&resollutions),8);
    unsigned int pltColor=0;
    bm.write(reinterpret_cast<char*>(&pltColor),4);
    unsigned int impColor=0;
    bm.write(reinterpret_cast<char*>(&impColor),4);
 
    unsigned char pol;
    for(size_t i=0;i<picSize[0];i++)
    {
        for(size_t j=0;j<picSize[1];j++)
        {
            pol=rand()%256;
            bm.write(reinterpret_cast<char*>(&pol),1);
        }
    }
    
 
    //fr.close();
    bm.close();
}
 
void f2(char arr[],int x, int y, int n)
{
    ofstream bm("3.bmp", ios::binary);
    
    //заголовок файла
    unsigned char signature[2]={'B','M'};
    bm.write(reinterpret_cast<char*>(signature),2);
    unsigned int fileSize=(n + 54);
    bm.write(reinterpret_cast<char*>(&fileSize),4);
    unsigned int reserved=0;
    bm.write(reinterpret_cast<char*>(&reserved),4);
    unsigned int offset = (n + 54) - (x * y);
    bm.write(reinterpret_cast<char*>(&offset), 4);
    
    //заголовок изображения 
    unsigned int headerSize = 40;
    bm.write(reinterpret_cast<char*>(&headerSize),4);
    unsigned int picSize[2]={x, y};
    bm.write(reinterpret_cast<char*>(picSize),8);
    unsigned short colorPlane=1;
    bm.write(reinterpret_cast<char*>(&colorPlane),2);
    unsigned int bitPerPixel=8;
    bm.write(reinterpret_cast<char*>(&bitPerPixel),2);
    unsigned int tipeOfComp=0;
    bm.write(reinterpret_cast<char*>(&tipeOfComp),4);
    unsigned int imgSize=x * y;
    bm.write(reinterpret_cast<char*>(&imgSize),4);
    unsigned int resollutions[2]={0, 0};  
    bm.write(reinterpret_cast<char*>(resollutions),8);
    unsigned int pltColor=0;
    bm.write(reinterpret_cast<char*>(&pltColor),4);
    unsigned int impColor=0;
    bm.write(reinterpret_cast<char*>(&impColor),4);
 
    bm.write(arr, n);
    bm.close();
}
 
int main()
{
    printf("File contan\n");
    
    ifstream fr("1.bmp",ios::binary);//открыли файл
        if(fr==NULL)
        {
        return 0;
        }
        fr.seekg(0, ios::end); // если курсор в начале файла, перемещаем курсор в конец файла.
        int sizef = fr.tellg(); // функция выдаст конечное положнние курсора относительно начала файла в байтах.
        fr.seekg(0, ios::beg); // возвращаем курсор в начало файла.
     
     char arr[3000];//массив куда я буду перегонять фаил
    
    fr.read(arr, sizef);//чтение в место. sizef  размер файла.
    //cout << fr.gcount() << endl;// сколько байт считано из файла в массив.
    fr.close();
    
    printf("%c %c",arr[0],arr[1]);
    
    char pol[3000];//массив куда я буду загонять палитру изображения
    int n = 0;
    for(int i = 54, j = 0; i < sizef; i++, j++)// собственно сама палитра
    {
        n++;
        pol[j] = arr[i];
    }
    
    f2(pol, 32, 32, n);//функция должна нарисовать ещё одно изображие копию первого
    
    char asd[10];
    scanf(asd);
    return 0;
}


Добавлено через 16 минут
Если поставить другое разрешение в "заголовке изображения", тоже нормально копируется. На что это влияет не понял. Но в файле 1.bmp, оно нулевое, поэтому, для точности совпадения, и в 3.bmp поставил нули.
 
Текущее время: 20:39. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru