Назад | Начало урока | Вперед
Содержание

Глава 3 стр 30

Получаем матричное отображение bmp-файла

Вариант 1
// копируем посимвольно из файла в массив
// из массива в файл в 16-ричном виде
//получаем матричное изображение bmp-файла
#include <stdio.h>
#include <fstream>
#include <iostream.h>
#include <string.h>

void filter(int chislo, char &first_val, char &second_val){

int rez_h = 0;
int rez_l = 0;
rez_h = chislo/16;
if(rez_h>9){
switch(rez_h){
case 10 :
first_val = 'A'; break;
case 11 :
first_val = 'B'; break;
case 12 :
first_val = 'C'; break;
case 13 :
first_val = 'D'; break;
case 14 :
first_val = 'E'; break;
case 15 :
first_val = 'F'; break;
default:
break;
}
}
else{
switch(rez_h){
case 0 :
first_val = '0'; break;
case 1 :
first_val = '1'; break;
case 2 :
first_val = '2'; break;
case 3 :
first_val = '3'; break;
case 4 :
first_val = '4'; break;
case 5 :
first_val = '5'; break;
case 6 :
first_val = '6'; break;
case 7 :
first_val = '7'; break;
case 8 :
first_val = '8'; break;
case 9 :
first_val = '9'; break;
default:
break;
}
}
rez_l = chislo%16;
if(rez_l>9){
switch(rez_l){
case 10 :
second_val = 'A'; break;
case 11 :
second_val = 'B'; break;
case 12 :
second_val = 'C'; break;
case 13 :
second_val = 'D'; break;
case 14 :
second_val = 'E'; break;
case 15 :
second_val = 'F'; break;
default:
break;
}
}
else{
switch(rez_l){
case 0 :
second_val = '0'; break;
case 1 :
second_val = '1'; break;
case 2 :
second_val = '2'; break;
case 3 :
second_val = '3'; break;
case 4 :
second_val = '4'; break;
case 5 :
second_val = '5'; break;
case 6 :
second_val = '6'; break;
case 7 :
second_val = '7'; break;
case 8 :
second_val = '8'; break;
case 9 :
second_val = '9'; break;
default:
break;
}
}
}
***********************************
***********************************
int main( int argc,char* argv[]) {

ifstream from1("bukva.bmp");//открываем файл для считывания
if(!from1) {

cout<<"Vhodnoi fail ne naiden:" ;
return (1);

}
ofstream to1("text2" ); // open for writing
if(!to1) {
cout<<"Vyhodnoi fail ne naiden:" ;
to1.close(); // always pays to be tidy
return (1);
}
//////////////////
const int len = 3000;
char buf[len];
char *p = buf;//сорентируем указатель на начало массива buf

char buf1[2];
char *p1 = buf1;//сорентируем указатель на начало массива buf1

char ch;
int n = 0;

while (from1.get(ch)) {

buf1[0] = ch;
strcpy(p,p1); //вставим
p++;
n++;
if(n>=len)break;
}

/////////////////////////
int temp = 0;
int temp_l = 0;
int temp_h = 0;
int size_file = 0; //размер исходного bmp-файла (2-й, 3-й байты)
int chislo_str = 0; //размер картинки в байтах (34-й, 35-й байты)
int size_card = 0; //количество строк в картинке (22-й, 23-й байты)
int dlina_str = 0; //длина строки в выходном файле

char first_ch = ' ';
char second_ch = ' ';

//--------------------------------
//Считаем данные из массива в переменные
temp_l = (int)buf[2];
if(temp_l<0)

temp_l = 256+temp_l;
temp_h = (int)buf[3];
if(temp_h<0)
temp_h = 256+temp_h;
temp_h = 256*temp_h;
size_file = temp_h+temp_l;

temp_l = (int)buf[22];
if(temp_l<0)

temp_l = 256+temp_l;
temp_h = (int)buf[23];
if(temp_h<0)
temp_h = 256+temp_h;
temp_h = 256*temp_h;
chislo_str = temp_h+temp_l;

temp_l = (int)buf[34];
if(temp_l<0)

temp_l = 256+temp_l;
temp_h = (int)buf[35];
if(temp_h<0)
temp_h = 256+temp_h;
temp_h = 256*temp_h;
size_card = temp_h+temp_l;

dlina_str = size_card/chislo_str;
//-------------------------------------------------
//Выведем из масива в файл
int k = 0;
for(int i=54;i < size_file;i++){

temp = (int)buf[i];
if(temp<0)
temp = 256+temp;
filter(temp,first_ch,second_ch);
to1 << first_ch << second_ch ;
k++;
if(k==dlina_str){//перенос строки
k=0;
to1<< " " << endl ;
}
}
////////////////////
from1.close(); // always pays to be tidy
to1.close(); // always pays to be tidy

return 0;

}


Назад | Начало урока | Вверх | Вперед
Содержание

Hosted by uCoz