亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? testdlg.cpp

?? 將一張圖片切割成任意大小的小圖片,經測試數據正確無誤
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// TestDlg.cpp : implementation file
//

#include "stdafx.h"
#include "Mybole.h"
#include "TestDlg.h"

#include <stdio.h>
#include <stdlib.h>
#define Headsize 54
int m,n,cow_num,rol_num, flag_num;

long width_old,height_old;
unsigned char header[54];
unsigned char *image;
BITMAP bm;

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/************************************************************
	BITMAP * LoadBitmapFile(char* FileName, int x, int y, HWND hwnd)
   加載一張位圖的信息,并返回一個位圖的指針********************
*************************************************************/


BITMAP * LoadBitmapFile(char* FileName, int x, int y, HWND hwnd)
{

   HDC hdc = GetDC(hwnd);
   HANDLE BitHandle;
   BitHandle = (HBITMAP)LoadImage(NULL, FileName, IMAGE_BITMAP, 0,0, LR_LOADFROMFILE);
   if(BitHandle == NULL)
   {
      MessageBox(0, "加載指定的位圖文件出錯", "程序錯誤!",
      MB_ICONERROR | MB_SYSTEMMODAL | MB_OK);
	  return NULL;
   }
   HDC dc = CreateCompatibleDC(hdc);
   SelectObject(dc, BitHandle);
   GetObject(BitHandle, sizeof(BITMAP), &bm);
  
   BitBlt(hdc, x, y, bm.bmWidth, bm.bmHeight, dc, 0,0, SRCCOPY);
   CPoint m_pt;
  // m_pt.x=x+bm.bmWidth+num1;
   //m_pt.y=y+num2;
	BitBlt(hdc, m_pt.x, m_pt.y, bm.bmWidth, bm.bmHeight, dc, 0,0, SRCCOPY);
 
   ReleaseDC(hwnd, hdc);
   return(&bm);
}


unsigned char * bmp_read( const char *filename) 
 {
//	unsigned char *image;
   char fname_bmp[128];
   FILE *fp;
   sprintf(fname_bmp, "%s.bmp", filename);
   if (!(fp = fopen(fname_bmp, "rb"))) 
    return NULL;
  fseek(fp,0,SEEK_SET);
  fread(header,sizeof(unsigned char),Headsize,fp);

  //獲得文件寬度
	width_old=header[18];
	width_old+=(header[19]<<8);
	width_old+=(header[20]<<16);
	width_old+=(header[21]<<24);
//	printf("the width_old of the  picture %d\n",width_old);
      
    //獲得文件高度
	height_old= header[22];
	height_old+=(header[23]<<8);
	height_old+=(header[24]<<16);
	height_old+=(header[25]<<16);
//	printf("the height_old of the picture %d\n",height_old);	
	
	image = (unsigned char *)malloc(width_old * height_old*2);
	if (image == NULL) 
    return NULL;

  fread(image, sizeof(unsigned char), width_old * height_old*2, fp);
  
 // AfxMessageBox("the programe in the read file");
  fclose(fp);
   return image;
 }
int bmp_write(unsigned char *image) 
{
	FILE *fp[65];
  	char fname_bmp[128];
	long width=m, height=n;
//	long data_size;
	long file_size = (width) * (height)*2+Headsize;
	int i=0,j,k,num1,num2,flag=0,temp1,temp2;
	
	j=width_old/m;
	k=height_old/n;
	cow_num=j;		//行數目
	rol_num=k;		//列數目
	if(j==0)	{width=width_old; cow_num=1;}	
	if(k==0)	{height=height_old; rol_num=1;}			

	//修改頭文件數據
	//修改文件大小
	header[2] = (unsigned char)(file_size &0x000000ff);
	header[3] = (unsigned char)((file_size >> 8) & 0x000000ff);
	header[4] = (unsigned char)((file_size >> 16) & 0x000000ff);
	header[5] = (unsigned char)((file_size >> 24) & 0x000000ff);
       
	//修改文件寬度
	header[18] = (unsigned char)(width & 0x000000ff);
	header[19] = (unsigned char)((width >> 8) &0x000000ff);
	header[20] = (unsigned char)((width >> 16) &0x000000ff);
	header[21] = (unsigned char)((width >> 24) &0x000000ff);
   
    //修改文件高度
	header[22] = (unsigned char)(height &0x000000ff);
	header[23] = (unsigned char)((height >> 8) &0x000000ff);
	header[24] = (unsigned char)((height >> 16) &0x000000ff);
	header[25] = (unsigned char)((height >> 24) &0x000000ff);
	
	//修改文件數據大小
	/* data_size=width*height*2;
	header[34] = (unsigned char)(data_size &0x000000ff);
	header[35] = (unsigned char)((data_size >> 8) &0x000000ff);
	header[36] = (unsigned char)((data_size >> 16) &0x000000ff);
	header[37] = (unsigned char)((data_size >> 24) &0x000000ff);*/
	
	if((width_old%m==0)&&(height_old%n==0))
	{
		flag_num=j*k;				//flag_num表示可以將小屏幕分成多少份.
		cow_num=j;	//用m記錄每一行的數據的個數.
		rol_num=k;	//用n記錄每一列的數據的個數.
	}
	else
	{
		if(width_old%m)	
		{
			flag_num=(j+1)*k;
			cow_num=j+1;
		}
		if(height_old%n)
		{
			flag_num=j*(k+1);
			rol_num=k+1;
		}
		if((width_old%m)&&(height_old%n))
		{
			flag_num=(j+1)*(k+1);
			cow_num=j+1;
			rol_num=k+1;
		}
	}

	for(flag=0;flag<flag_num;flag++)
	{
		sprintf(fname_bmp, "%s_%d.bmp", "1007",flag);
		if (!(fp[flag] = fopen(fname_bmp, "wb+"))) 
		return -1;
		 fseek(fp[flag],0,SEEK_SET);
		 fwrite(header, sizeof(unsigned char), Headsize, fp[flag]);		//所有文件都按需要截取的格式寫頭文件信息。
	}
	flag=0;			//準備寫第一個文件。
	if(flag_num==1)
	{
		fwrite(image, sizeof(unsigned char), width_old*height_old*2, fp[flag]);		//BMP圖片數據信息的填寫
	}
	else
	{
		
		if((width_old%m==0)&&(height_old%n==0))
		{
			for(temp2=0;temp2<k;temp2++)		//需要截取的小屏的列數超過1時,即分屏分成至少K行數目的小屏,進行按行讀取的形式.且前面的K-1行的數據都是完整的一小屏數據.只有最后一行的屏幕可能會出現誤差需要校正.
			{	
			
				for (i=0;i<n;i++)		//寫一排小屏幕的數據
				{	
					
					for(temp1=0;temp1<j;temp1++)
					{	
						fwrite(image, sizeof(unsigned char), width*2, fp[flag]);		//BMP圖片數據信息的填寫
						image=image+width*2;
						flag++;
					}
					flag=flag-j;
				}
					flag=flag+j;
			}
		}
		if(width_old%width)				//當行不能整行截取時.
		{
			num1=width_old%width;
			//printf("the size of the nomal file is %x\n",file_size);

			//修改最每一行的最后一個文件寬度
			num1=width_old%width;
			header[18] = (unsigned char)(num1 & 0x000000ff);
			header[19] = (unsigned char)((num1 >> 8) &0x000000ff);
			header[20] = (unsigned char)((num1 >> 16) &0x000000ff);
			header[21] = (unsigned char)((num1 >> 24) &0x000000ff);
			//修改文件大小
			file_size = (num1) * (height)*2+Headsize;
			//修改文件大小
			header[2] = (unsigned char)(file_size &0x000000ff);
			header[3] = (unsigned char)((file_size >> 8) & 0x000000ff);
			header[4] = (unsigned char)((file_size >> 16) & 0x000000ff);
			header[5] = (unsigned char)((file_size >> 24) & 0x000000ff);
		
			//printf("the size of the last file is %x\n",file_size);
			for(temp1=0;temp1<k;temp1++)
			{
				flag=(temp1+1)*(j+1)-1;
				fseek(fp[flag],0,SEEK_SET);
				fwrite(header, sizeof(unsigned char), Headsize, fp[flag]);
			}
			flag=0;
			//printf("the file of heade has been deal success\n");
		
			for(temp2=0;temp2<k;temp2++)		//需要截取的小屏的列數超過1時,即分屏分成至少K行數目的小屏,進行按行讀取的形式.且前面的K-1行的數據都是完整的一小屏數據.只有最后一行的屏幕可能會出現誤差需要校正.
			{	
			
				for (i=0;i<n;i++)		//寫一排小屏幕的數據
				{	
					
					for(temp1=0;temp1<j;temp1++)
					{	
						fwrite(image, sizeof(unsigned char), width*2, fp[flag]);		//BMP圖片數據信息的填寫
						image=image+width*2;
						flag++;
					}
						fwrite(image, sizeof(unsigned char), num1*2, fp[flag]);		//BMP圖片數據信息的填寫
						image=image+num1*2;
						flag=flag-j;
				}
					flag=flag+j+1;
			}
		}
	
		if(width_old%width==0)	num1=width;
		if(height_old%height)
		{	
			//修改文件寬度
			header[18] = (unsigned char)(width & 0x000000ff);
			header[19] = (unsigned char)((width >> 8) &0x000000ff);
			header[20] = (unsigned char)((width >> 16) &0x000000ff);
			header[21] = (unsigned char)((width >> 24) &0x000000ff);
	//		printf("%d\t%d\t%d\t%d\n",header[18],header[19],header[20],	header[21]);

			num2=height_old%height;
			header[22] = (unsigned char)(num2 &0x000000ff);
			header[23] = (unsigned char)((num2 >> 8) &0x000000ff);
			header[24] = (unsigned char)((num2 >> 16) &0x000000ff);
			header[25] = (unsigned char)((num2 >> 24) &0x000000ff);
			file_size = (width) * (num2)*2+Headsize;//修改文件大小
	//		printf("the width of the last row picture is %d\n",width);

	//		printf("the size of width) * (num2file is %x\n",file_size);
			//修改文件大小
			header[2] = (unsigned char)(file_size &0x000000ff);
			header[3] = (unsigned char)((file_size >> 8) & 0x000000ff);
			header[4] = (unsigned char)((file_size >> 16) & 0x000000ff);
			header[5] = (unsigned char)((file_size >> 24) & 0x000000ff);
			
			//printf("the size of the last file is %x\n",file_size);
			temp2=flag;
			printf("flag=%d\n",flag);
			flag=flag_num-cow_num;
			for(temp1=0;temp1<j;temp1++)
			{
				fseek(fp[flag],0,SEEK_SET);
				fwrite(header, sizeof(unsigned char), Headsize, fp[flag]);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产a毛片| 欧美成人伊人久久综合网| 狠狠色伊人亚洲综合成人| 亚洲国产日韩在线一区模特| 一区二区三区小说| 亚洲精品视频在线观看免费| 亚洲精品成人天堂一二三| 一区在线播放视频| 中文字幕欧美一| 亚洲在线中文字幕| 视频一区视频二区在线观看| 美国十次综合导航| 国产一区二区三区香蕉 | 丁香天五香天堂综合| 久久精品国产亚洲5555| 黑人精品欧美一区二区蜜桃| 国产一区二区视频在线播放| 成人av动漫网站| 色综合久久99| 制服丝袜亚洲网站| 精品久久久久一区二区国产| 国产精品天干天干在观线| **网站欧美大片在线观看| 亚洲一区在线观看免费 | 国产日产欧产精品推荐色| 中文一区二区在线观看| 成人免费在线观看入口| 丝袜美腿亚洲一区| 国产麻豆午夜三级精品| 99久久精品国产导航| 欧美精品国产精品| 欧美经典一区二区| 亚洲成av人影院在线观看网| 国产精品99久久久久久宅男| 91国模大尺度私拍在线视频| 欧美va亚洲va| 亚洲女与黑人做爰| 日韩电影在线一区| 91在线码无精品| 欧美va亚洲va在线观看蝴蝶网| 国产精品国产馆在线真实露脸| 亚洲国产成人tv| 成人免费视频一区| 欧美一级xxx| 有码一区二区三区| 国产一区二区三区电影在线观看 | 日韩精品成人一区二区三区| 成人午夜看片网址| 91精品国产欧美日韩| 中文字幕亚洲不卡| 国产东北露脸精品视频| 欧美一级欧美三级| 亚洲欧美日韩国产成人精品影院| 精品一区二区三区久久| 欧美色图在线观看| ●精品国产综合乱码久久久久| 久色婷婷小香蕉久久| 欧美亚洲禁片免费| 国产精品不卡在线| 国产成人自拍高清视频在线免费播放| 欧美日韩国产一级| 亚洲免费观看高清完整版在线观看熊 | 欧美在线观看一二区| 欧美高清在线一区二区| 极品尤物av久久免费看| 欧美美女激情18p| 亚洲图片欧美综合| 91蝌蚪porny成人天涯| 日本一区免费视频| 国内精品写真在线观看| 日韩一区二区麻豆国产| 亚洲一区二区三区小说| 成人av网站在线观看| 久久久www成人免费无遮挡大片| 久久精品国产99国产| 欧美一区二区视频在线观看 | 久久久久国产精品麻豆ai换脸| 秋霞电影网一区二区| 欧美二区在线观看| 蜜臀va亚洲va欧美va天堂| 欧美一区中文字幕| 裸体健美xxxx欧美裸体表演| 日韩视频免费直播| 国产一区二区在线视频| 欧美国产1区2区| 91视视频在线直接观看在线看网页在线看 | 欧美日韩综合一区| 亚洲 欧美综合在线网络| 欧美人与z0zoxxxx视频| 视频在线观看一区二区三区| 欧美一级爆毛片| 国产成人自拍在线| 中文字幕在线观看不卡| 在线一区二区观看| 日韩国产精品91| 精品播放一区二区| 成人午夜激情片| 亚洲一区在线观看网站| 欧美一卡二卡三卡四卡| 国产一区二区在线看| 亚洲人吸女人奶水| 这里只有精品视频在线观看| 国产一区二区三区精品欧美日韩一区二区三区 | 欧美日韩电影在线播放| 日产国产高清一区二区三区| 久久久91精品国产一区二区精品 | 麻豆成人综合网| 久久久久久免费毛片精品| 91视频精品在这里| 日韩影视精彩在线| 国产精品视频一二| 欧美精品久久99| 91在线丨porny丨国产| 麻豆精品在线观看| 中文字幕在线观看不卡视频| 日韩午夜精品视频| 99久久综合狠狠综合久久| 天天操天天干天天综合网| 国产欧美一区二区精品性| 欧美日本一区二区| 成人av在线资源网| 久久99精品久久久久久 | 91精品婷婷国产综合久久性色| 极品瑜伽女神91| 亚洲chinese男男1069| 国产精品久久免费看| 欧美一级片在线看| 欧美三级日韩三级| voyeur盗摄精品| 精品午夜久久福利影院| 午夜电影一区二区三区| 亚洲欧美一区二区三区极速播放 | 国产成人av一区| 日韩高清一级片| 亚洲最快最全在线视频| 国产精品久久久久一区二区三区 | 亚洲成人av一区二区| 中文字幕日韩一区二区| 国产日韩精品一区| 日韩一级在线观看| 欧美丰满少妇xxxxx高潮对白| 99久久免费视频.com| 国产成人精品免费视频网站| 国产毛片精品视频| 国产一区二区主播在线| 精品一区精品二区高清| 美日韩一区二区| 美女视频一区二区| 午夜欧美视频在线观看| 亚洲午夜私人影院| 午夜视频一区二区| 性久久久久久久久久久久| 午夜视频在线观看一区二区三区| 亚洲一二三四在线| 亚洲成人自拍一区| 日韩电影在线免费看| 蜜桃久久av一区| 国产九色精品成人porny | 椎名由奈av一区二区三区| 亚洲国产精品精华液ab| 国产精品毛片久久久久久久| 国产精品美女久久久久久久| 成人欧美一区二区三区在线播放| 国产精品福利一区| 亚洲美女偷拍久久| 亚洲五月六月丁香激情| 蜜芽一区二区三区| 精品一区二区在线视频| 国产麻豆精品在线| 不卡的av中国片| 91福利视频网站| 欧美不卡在线视频| 国产精品三级电影| 亚洲一区二区三区在线看 | 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 精品欧美乱码久久久久久1区2区| 精品国产电影一区二区| 国产女人18水真多18精品一级做| 国产精品不卡视频| 亚洲成人你懂的| 国产一区二区在线电影| 99re成人精品视频| 欧美精品一二三区| 国产亚洲综合性久久久影院| 亚洲精品免费播放| 日本人妖一区二区| 国产传媒日韩欧美成人| 在线亚洲精品福利网址导航| 欧美电影免费观看高清完整版在线 | 欧美日韩久久不卡| 久久久久久久久久久久久夜| 亚洲欧美色一区| 久久疯狂做爰流白浆xx| 99re热这里只有精品视频| 欧美一级搡bbbb搡bbbb| 中文字幕在线一区免费| 亚洲综合色成人| 成人av网站在线观看| 欧美v亚洲v综合ⅴ国产v| 亚洲精品成人悠悠色影视|