source: dev/trunk/ab5.0/abdev/abdev/IconEditor.cpp@ 705

Last change on this file since 705 was 705, checked in by イグトランス (egtra), 16 years ago

ファイルハンドルが解放されず困ることがあるのでCHandleへ入れた。

File size: 17.0 KB
Line 
1#include "stdafx.h"
2
3#include "Common.h"
4
5RGBQUAD DefaultColorTable16[16]={
6 0,0,0,0,
7 0,0,128,0,
8 0,128,0,0,
9 0,128,128,0,
10 128,0,0,0,
11 128,0,128,0,
12 128,128,0,0,
13 128,128,128,0,
14 192,192,192,0,
15 0,0,255,0,
16 0,255,0,0,
17 0,255,255,0,
18 255,0,0,0,
19 255,0,255,0,
20 255,255,0,0,
21 255,255,255,0,
22};
23RGBQUAD DefaultColorTable256[256]; //ファイルから読み込む(SetupProjectEditor関数を参照)
24
25void ResizeIconWindow(HWND hMain,HWND hToolDlg,HWND hColorDlg,int width,int height){
26 MoveWindow(hMain,0,0,width-170,height-50,1);
27 MoveWindow(hToolDlg,width-170,0,170,height,1);
28 MoveWindow(hColorDlg,0,height-50,width-170,50,1);
29}
30void ResetIconType(int WndNum){
31 int i;
32 HWND hCombo;
33 char temporary[MAX_PATH];
34 BITMAPINFOHEADER *pBmpInfoHdr;
35
36 hCombo=GetDlgItem(MdiInfo[WndNum]->MdiIconEditInfo->hToolDlg,IDC_ICONTYPECOMBO);
37
38 for(i=0;i<MdiInfo[WndNum]->MdiIconEditInfo->num;i++){
39 pBmpInfoHdr=(BITMAPINFOHEADER *)MdiInfo[WndNum]->MdiIconEditInfo->pIconImage[i];
40
41 //例: "32*32 (xxxx色)"
42 sprintf(temporary,"%d*%d (%d%s)",
43 pBmpInfoHdr->biWidth,
44 pBmpInfoHdr->biHeight/2,
45 (int)pow((double)2,(double)pBmpInfoHdr->biBitCount),
46 STRING_UNIT_COLORS);
47 SendMessage(hCombo,CB_ADDSTRING,0,(long)temporary);
48 }
49 SendMessage(hCombo,CB_SETCURSEL,0,0);
50}
51BYTE *CreateIconType(int IconType,DWORD *dwBytes){
52 extern HANDLE hHeap;
53 int i,width,BitCount,dwBytesInRes;
54 BITMAPINFOHEADER *pBmpHdr;
55 BYTE *pImageBuffer;
56
57 switch(IconType){
58 case ICONTYPE_16_16:
59 width=16;
60 BitCount=4;
61 break;
62 case ICONTYPE_16_256:
63 width=16;
64 BitCount=8;
65 break;
66 case ICONTYPE_32_16:
67 width=32;
68 BitCount=4;
69 break;
70 case ICONTYPE_32_256:
71 width=32;
72 BitCount=8;
73 break;
74 }
75
76 //イメージサイズを計算
77 dwBytesInRes=sizeof(BITMAPINFOHEADER)+
78 sizeof(RGBQUAD)*(int)pow((double)2,(double)BitCount)+
79 BitCount*width*width/8;
80 if(width==16) dwBytesInRes+=width*width*2/8;
81 else dwBytesInRes+=width*width/8;
82 *dwBytes=dwBytesInRes;
83
84 //メモリ領域を確保
85 pImageBuffer=(BYTE *)HeapAlloc(hHeap,HEAP_ZERO_MEMORY,dwBytesInRes);
86
87 //ヘッダ情報をセット
88 pBmpHdr=(BITMAPINFOHEADER *)pImageBuffer;
89 pBmpHdr->biSize=sizeof(BITMAPINFOHEADER);
90 pBmpHdr->biWidth=width;
91 pBmpHdr->biHeight=width*2;
92 pBmpHdr->biPlanes=1;
93 pBmpHdr->biBitCount=BitCount;
94
95 //カラーテーブルをセット
96 RGBQUAD *pRgbq;
97 pRgbq=(RGBQUAD *)(pImageBuffer+sizeof(BITMAPINFOHEADER));
98 if(BitCount==4){
99 //16色
100 memcpy(pRgbq,DefaultColorTable16,sizeof(RGBQUAD)*16);
101 }
102 else if(BitCount==8){
103 //256色
104 memcpy(pRgbq,DefaultColorTable256,sizeof(RGBQUAD)*256);
105 }
106
107 //マスクビットをセット
108 BYTE *pMaskBuf;
109 pMaskBuf=pImageBuffer+
110 sizeof(BITMAPINFOHEADER)+
111 sizeof(RGBQUAD)*(int)pow((double)2,(double)BitCount)+
112 BitCount*width*width/8;
113 if(width==16){
114 //一行の4バイト境界を考慮
115 for(i=0;i<16;i++){
116 pMaskBuf[i*4]=0xFF;
117 pMaskBuf[i*4+1]=0xFF;
118 pMaskBuf[i*4+2]=0;
119 pMaskBuf[i*4+3]=0;
120 }
121 }
122 else memset(pMaskBuf,0xFF,width*width/8);
123
124 return pImageBuffer;
125}
126void AddIconType(int WndNum,int IconType){
127 extern HANDLE hHeap;
128 int i,width,BitCount;
129
130 switch(IconType){
131 case ICONTYPE_16_16:
132 width=16;
133 BitCount=4;
134 break;
135 case ICONTYPE_16_256:
136 width=16;
137 BitCount=8;
138 break;
139 case ICONTYPE_32_16:
140 width=32;
141 BitCount=4;
142 break;
143 case ICONTYPE_32_256:
144 width=32;
145 BitCount=8;
146 break;
147 }
148
149 MdiInfo[WndNum]->MdiIconEditInfo->pIconImage[MdiInfo[WndNum]->MdiIconEditInfo->num]=
150 CreateIconType(IconType,
151 &MdiInfo[WndNum]->MdiIconEditInfo->dwBytesInRes[MdiInfo[WndNum]->MdiIconEditInfo->num]);
152
153 //イメージ選択用のメモリを解放
154 if(MdiInfo[WndNum]->MdiIconEditInfo->SelectLevel==2)
155 DeleteObject(MdiInfo[WndNum]->MdiIconEditInfo->hSelectingBmp);
156 MdiInfo[WndNum]->MdiIconEditInfo->SelectLevel=0;
157
158 //アイコンタイプを追加
159 MdiInfo[WndNum]->MdiIconEditInfo->SelectIconNum=MdiInfo[WndNum]->MdiIconEditInfo->num;
160 MdiInfo[WndNum]->MdiIconEditInfo->num++;
161
162 //変更情報を初期化
163 i=MdiInfo[WndNum]->MdiIconEditInfo->SelectIconNum;
164 MdiInfo[WndNum]->MdiIconEditInfo->undo[i].NowPos=0;
165 memset(MdiInfo[WndNum]->MdiIconEditInfo->undo[i].lpData,0,sizeof(BYTE *)*MAX_ICONEDIT_UNDONUM);
166
167 //アイコンタイプコンボボックスに追加
168 char temporary[32];
169 HWND hCombo;
170 hCombo=GetDlgItem(MdiInfo[WndNum]->MdiIconEditInfo->hToolDlg,IDC_ICONTYPECOMBO);
171
172 //例: "32*32 (xxxx色)"
173 sprintf(temporary,"%d*%d (%d%s)",
174 width,
175 width,
176 (int)pow((double)2,(double)BitCount),
177 STRING_UNIT_COLORS);
178 i=SendMessage(hCombo,CB_ADDSTRING,0,(long)temporary);
179
180 SendMessage(hCombo,CB_SETCURSEL,i,0);
181
182 //再描画
183 HBRUSH hOldBrush;
184 hOldBrush=(HBRUSH)SelectObject(MdiInfo[WndNum]->MdiIconEditInfo->memdc,GetStockObject(WHITE_BRUSH));
185 PatBlt(MdiInfo[WndNum]->MdiIconEditInfo->memdc,0,0,400,400,PATCOPY);
186 SelectObject(MdiInfo[WndNum]->MdiIconEditInfo->memdc,hOldBrush);
187 DrawIconToMemBmp(WndNum,0);
188 InvalidateRect(MdiInfo[WndNum]->MdiIconEditInfo->hMain,NULL,1);
189 InvalidateRect(MdiInfo[WndNum]->MdiIconEditInfo->hColorDlg,NULL,0);
190}
191void DeleteIconType(int WndNum){
192 int i;
193
194 //変更情報を解放
195 for(i=0;i<MAX_ICONEDIT_UNDONUM;i++){
196 if(MdiInfo[WndNum]->MdiIconEditInfo->undo[MdiInfo[WndNum]->MdiIconEditInfo->SelectIconNum].lpData[i])
197 HeapDefaultFree(MdiInfo[WndNum]->MdiIconEditInfo->undo[MdiInfo[WndNum]->MdiIconEditInfo->SelectIconNum].lpData[i]);
198 }
199
200 //メモリを解放
201 HeapDefaultFree(MdiInfo[WndNum]->MdiIconEditInfo->pIconImage[MdiInfo[WndNum]->MdiIconEditInfo->SelectIconNum]);
202
203 //イメージ選択用のメモリを解放
204 if(MdiInfo[WndNum]->MdiIconEditInfo->SelectLevel==2)
205 DeleteObject(MdiInfo[WndNum]->MdiIconEditInfo->hSelectingBmp);
206 MdiInfo[WndNum]->MdiIconEditInfo->SelectLevel=0;
207
208 ////////////////////////
209 // アイコンタイプを削除
210 for(i=MdiInfo[WndNum]->MdiIconEditInfo->SelectIconNum;i<MdiInfo[WndNum]->MdiIconEditInfo->num-1;i++){
211 MdiInfo[WndNum]->MdiIconEditInfo->pIconImage[i]=MdiInfo[WndNum]->MdiIconEditInfo->pIconImage[i+1];
212 MdiInfo[WndNum]->MdiIconEditInfo->dwBytesInRes[i]=MdiInfo[WndNum]->MdiIconEditInfo->dwBytesInRes[i+1];
213 MdiInfo[WndNum]->MdiIconEditInfo->undo[i]=MdiInfo[WndNum]->MdiIconEditInfo->undo[i+1];
214 }
215 MdiInfo[WndNum]->MdiIconEditInfo->num--;
216 if(MdiInfo[WndNum]->MdiIconEditInfo->num==MdiInfo[WndNum]->MdiIconEditInfo->SelectIconNum)
217 MdiInfo[WndNum]->MdiIconEditInfo->SelectIconNum=MdiInfo[WndNum]->MdiIconEditInfo->num-1;
218
219 //コンボボックスからアイコンタイプを削除
220 HWND hCombo;
221 hCombo=GetDlgItem(MdiInfo[WndNum]->MdiIconEditInfo->hToolDlg,IDC_ICONTYPECOMBO);
222 i=SendMessage(hCombo,CB_DELETESTRING,
223 SendMessage(hCombo,CB_GETCURSEL,0,0),
224 0);
225 SendMessage(hCombo,CB_SETCURSEL,MdiInfo[WndNum]->MdiIconEditInfo->SelectIconNum,0);
226
227 //再描画
228 HBRUSH hOldBrush;
229 hOldBrush=(HBRUSH)SelectObject(MdiInfo[WndNum]->MdiIconEditInfo->memdc,GetStockObject(WHITE_BRUSH));
230 PatBlt(MdiInfo[WndNum]->MdiIconEditInfo->memdc,0,0,400,400,PATCOPY);
231 SelectObject(MdiInfo[WndNum]->MdiIconEditInfo->memdc,hOldBrush);
232 DrawIconToMemBmp(WndNum,0);
233 InvalidateRect(MdiInfo[WndNum]->MdiIconEditInfo->hMain,NULL,1);
234 InvalidateRect(MdiInfo[WndNum]->MdiIconEditInfo->hColorDlg,NULL,0);
235}
236void NewIconEditWindow(const char *filepath){
237 extern HINSTANCE hInst,hResInst;
238 extern HANDLE hHeap;
239 extern HWND hDocCombo;
240 int i,i2,IconNum;
241 char str[MAX_PATH],str2[32],*buffer;
242 BYTE *pImageBuffer[8];
243 DWORD dwBytesInRes[8];
244 HWND hChild;
245 HDC hdc;
246 MDICREATESTRUCT mdic;
247
248 if(filepath){
249
250 //すでに指定されたファイルが開かれている場合
251 hChild=GetWindow(hClient,GW_CHILD);
252 while(hChild){
253 i=GetWndNum(hChild);
254 if(MdiInfo[i]->DocType==WNDTYPE_ICONEDIT){
255 if(lstrcmpi(MdiInfo[i]->path.c_str(),filepath)==0) break;
256 }
257 hChild=GetNextWindow(hChild,GW_HWNDNEXT);
258 }
259 if(hChild){
260 BringWindowToTop(hChild);
261 return;
262 }
263
264 //ファイル読み込み(正常に読み込めるかの確認も含む)
265 {
266 DWORD dw;
267 ATL::CHandle hFile(CreateFile(filepath,GENERIC_READ,FILE_SHARE_READ|FILE_SHARE_WRITE,NULL,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,NULL));
268 if(hFile==INVALID_HANDLE_VALUE){
269 hFile.Detach();
270 //"\"%s\" ファイルの読み込みに失敗しました。"
271 sprintf(str,STRING_ERROR_CANT_FILEOPEN,filepath);
272 MessageBox(hOwner,str,STRING_ERROR,MB_OK|MB_ICONEXCLAMATION);
273 return;
274 }
275 i=GetFileSize(hFile,NULL);
276 buffer=(char *)HeapAlloc(hHeap,0,i+1);
277 ReadFile(hFile,buffer,i,&dw,NULL);
278 }
279
280 ICONDIR *pIconDir;
281 ICONDIRENTRY *pIconDirEntry;
282 pIconDir=(ICONDIR *)buffer;
283 IconNum=pIconDir->idCount;
284 bool FileOk = true;
285 for(i=0;i<IconNum;i++){
286 pIconDirEntry=(ICONDIRENTRY *)(buffer+sizeof(ICONDIR)+sizeof(ICONDIRENTRY)*i);
287
288 pImageBuffer[i]=(BYTE *)HeapAlloc(hHeap,0,pIconDirEntry->dwBytesInRes);
289 memcpy(pImageBuffer[i],buffer+pIconDirEntry->dwImageOffset,pIconDirEntry->dwBytesInRes);
290
291 dwBytesInRes[i]=pIconDirEntry->dwBytesInRes;
292
293 //対応チェック
294 BITMAPINFOHEADER *pBmpInfoHdr=(BITMAPINFOHEADER *)pImageBuffer[i];
295 if( !(pBmpInfoHdr->biBitCount == 4 || pBmpInfoHdr->biBitCount == 8 ) ){
296 //16色、256色以外の場合
297 //未対応
298 FileOk = false;
299 }
300 }
301
302 _splitpath(filepath,NULL,NULL,str,str2);
303 lstrcat(str,str2);
304 mdic.szTitle=str;
305
306 HeapDefaultFree(buffer);
307
308 if( !FileOk ){
309 for(i=0;i<IconNum;i++){
310 HeapDefaultFree( pImageBuffer[i] );
311 }
312
313 char msg[1024];
314 sprintf( msg, "\"%s\"\n\n16色または256色以外の形式のファイルには対応していません。", filepath );
315 MessageBox( hOwner, msg, "ActiveBasic", MB_OK | MB_ICONEXCLAMATION );
316 return;
317 }
318 }
319 else{
320 extern int DocumentCounter;
321 buffer=0;
322 DocumentCounter++;
323 sprintf(str,"Icon[%d]",DocumentCounter);
324 mdic.szTitle=str;
325
326 IconNum=1;
327 pImageBuffer[0]=CreateIconType(ICONTYPE_32_16,&dwBytesInRes[0]);
328 }
329 mdic.szClass="MDIClientWindow_IconEdit";
330 mdic.hOwner=hInst;
331 mdic.x=CW_USEDEFAULT;
332 mdic.y=CW_USEDEFAULT;
333 mdic.cx=CW_USEDEFAULT;
334 mdic.cy=CW_USEDEFAULT;
335
336 hChild=GetWindow(hClient,GW_CHILD);
337 if(IsWindow(hChild)){
338 if(IsZoomed(hChild)) mdic.style=WS_MAXIMIZE;
339 else mdic.style=0;
340 }
341 else{
342 if(pobj_nv->bMDIZoomed) mdic.style=WS_MAXIMIZE;
343 else mdic.style=0;
344 }
345
346 mdic.lParam=0;
347 mdic.style |= WS_VISIBLE | WS_CHILD | WS_CLIPSIBLINGS | WS_CLIPCHILDREN | WS_SYSMENU | WS_CAPTION | WS_THICKFRAME | WS_MINIMIZEBOX | WS_MAXIMIZEBOX;
348 hChild=(HWND)SendMessage(hClient,WM_MDICREATE,0,(long)&mdic); //ウィンドウ作成
349
350 ////////////////////
351 //子ウィンドウ作成
352
353 //エディタ中央部分を作成
354 HWND hMain;
355 hMain=CreateWindowEx(WS_EX_CLIENTEDGE,"IconEditWindowProc",NULL,
356 WS_CHILD|WS_VISIBLE,
357 0,0,0,0,
358 hChild,NULL,hInst,NULL);
359
360 //ツールダイアログ部分を作成
361 HWND hToolDlg;
362 hToolDlg=CreateDialog(hResInst,MAKEINTRESOURCE(IDD_ICONEDIT_TOOL),hChild,(DLGPROC)DlgIconToolProc);
363
364 //ツールダイアログのボタン部分を作成
365 HWND hButtonsDlg;
366 hButtonsDlg=CreateDialog(hResInst,MAKEINTRESOURCE(IDD_ICONEDIT_BUTTONS),hToolDlg,(DLGPROC)DlgIconButtons);
367
368 //カラーテーブルダイアログ部分を作成
369 HWND hColorDlg;
370 hColorDlg=CreateDialog(hResInst,MAKEINTRESOURCE(IDD_ICONEDIT_COLOR),hChild,(DLGPROC)DlgIconColorProc);
371
372 //ウィンドウのID登録
373 MdiInfo.push_back( new MDIINFO() );
374 i = MdiInfo.size()-1;
375 MdiInfo[i]->hwnd=hChild;
376 MdiInfo[i]->DocType=WNDTYPE_ICONEDIT;
377 MdiInfo[i]->title = str;
378 if(filepath)
379 {
380 MdiInfo[i]->path = filepath;
381 }
382 else
383 {
384 MdiInfo[i]->path = "";
385 }
386
387 MdiInfo[i]->MdiIconEditInfo=(MDIICONEDITINFO *)HeapAlloc(hHeap,0,sizeof(MDIICONEDITINFO));
388 MdiInfo[i]->MdiIconEditInfo->hMain=hMain;
389 MdiInfo[i]->MdiIconEditInfo->hToolDlg=hToolDlg;
390 MdiInfo[i]->MdiIconEditInfo->hButtonsDlg=hButtonsDlg;
391 MdiInfo[i]->MdiIconEditInfo->hColorDlg=hColorDlg;
392 hdc=GetDC(hMain);
393 MdiInfo[i]->MdiIconEditInfo->memdc=CreateCompatibleDC(hdc);
394 MdiInfo[i]->MdiIconEditInfo->hMemBmp=CreateCompatibleBitmap(hdc,600,400);
395 SelectObject(MdiInfo[i]->MdiIconEditInfo->memdc,MdiInfo[i]->MdiIconEditInfo->hMemBmp);
396 ReleaseDC(hMain,hdc);
397
398 MdiInfo[i]->MdiIconEditInfo->SelectLevel=0;
399
400 MdiInfo[i]->MdiIconEditInfo->num=IconNum;
401 MdiInfo[i]->MdiIconEditInfo->SelectIconNum=0;
402 memcpy(MdiInfo[i]->MdiIconEditInfo->pIconImage,pImageBuffer,sizeof(DWORD)*IconNum);
403
404 memcpy(MdiInfo[i]->MdiIconEditInfo->dwBytesInRes,dwBytesInRes,sizeof(DWORD)*IconNum);
405
406 MdiInfo[i]->MdiIconEditInfo->NowTool=IDC_TOOL_PEN;
407 MdiInfo[i]->MdiIconEditInfo->MainColor=RGB(0,0,0);
408 extern COLORREF TransparentClrRef;
409 MdiInfo[i]->MdiIconEditInfo->SubColor=TransparentClrRef;
410
411 for(i2=0;i2<MdiInfo[i]->MdiIconEditInfo->num;i2++){
412 MdiInfo[i]->MdiIconEditInfo->undo[i2].NowPos=0;
413 memset(MdiInfo[i]->MdiIconEditInfo->undo[i2].lpData,0,sizeof(BYTE *)*MAX_ICONEDIT_UNDONUM);
414 }
415 MdiInfo[i]->MdiIconEditInfo->bModify=0;
416
417
418
419 //メモリへ初期描画を行う
420 HBRUSH hOldBrush;
421 hOldBrush=(HBRUSH)SelectObject(MdiInfo[i]->MdiIconEditInfo->memdc,GetStockObject(WHITE_BRUSH));
422 PatBlt(MdiInfo[i]->MdiIconEditInfo->memdc,0,0,600,400,PATCOPY);
423 SelectObject(MdiInfo[i]->MdiIconEditInfo->memdc,hOldBrush);
424 DrawIconToMemBmp(i,0);
425
426 //ウィンドウ位置を初期化
427 RECT rc;
428 GetClientRect(hChild,&rc);
429 ResizeIconWindow(hMain,hToolDlg,hColorDlg,rc.right,rc.bottom);
430
431 //アイコンタイプコンボボックスをセット
432 ResetIconType(i);
433
434 if(MdiInfo[i]->MdiIconEditInfo->num<=1)
435 EnableWindow(GetDlgItem(hToolDlg,IDC_DELETE_ICONTYPE),0);
436
437 //Docコンボボックスに追加
438 i=SendMessage(hDocCombo,CB_ADDSTRING,0,(long)str);
439 SendMessage(hDocCombo,CB_SETCURSEL,i,0);
440
441 //タブに追加
442 pobj_MainTab->InsertItem( str, true );
443
444 SetStatusText(NULL);
445
446 //メニュー状態を設定
447 ResetState_DocMenu();
448}
449void SetFileIdentityFromFile(MDIINFO &mi, HANDLE hFile);
450
451void SaveIconFile(char *filepath,HWND hwnd){
452 int i,i2,WndNum;
453 char buffer[8192],temporary[MAX_PATH];
454 int ImgBufSize[8];
455
456 WndNum=GetWndNum(hwnd);
457
458 i2=0;
459
460 ///////////
461 // ICONDIR
462 *((WORD *)(buffer+i2))=0; //idReserved
463 i2+=sizeof(WORD);
464 *((WORD *)(buffer+i2))=1; //idType
465 i2+=sizeof(WORD);
466 *((WORD *)(buffer+i2))=MdiInfo[WndNum]->MdiIconEditInfo->num; //idCount
467 i2+=sizeof(WORD);
468
469 ////////////////
470 // ICONDIRENTRY
471 ICONDIRENTRY IconDirEntry;
472 memset(&IconDirEntry,0,sizeof(ICONDIRENTRY));
473
474 //イメージバッファの初期位置
475 IconDirEntry.dwImageOffset=sizeof(ICONDIR)+
476 sizeof(ICONDIRENTRY)*MdiInfo[WndNum]->MdiIconEditInfo->num;
477
478 for(i=0;i<MdiInfo[WndNum]->MdiIconEditInfo->num;i++){
479 BITMAPINFOHEADER *pBmpInfoHdr;
480 pBmpInfoHdr=(BITMAPINFOHEADER *)MdiInfo[WndNum]->MdiIconEditInfo->pIconImage[i];
481
482 IconDirEntry.bWidth=(BYTE)pBmpInfoHdr->biWidth;
483 IconDirEntry.bHeight=(BYTE)pBmpInfoHdr->biHeight/2;
484 if(pBmpInfoHdr->biBitCount<=8)
485 IconDirEntry.bColorCount=(BYTE)pow((double)2,(double)pBmpInfoHdr->biBitCount);
486 else IconDirEntry.bColorCount=0;
487
488 IconDirEntry.dwBytesInRes=sizeof(BITMAPINFOHEADER);
489 if(pBmpInfoHdr->biBitCount<=8) //256色以下の場合はカラーパレットのサイズを考慮
490 IconDirEntry.dwBytesInRes+=(DWORD)pow((double)2,(double)pBmpInfoHdr->biBitCount)*sizeof(long);
491 IconDirEntry.dwBytesInRes+=pBmpInfoHdr->biBitCount*pBmpInfoHdr->biWidth*(pBmpInfoHdr->biHeight/2)/8;
492 if(pBmpInfoHdr->biWidth==16){
493 //16*16のアイコン
494 IconDirEntry.dwBytesInRes+=pBmpInfoHdr->biWidth*(pBmpInfoHdr->biHeight/2)/8*2;
495 }
496 else{
497 //32*32のアイコン
498 IconDirEntry.dwBytesInRes+=pBmpInfoHdr->biWidth*(pBmpInfoHdr->biHeight/2)/8;
499 }
500
501 ImgBufSize[i]=IconDirEntry.dwBytesInRes;
502
503 memcpy(buffer+i2,&IconDirEntry,sizeof(ICONDIRENTRY));
504 i2+=sizeof(ICONDIRENTRY);
505
506 IconDirEntry.dwImageOffset+=IconDirEntry.dwBytesInRes;
507 }
508
509 ////////////////////
510 // イメージバッファ
511 for(i=0;i<MdiInfo[WndNum]->MdiIconEditInfo->num;i++){
512 memcpy(buffer+i2,
513 MdiInfo[WndNum]->MdiIconEditInfo->pIconImage[i],
514 ImgBufSize[i]);
515
516 i2+=ImgBufSize[i];
517 }
518
519
520 //ファイルへ書き込み
521 DWORD dummy;
522 ATL::CHandle hFile(CreateFile(filepath,GENERIC_WRITE,0,NULL,CREATE_ALWAYS,FILE_ATTRIBUTE_NORMAL,NULL));
523 if(hFile==INVALID_HANDLE_VALUE){
524 hFile.Detach();
525 //"\"%s\" ファイルへの書き込みに失敗しました。"
526 sprintf(temporary,STRING_ERROR_CANT_FILESAVE,filepath);
527 MessageBox(hOwner,temporary,STRING_ERROR,MB_OK|MB_ICONSTOP);
528 return;
529 }
530 WriteFile(hFile,buffer,i2,&dummy,NULL);
531 SetFileIdentityFromFile(*MdiInfo[WndNum], hFile);
532}
533
534LRESULT CALLBACK MDIClientWindow_IconEdit(HWND hwnd,UINT message,WPARAM wParam,LPARAM lParam){
535 extern HWND hDocCombo;
536 int i,WndNum;
537
538 switch(message){
539 case WM_MDIACTIVATE:
540 if(!lParam) return 0;
541 i=GetWndNum((HWND)lParam);
542 if(i==-1) return 0; //ウィンドウが初期状態の場合
543
544 i=SendMessage(hDocCombo,CB_FINDSTRINGEXACT,0,(long)MdiInfo[i]->title.c_str());
545 SendMessage(hDocCombo,CB_SETCURSEL,i,0);
546 SetStatusText(NULL);
547 ResetState_EditMenu();
548 return 0;
549 case WM_SIZE:
550 WndNum=GetWndNum(hwnd);
551 if(WndNum==-1) break;
552 ResizeIconWindow(MdiInfo[WndNum]->MdiIconEditInfo->hMain,
553 MdiInfo[WndNum]->MdiIconEditInfo->hToolDlg,
554 MdiInfo[WndNum]->MdiIconEditInfo->hColorDlg,
555 LOWORD(lParam),HIWORD(lParam));
556 break;
557 case WM_CLOSE:
558 CloseDocWindow(GetWndNum(hwnd));
559 pobj_nv->bMDIZoomed=IsZoomed(hwnd);
560 i=DefMDIChildProc(hwnd,message,wParam,lParam);
561
562 //メニュー状態を設定
563 ResetState_DocMenu();
564
565 return i;
566 }
567 return DefMDIChildProc(hwnd,message,wParam,lParam);
568}
Note: See TracBrowser for help on using the repository browser.