亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
色老头久久综合| 亚洲天堂成人在线观看| 久久亚洲私人国产精品va媚药| 精品国产露脸精彩对白| 国产精品视频第一区| 亚洲资源中文字幕| 国内成人免费视频| 99久久99精品久久久久久| 欧洲一区在线观看| 精品福利一区二区三区| 亚洲免费观看高清完整版在线观看熊 | 国产天堂亚洲国产碰碰| 亚洲区小说区图片区qvod| 日韩中文字幕麻豆| youjizz久久| 欧美大尺度电影在线| 亚洲天堂免费看| 久久99在线观看| 在线视频亚洲一区| 久久久久成人黄色影片| 午夜不卡av免费| www.在线欧美| 久久综合99re88久久爱| 亚洲一区在线观看视频| 国产凹凸在线观看一区二区| 精品视频999| 国产精品国产三级国产三级人妇| 蜜臀av一区二区| 日本乱人伦aⅴ精品| 久久久99久久| 免费观看在线色综合| 99re视频精品| 久久久久久久久久电影| 蜜臀av国产精品久久久久 | 夜夜爽夜夜爽精品视频| 久久se精品一区精品二区| 欧美综合久久久| 中文字幕的久久| 国产在线不卡一卡二卡三卡四卡| 欧美日韩国产高清一区二区三区| 中文字幕在线不卡| 久久国产精品99精品国产| 欧美午夜一区二区三区| 一区视频在线播放| 国产成人丝袜美腿| 精品日韩在线观看| 午夜精品一区二区三区三上悠亚| 色婷婷久久一区二区三区麻豆| 精品国产一区二区三区av性色| 亚洲成人黄色影院| 在线观看亚洲精品视频| 亚洲日本护士毛茸茸| 成人激情校园春色| 久久精品视频在线免费观看| 美国一区二区三区在线播放| 在线电影欧美成精品| 一区二区日韩av| 欧洲精品在线观看| 一区二区三区在线视频观看| 一区二区三区国产精品| 奇米在线7777在线精品| 欧美三级日韩在线| 一级女性全黄久久生活片免费| 91麻豆精品视频| 亚洲色图另类专区| av成人老司机| 亚洲三级免费电影| 91丝袜呻吟高潮美腿白嫩在线观看| 欧美国产一区二区| 国产老女人精品毛片久久| 久久一日本道色综合| 国产在线不卡一卡二卡三卡四卡| 精品区一区二区| 麻豆国产欧美一区二区三区| 日韩一级高清毛片| 日产国产高清一区二区三区 | 久久精品免费观看| 91精品国产91热久久久做人人| 一区二区欧美视频| 欧美在线视频日韩| 亚洲国产综合人成综合网站| 欧美日韩午夜影院| 天天亚洲美女在线视频| 日韩欧美在线综合网| 看电影不卡的网站| 久久噜噜亚洲综合| 成人激情视频网站| 亚洲精品日产精品乱码不卡| 欧美日韩一区二区三区四区五区| 同产精品九九九| 日韩三级在线观看| 国产伦精一区二区三区| 国产精品美女久久久久aⅴ| 色综合久久久久网| 日韩精品色哟哟| 久久综合久久综合久久| 99精品偷自拍| 亚洲一区二区在线视频| 欧美电影免费观看高清完整版在| 国产精品99久久久久久似苏梦涵| 亚洲欧美中日韩| 91麻豆精品国产91久久久| 黄色成人免费在线| 国产精品久久久99| 欧美亚洲高清一区二区三区不卡| 日韩中文字幕一区二区三区| 久久精品亚洲国产奇米99| 91精品国产全国免费观看 | 亚洲综合偷拍欧美一区色| 欧美性色综合网| 麻豆国产精品一区二区三区| 国产精品理论片| 51精品视频一区二区三区| 国产又黄又大久久| 亚洲免费观看视频| 日韩久久久久久| 99久久婷婷国产| 热久久国产精品| 国产日韩欧美综合一区| 色拍拍在线精品视频8848| 老司机精品视频线观看86| 国产精品久久毛片| 6080国产精品一区二区| 不卡一区二区在线| 奇米影视7777精品一区二区| 国产精品久久久久毛片软件| 91麻豆精品国产91久久久久久| 成人性生交大片| 人人狠狠综合久久亚洲| 国产精品美女一区二区在线观看| 91精品国产综合久久久蜜臀粉嫩| 成人黄色av电影| 蜜桃一区二区三区在线| 亚洲黄一区二区三区| 久久久久久一二三区| 在线播放91灌醉迷j高跟美女 | 一级特黄大欧美久久久| 国产午夜精品久久| 欧美精品丝袜中出| 成人av影视在线观看| 日本vs亚洲vs韩国一区三区二区 | 欧美丝袜自拍制服另类| 国产福利精品一区二区| 日本欧美一区二区三区乱码| 亚洲激情第一区| 国产精品福利一区二区| 欧美zozo另类异族| 欧美老年两性高潮| 91福利视频网站| 成人激情小说网站| 国产一区二区网址| 久久精品国产**网站演员| 亚洲va在线va天堂| 伊人婷婷欧美激情| 国产精品美女www爽爽爽| 久久夜色精品国产欧美乱极品| 欧美一区二区三区在线观看| 精品视频一区三区九区| 91丨porny丨国产| 国产69精品久久久久毛片| 精久久久久久久久久久| 日本视频在线一区| 丝袜美腿亚洲一区二区图片| 一级做a爱片久久| 亚洲靠逼com| 国产精品传媒在线| 国产精品无人区| 国产精品丝袜久久久久久app| 久久久久一区二区三区四区| 精品日韩99亚洲| 91精品国产91综合久久蜜臀| 91精品国产免费| 91精品国产综合久久婷婷香蕉 | 美女一区二区三区在线观看| 午夜欧美一区二区三区在线播放| 亚洲丝袜美腿综合| 亚洲免费观看高清完整版在线 | 欧美日韩另类一区| 欧美午夜不卡在线观看免费| 91在线精品秘密一区二区| 不卡一区中文字幕| 成人精品小蝌蚪| 不卡区在线中文字幕| 成人av综合在线| 99在线精品观看| 91社区在线播放| 在线观看日韩av先锋影音电影院| 91精品1区2区| 欧美特级限制片免费在线观看| 欧美三级乱人伦电影| 制服.丝袜.亚洲.另类.中文| 日韩一区二区三区在线视频| 欧美mv和日韩mv的网站| 久久久国际精品| 中文av一区特黄| 亚洲欧美日韩电影| 亚洲一区二区在线视频| 青青草成人在线观看| 国产一区二区在线免费观看| k8久久久一区二区三区|