123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278 |
- #include <string.h>
- #include <ALL.h>
- #include <OVGA.h>
- #include <OMOUSE.h>
- #include <OIMGRES.h>
- ImageRes::ImageRes(char* resFile, int readAll, int useCommonBuf) :
- ResourceIdx(resFile, readAll, useCommonBuf)
- {
- }
- void ImageRes::put_front(int x, int y, char* imageName, int compressFlag)
- {
- char* bitmapPtr = ResourceIdx::read(imageName);
- if(!bitmapPtr)
- return;
- mouse.hide_area( x, y, x+*((short*)bitmapPtr)-1, y+*(((short*)bitmapPtr)+1)-1 );
- if( compressFlag )
- vga_front.put_bitmap_trans_decompress( x, y, bitmapPtr );
- else
- vga_front.put_bitmap_trans( x, y, bitmapPtr );
- mouse.show_area();
- }
- void ImageRes::put_back(int x, int y, char* imageName, int compressFlag)
- {
- char* bitmapPtr = ResourceIdx::read(imageName);
- if( bitmapPtr )
- {
- if( compressFlag )
- vga_back.put_bitmap_trans_decompress( x, y, bitmapPtr );
- else
- vga_back.put_bitmap_trans( x, y, bitmapPtr );
- }
- }
- void ImageRes::put_front(int x, int y, int bitmapId, int compressFlag)
- {
- char* bitmapPtr = ResourceIdx::get_data(bitmapId);
- if( !bitmapPtr )
- return;
- mouse.hide_area( x, y, x+*((short*)bitmapPtr)-1, y+*(((short*)bitmapPtr)+1)-1 );
- if( compressFlag )
- vga_front.put_bitmap_trans_decompress( x, y, bitmapPtr );
- else
- vga_front.put_bitmap_trans( x, y, bitmapPtr );
- mouse.show_area();
- }
- void ImageRes::put_back(int x, int y, int bitmapId, int compressFlag)
- {
- char* bitmapPtr = ResourceIdx::get_data(bitmapId);
- if( bitmapPtr )
- {
- if( compressFlag )
- vga_back.put_bitmap_trans_decompress( x, y, bitmapPtr );
- else
- vga_back.put_bitmap_trans( x, y, bitmapPtr );
- }
- }
- void ImageRes::put_join(int x, int y, char* imageName)
- {
- char* bitmapPtr = ResourceIdx::read(imageName);
- if( !bitmapPtr )
- return;
- mouse.hide_area( x, y, x+*((short*)bitmapPtr)-1, y+*(((short*)bitmapPtr)+1)-1 );
- if( bitmapPtr )
- IMGjoinTrans( vga_front.buf_ptr(), vga_front.buf_pitch(),
- vga_back.buf_ptr(), vga_back.buf_pitch(), x, y, bitmapPtr );
- mouse.show_area();
- }
- void ImageRes::put_large(VgaBuf* vgaBuf, int x, int y, char* imageName)
- {
- int dataSize;
- vgaBuf->put_large_bitmap( x, y, ResourceIdx::get_file(imageName, dataSize) );
- }
- void ImageRes::put_large(VgaBuf* vgaBuf, int x, int y, int bitmapId)
- {
- int dataSize;
- vgaBuf->put_large_bitmap( x, y, ResourceIdx::get_file(bitmapId, dataSize) );
- }
- void ImageRes::put_to_buf(VgaBuf* vgaBufPtr, char* imageName)
- {
- set_user_buf( vgaBufPtr->buf_ptr(), vgaBufPtr->buf_size(), 4 );
- read(imageName);
- reset_user_buf();
-
- if( vgaBufPtr->buf_pitch() > vgaBufPtr->buf_width() )
- {
- int y = vgaBufPtr->buf_height()-1;
- int p = vgaBufPtr->buf_pitch();
- int w = vgaBufPtr->buf_width();
- char *srcPtr = vgaBufPtr->buf_ptr() + w * y;
- char *destPtr = vgaBufPtr->buf_ptr() + p * y;
- for( ; y > 0; --y, srcPtr -= w, destPtr -= p )
- memmove( destPtr, srcPtr, w );
- }
- }
- void ImageRes::put_to_buf(VgaBuf* vgaBufPtr, int bitmapId)
- {
- set_user_buf( vgaBufPtr->buf_ptr(), vgaBufPtr->buf_size(), 4 );
- get_data(bitmapId);
- reset_user_buf();
-
- if( vgaBufPtr->buf_pitch() > vgaBufPtr->buf_width() )
- {
- int y = vgaBufPtr->buf_height()-1;
- int p = vgaBufPtr->buf_pitch();
- int w = vgaBufPtr->buf_width();
- char *srcPtr = vgaBufPtr->buf_ptr() + w * y;
- char *destPtr = vgaBufPtr->buf_ptr() + p * y;
- for( ; y > 0; --y, srcPtr -= w, destPtr -= p )
- memmove( destPtr, srcPtr, w );
- }
- }
|