Pages

Sunday, 29 April 2012

C++ PROJECT-IV DISPLAY BMP

DISPLAY BMP IMAGE IN C LANGUAGE
Code :
#include <stdio.h>
#include <conio.h>
#include <dos.h>
#define DECLARE

#define VGALOW 0x101

typedef unsigned int UINT;
typedef unsigned char UCHAR;
struct VgaInfoBlock {
 char signature[4];
 short version;
 char far  *oemname;
long capabilities;
unsigned far *modes;
char buffer[238];
};

typedef struct
{
 char red;
char green;
char blue;
}RGB;

 struct VgaModeInfoBlock
{
 UINT ModeAttributes;
UCHAR WinAAttributes;
UCHAR WinBAttributes;
UINT WindowGranularity;
UINT WinSize;
UINT WinASegment;
UINT WinBSegment;
void (far *WinFuncPtr)(void);
UINT BytesperScanLine;
UINT XResolution;
UINT YResolution;
UCHAR XCharSize;
UCHAR YCharSize;
UCHAR NumberOfPlanes;
UCHAR BitsPerPixel;
UCHAR NumberOfBanks;
UCHAR MemoryModel;
UCHAR BankSize;
UCHAR NumberOfImagePages;
UCHAR Reserved1;
UCHAR RedMaskSize;
UCHAR RedMaskPosition;
UCHAR GreenMaskSize;
UCHAR GreenMaskPosition;
UCHAR BlueMaskSize;
UCHAR BlueMaskPosition;
UCHAR ReservedMaskSize;
UCHAR ReservedMskPosition;
UCHAR DirectScreenModeInfo;
UCHAR Reserved2[216];
}modeinfo;

typedef enum
{
 memPL = 3,
memPK = 4,
memRGB = 6,
memYUV = 7
}memModels;

typedef struct tagBMPHEADER
{
 unsigned char bftype[2];
unsigned long bfsize;
unsigned int bfres1,bfres2;
unsigned long bfoffbits;
unsigned long bisize,biwidth,biheight;
unsigned int biplanes,bibitcount;
unsigned long
bicompression,bisizeimage,bixpelspermeter,biypelspermeter;
unsigned long biclrused,biclrimportant;
}BMPHEADER;
typedef struct tagRGBQUAD
{
 unsigned char blue,green,red,rgbreserved;
}RGBQUAD;
typedef struct tagBMPINFO
{
 BMPHEADER bmiheader;
 RGBQUAD bmicolors[256];
}BMPINFO;

DECLARE int maxx,maxy;
DECLARE int xres,yres;
DECLARE int bytesperline;
DECLARE int curbank;
DECLARE unsigned int bankshift;
DECLARE int oldmode;
DECLARE char far *screenptr;
DECLARE void (far *bankswitch)(void);
DECLARE int pcolor,xp,yp;
DECLARE int ccolor;

DECLARE int GetVesaMode(void);
DECLARE void SetVseaMode(int);
DECLARE void setbank(int);
DECLARE void SetPalette(RGB pal[256]);
DECLARE void vinitgraph(int);
DECLARE void setwidth(int);
DECLARE void vclosegraph(void);
DECLARE void startaddr(int *,int *,int);
DECLARE void vputpixel(int,int,int);
DECLARE void SetPalette(RGB color[256]);
DECLARE char *ReadMemString(char far *);
DECLARE void showbitmap(char *infname,int xs,int ys);


void Vesa(int state)
{
 union REGS reg;
reg.x.ax=0x4FFF;
reg.h.dl=(char ) state;
int86(0x10,®,®);
return ;
}

int GetSvgaInfo(struct VgaInfoBlock far *buffer)
{
 struct REGPACK reg;
reg.r_ax = 0x4F00;
reg.r_es = FP_SEG(buffer);
reg.r_di = FP_OFF(buffer);
intr(0x10,®);
if(reg.r_ax==0x004F)
 return 0;
else
 return 1;
}

char *ReadMemString(char far *pointer)
{
 char string[200];
int i=0;
while(*pointer)
{
 string[i]=*pointer;
 pointer++;
i++;
}
string[i]=0;
return string;
}

int GetSvgaModeInfo(int mode,struct VgaModeInfoBlock far *buffer)
{
 struct REGPACK reg;
reg.r_ax = 0x4F01;
reg.r_es = FP_SEG(buffer);
reg.r_di = FP_OFF(buffer);
reg.r_cx=mode;
intr(0x10,®);
if(reg.r_ax!=0x004F)
 return 1;
else
 return 0;
}

int GetVesaMode(void)
{
 union REGS in,out;
in.x.ax=0x4F03;
int86(0x10,&in,&out);
return out.x.bx;
}

void SetVesaMode(int mode)
{

struct REGPACK reg;
oldmode = GetVesaMode();
reg.r_ax = 0x4F02;
reg.r_bx=mode;
intr(0x10,®);
GetSvgaModeInfo(GetVesaMode(), &modeinfo);

xres = modeinfo.XResolution;
yres = modeinfo.YResolution;

maxx=xres;
bytesperline = modeinfo.BytesperScanLine;
bankshift = 0;
while((unsigned ) (64 >> bankshift)!= modeinfo.WindowGranularity)
 bankshift++;
bankswitch = modeinfo.WinFuncPtr;
curbank=-1;
screenptr = (char far *)( ((long) 0xA000 )<<16 | 0);

return ;
}
void setbank(int bank)
{
  if(bank==curbank)
   return;
  curbank = bank;
bank<<=bankshift;
_BX=0;
_DX=bank;
bankswitch();
_BX=1;
bankswitch();
return ;
}

void SetPalette(RGB pal[256])
{
 union REGS reg;
 struct SREGS inreg;
 reg.x.ax=0x1012;
 segread(&inreg);
 inreg.es = inreg.ds;
 reg.x.bx=0;
reg.x.cx=256;
reg.x.dx=(int ) &pal[0];
int86x(0x10,®,®,&inreg);
return ;
}
void vputpixel(int x,int y,int c)
{
 long addr = (long ) y *  bytesperline + x;
setbank((int) (addr>>16));
*(screenptr+(addr & 0xFFFF))=(char) c;
return;
}
void setwidth(int width)
{
  union REGS in,out;
in.x.ax = 0x4F06;
in.x.bx=0x0000;
in.x.cx=width;
int86(0x10,&in,&out);

bytesperline = (int ) out.x.bx;
maxy = (int ) out.x.dx;
maxx = (int ) out.x.cx;
return ;
}
void vinitgraph(int mode)
{
 SetVesaMode(mode);
 setwidth(xres);
return ;
}

void vclosegraph(void)
{
 vinitgraph(oldmode);
/*    union REGS regs;
    regs.h.ah = 0x00;
    regs.h.al = 0x03;
    int86(0x10, ®s, ®s);*/
 maxx=xres;
}
void startaddr(int *xs,int *ys,int mode)
{
  union REGS in,out;
in.x.ax = 0x4F07;
if(mode==0)
 {
  in.x.bx=0x0000;
  in.x.cx=*xs;
  in.x.dx = *ys;
 }
else
 in.x.bx = 0x0001;
int86(0x10,&in,&out);
if(mode==1)
 {
   *xs = out.x.cx;
   *ys = out.x.dx;
 }
return ;

}

char ISValidBitmap(char *fname)
{
 BMPINFO bmpinfo;
 FILE *fp;
 if((fp = fopen(fname,"rb+"))==NULL)
 {
  printf("
Unable open the file %s",fname,"!!");
  return 0;
 }

 fread(&bmpinfo,sizeof(bmpinfo),1,fp);
 fclose(fp);
 if(!(bmpinfo.bmiheader.bftype[0]=='B' &&
bmpinfo.bmiheader.bftype[1]=='M'))
 {
  printf("
can't read the file: not a valid BMP file!");
  return 0;
 }

 if(!bmpinfo.bmiheader.bicompression==0)
 {
  printf("
can't read the file: should not be a RLR encoded!!");
  return 0;
 }
 if(!bmpinfo.bmiheader.bibitcount==8)
 {
 printf("can't read the file: should be 8-bit per color format!!");
 return 0;
 }

return 1;
}






void showbitmap(char *infname,int xs,int ys)
{
BMPINFO bmpinfo;
RGB pal[256];
FILE *fpt;
int i,j,w,h,c,bank;
unsigned char byte[1056];
long addr;
unsigned int k;
if((fpt=fopen(infname,"rb+"))==NULL)
 {
  printf("
Error opening file ");
  getch();
  return 1;
 }

fread(&bmpinfo,sizeof(bmpinfo),1,fpt);
fseek(fpt,bmpinfo.bmiheader.bfoffbits,SEEK_SET);
w = bmpinfo.bmiheader.biwidth;
h = bmpinfo.bmiheader.biheight;
for(i=0;i<=255;i++)
{
 pal[i].red = bmpinfo.bmicolors[i].red/4;
pal[i].green = bmpinfo.bmicolors[i].green/4;
pal[i].blue = bmpinfo.bmicolors[i].blue/4;
}
vinitgraph(VGALOW);
setwidth(1000);
SetPalette(pal);
for(i=0;i<h;i++)
{
   fread(&byte[0],sizeof(unsigned char),w,fpt);
 for(j=0;j<w;j++)
  {
   c= (int ) byte[j];
     addr= (long) (ys+h-i)*bytesperline+xs+j;
bank = (int ) (addr >>16);
if(curbank!= bank)
{
 curbank =bank;
bank<<=bankshift;
_BX=0;
_DX=bank;
bankswitch();
_BX=1;
bankswitch();
}
*(screenptr+(addr & 0xFFFF)) = (char ) c;
}
}
fclose(fpt);
getch();
vclosegraph();
return 0;
}



int ColorToGrey(char *infname,int xs,int ys)
{
BMPINFO bmpinfo;
FILE *fpt1,*fpt2;
char fname[13];
unsigned char r,g,b,byte[1056],pal[256];
double e,grey;
int i,j,h,w,pcnt=0;
long size,curpos;
strcpy(fname,infname);
fpt2=fopen("Grey.bmp","wb");
if((fpt1=fopen(fname,"rb+"))==NULL)
{
  printf("can't open the file %s",infname);
getch();
return 1;
}

clrscr();
printf("Preparing taget file..");
fseek(fpt1,0,SEEK_END);
size = ftell(fpt1) + 256;
fseek(fpt1,0,SEEK_SET);
fread(&bmpinfo,sizeof(bmpinfo),1,fpt1);
curpos=ftell(fpt1);
pcnt = (int )ceil((float) curpos *100.0/(float) size);
gotoxy(25,1);
printf("%d completed",pcnt);
for(i=0;i<=255;i++)
{
 r = bmpinfo.bmicolors[i].red;
 g = bmpinfo.bmicolors[i].green;
 b = bmpinfo.bmicolors[i].blue;
grey = (double) 0.3 * (double ) r+ (double ) 0.11 * (double ) b +
(double ) 0.59 * (double) g;
if(grey-(int) grey >=0.5)
 grey++;
if(grey>255)
 grey=255;
pal[i]=(unsigned char ) grey;
bmpinfo.bmicolors[i].red = (unsigned char ) i;
bmpinfo.bmicolors[i].green = (unsigned char ) i;
bmpinfo.bmicolors[i].blue = (unsigned char ) i;
curpos++;
}
bmpinfo.bmiheader.biclrused=0;
i = bmpinfo.bmiheader.bfoffbits;
bmpinfo.bmiheader.bfoffbits=1078;
fwrite(&bmpinfo,sizeof(bmpinfo),1,fpt2);
fseek(fpt1,i,SEEK_SET);
fseek(fpt2,bmpinfo.bmiheader.bfoffbits,SEEK_SET);
w=bmpinfo.bmiheader.biwidth;
h = bmpinfo.bmiheader.biheight;
curpos = ftell(fpt1) + 256;
for(i=0;i<h;i++)
{
 fread(&byte[0],sizeof(unsigned char),w,fpt2);
 for(j=0;j<w;j++)
   byte[j]=pal[byte[j]];
 fwrite(&byte[0],sizeof(unsigned char ) , w,fpt2);
curpos+=w;
pcnt = (int )ceil((float) curpos *100.0/(float) size);
gotoxy(25,1);
printf("%d completed",pcnt);
}
fclose(fpt1);
fclose(fpt2);
showbitmap("Grey.bmp",xs,ys);
return 0;
}




void main()
{
  char file[13];
  memset(file,0,13);
 clrscr();
 printf("
Enter the file name[*.bmp]:");
 scanf("%s",file);
 if(IsValidBitmap(file))
   showbitmap(file,0,0);
 else
   printf("
Not a valid bitmap file");
 printf("
That's all folks");
   getch();

 }

No comments:

Post a Comment