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

Last change on this file since 681 was 629, checked in by dai_9181, 16 years ago

MDIINFO構造体をリファクタリング。

File size: 16.8 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 HANDLE hFile;
266 DWORD dw;
267 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 //"\"%s\" ファイルの読み込みに失敗しました。"
270 sprintf(str,STRING_ERROR_CANT_FILEOPEN,filepath);
271 MessageBox(hOwner,str,STRING_ERROR,MB_OK|MB_ICONEXCLAMATION);
272 return;
273 }
274 i=GetFileSize(hFile,NULL);
275 buffer=(char *)HeapAlloc(hHeap,0,i+1);
276 ReadFile(hFile,buffer,i,&dw,NULL);
277 CloseHandle(hFile);
278
279 ICONDIR *pIconDir;
280 ICONDIRENTRY *pIconDirEntry;
281 pIconDir=(ICONDIR *)buffer;
282 IconNum=pIconDir->idCount;
283 bool FileOk = true;
284 for(i=0;i<IconNum;i++){
285 pIconDirEntry=(ICONDIRENTRY *)(buffer+sizeof(ICONDIR)+sizeof(ICONDIRENTRY)*i);
286
287 pImageBuffer[i]=(BYTE *)HeapAlloc(hHeap,0,pIconDirEntry->dwBytesInRes);
288 memcpy(pImageBuffer[i],buffer+pIconDirEntry->dwImageOffset,pIconDirEntry->dwBytesInRes);
289
290 dwBytesInRes[i]=pIconDirEntry->dwBytesInRes;
291
292 //対応チェック
293 BITMAPINFOHEADER *pBmpInfoHdr=(BITMAPINFOHEADER *)pImageBuffer[i];
294 if( !(pBmpInfoHdr->biBitCount == 4 || pBmpInfoHdr->biBitCount == 8 ) ){
295 //16色、256色以外の場合
296 //未対応
297 FileOk = false;
298 }
299 }
300
301 _splitpath(filepath,NULL,NULL,str,str2);
302 lstrcat(str,str2);
303 mdic.szTitle=str;
304
305 HeapDefaultFree(buffer);
306
307 if( !FileOk ){
308 for(i=0;i<IconNum;i++){
309 HeapDefaultFree( pImageBuffer[i] );
310 }
311
312 char msg[1024];
313 sprintf( msg, "\"%s\"\n\n16色または256色以外の形式のファイルには対応していません。", filepath );
314 MessageBox( hOwner, msg, "ActiveBasic", MB_OK | MB_ICONEXCLAMATION );
315 return;
316 }
317 }
318 else{
319 extern int DocumentCounter;
320 buffer=0;
321 DocumentCounter++;
322 sprintf(str,"Icon[%d]",DocumentCounter);
323 mdic.szTitle=str;
324
325 IconNum=1;
326 pImageBuffer[0]=CreateIconType(ICONTYPE_32_16,&dwBytesInRes[0]);
327 }
328 mdic.szClass="MDIClientWindow_IconEdit";
329 mdic.hOwner=hInst;
330 mdic.x=CW_USEDEFAULT;
331 mdic.y=CW_USEDEFAULT;
332 mdic.cx=CW_USEDEFAULT;
333 mdic.cy=CW_USEDEFAULT;
334
335 hChild=GetWindow(hClient,GW_CHILD);
336 if(IsWindow(hChild)){
337 if(IsZoomed(hChild)) mdic.style=WS_MAXIMIZE;
338 else mdic.style=0;
339 }
340 else{
341 if(pobj_nv->bMDIZoomed) mdic.style=WS_MAXIMIZE;
342 else mdic.style=0;
343 }
344
345 mdic.lParam=0;
346 mdic.style |= WS_VISIBLE | WS_CHILD | WS_CLIPSIBLINGS | WS_CLIPCHILDREN | WS_SYSMENU | WS_CAPTION | WS_THICKFRAME | WS_MINIMIZEBOX | WS_MAXIMIZEBOX;
347 hChild=(HWND)SendMessage(hClient,WM_MDICREATE,0,(long)&mdic); //ウィンドウ作成
348
349 ////////////////////
350 //子ウィンドウ作成
351
352 //エディタ中央部分を作成
353 HWND hMain;
354 hMain=CreateWindowEx(WS_EX_CLIENTEDGE,"IconEditWindowProc",NULL,
355 WS_CHILD|WS_VISIBLE,
356 0,0,0,0,
357 hChild,NULL,hInst,NULL);
358
359 //ツールダイアログ部分を作成
360 HWND hToolDlg;
361 hToolDlg=CreateDialog(hResInst,MAKEINTRESOURCE(IDD_ICONEDIT_TOOL),hChild,(DLGPROC)DlgIconToolProc);
362
363 //ツールダイアログのボタン部分を作成
364 HWND hButtonsDlg;
365 hButtonsDlg=CreateDialog(hResInst,MAKEINTRESOURCE(IDD_ICONEDIT_BUTTONS),hToolDlg,(DLGPROC)DlgIconButtons);
366
367 //カラーテーブルダイアログ部分を作成
368 HWND hColorDlg;
369 hColorDlg=CreateDialog(hResInst,MAKEINTRESOURCE(IDD_ICONEDIT_COLOR),hChild,(DLGPROC)DlgIconColorProc);
370
371 //ウィンドウのID登録
372 MdiInfo.push_back( new MDIINFO() );
373 i = MdiInfo.size()-1;
374 MdiInfo[i]->hwnd=hChild;
375 MdiInfo[i]->DocType=WNDTYPE_ICONEDIT;
376 MdiInfo[i]->title = str;
377 if(filepath)
378 {
379 MdiInfo[i]->path = filepath;
380 }
381 else
382 {
383 MdiInfo[i]->path = "";
384 }
385
386 MdiInfo[i]->MdiIconEditInfo=(MDIICONEDITINFO *)HeapAlloc(hHeap,0,sizeof(MDIICONEDITINFO));
387 MdiInfo[i]->MdiIconEditInfo->hMain=hMain;
388 MdiInfo[i]->MdiIconEditInfo->hToolDlg=hToolDlg;
389 MdiInfo[i]->MdiIconEditInfo->hButtonsDlg=hButtonsDlg;
390 MdiInfo[i]->MdiIconEditInfo->hColorDlg=hColorDlg;
391 hdc=GetDC(hMain);
392 MdiInfo[i]->MdiIconEditInfo->memdc=CreateCompatibleDC(hdc);
393 MdiInfo[i]->MdiIconEditInfo->hMemBmp=CreateCompatibleBitmap(hdc,600,400);
394 SelectObject(MdiInfo[i]->MdiIconEditInfo->memdc,MdiInfo[i]->MdiIconEditInfo->hMemBmp);
395 ReleaseDC(hMain,hdc);
396
397 MdiInfo[i]->MdiIconEditInfo->SelectLevel=0;
398
399 MdiInfo[i]->MdiIconEditInfo->num=IconNum;
400 MdiInfo[i]->MdiIconEditInfo->SelectIconNum=0;
401 memcpy(MdiInfo[i]->MdiIconEditInfo->pIconImage,pImageBuffer,sizeof(DWORD)*IconNum);
402
403 memcpy(MdiInfo[i]->MdiIconEditInfo->dwBytesInRes,dwBytesInRes,sizeof(DWORD)*IconNum);
404
405 MdiInfo[i]->MdiIconEditInfo->NowTool=IDC_TOOL_PEN;
406 MdiInfo[i]->MdiIconEditInfo->MainColor=RGB(0,0,0);
407 extern COLORREF TransparentClrRef;
408 MdiInfo[i]->MdiIconEditInfo->SubColor=TransparentClrRef;
409
410 for(i2=0;i2<MdiInfo[i]->MdiIconEditInfo->num;i2++){
411 MdiInfo[i]->MdiIconEditInfo->undo[i2].NowPos=0;
412 memset(MdiInfo[i]->MdiIconEditInfo->undo[i2].lpData,0,sizeof(BYTE *)*MAX_ICONEDIT_UNDONUM);
413 }
414 MdiInfo[i]->MdiIconEditInfo->bModify=0;
415
416
417
418 //メモリへ初期描画を行う
419 HBRUSH hOldBrush;
420 hOldBrush=(HBRUSH)SelectObject(MdiInfo[i]->MdiIconEditInfo->memdc,GetStockObject(WHITE_BRUSH));
421 PatBlt(MdiInfo[i]->MdiIconEditInfo->memdc,0,0,600,400,PATCOPY);
422 SelectObject(MdiInfo[i]->MdiIconEditInfo->memdc,hOldBrush);
423 DrawIconToMemBmp(i,0);
424
425 //ウィンドウ位置を初期化
426 RECT rc;
427 GetClientRect(hChild,&rc);
428 ResizeIconWindow(hMain,hToolDlg,hColorDlg,rc.right,rc.bottom);
429
430 //アイコンタイプコンボボックスをセット
431 ResetIconType(i);
432
433 if(MdiInfo[i]->MdiIconEditInfo->num<=1)
434 EnableWindow(GetDlgItem(hToolDlg,IDC_DELETE_ICONTYPE),0);
435
436 //Docコンボボックスに追加
437 i=SendMessage(hDocCombo,CB_ADDSTRING,0,(long)str);
438 SendMessage(hDocCombo,CB_SETCURSEL,i,0);
439
440 //タブに追加
441 pobj_MainTab->InsertItem( str, true );
442
443 SetStatusText(NULL);
444
445 //メニュー状態を設定
446 ResetState_DocMenu();
447}
448void SaveIconFile(char *filepath,HWND hwnd){
449 int i,i2,WndNum;
450 char buffer[8192],temporary[MAX_PATH];
451 int ImgBufSize[8];
452
453 WndNum=GetWndNum(hwnd);
454
455 i2=0;
456
457 ///////////
458 // ICONDIR
459 *((WORD *)(buffer+i2))=0; //idReserved
460 i2+=sizeof(WORD);
461 *((WORD *)(buffer+i2))=1; //idType
462 i2+=sizeof(WORD);
463 *((WORD *)(buffer+i2))=MdiInfo[WndNum]->MdiIconEditInfo->num; //idCount
464 i2+=sizeof(WORD);
465
466 ////////////////
467 // ICONDIRENTRY
468 ICONDIRENTRY IconDirEntry;
469 memset(&IconDirEntry,0,sizeof(ICONDIRENTRY));
470
471 //イメージバッファの初期位置
472 IconDirEntry.dwImageOffset=sizeof(ICONDIR)+
473 sizeof(ICONDIRENTRY)*MdiInfo[WndNum]->MdiIconEditInfo->num;
474
475 for(i=0;i<MdiInfo[WndNum]->MdiIconEditInfo->num;i++){
476 BITMAPINFOHEADER *pBmpInfoHdr;
477 pBmpInfoHdr=(BITMAPINFOHEADER *)MdiInfo[WndNum]->MdiIconEditInfo->pIconImage[i];
478
479 IconDirEntry.bWidth=(BYTE)pBmpInfoHdr->biWidth;
480 IconDirEntry.bHeight=(BYTE)pBmpInfoHdr->biHeight/2;
481 if(pBmpInfoHdr->biBitCount<=8)
482 IconDirEntry.bColorCount=(BYTE)pow((double)2,(double)pBmpInfoHdr->biBitCount);
483 else IconDirEntry.bColorCount=0;
484
485 IconDirEntry.dwBytesInRes=sizeof(BITMAPINFOHEADER);
486 if(pBmpInfoHdr->biBitCount<=8) //256色以下の場合はカラーパレットのサイズを考慮
487 IconDirEntry.dwBytesInRes+=(DWORD)pow((double)2,(double)pBmpInfoHdr->biBitCount)*sizeof(long);
488 IconDirEntry.dwBytesInRes+=pBmpInfoHdr->biBitCount*pBmpInfoHdr->biWidth*(pBmpInfoHdr->biHeight/2)/8;
489 if(pBmpInfoHdr->biWidth==16){
490 //16*16のアイコン
491 IconDirEntry.dwBytesInRes+=pBmpInfoHdr->biWidth*(pBmpInfoHdr->biHeight/2)/8*2;
492 }
493 else{
494 //32*32のアイコン
495 IconDirEntry.dwBytesInRes+=pBmpInfoHdr->biWidth*(pBmpInfoHdr->biHeight/2)/8;
496 }
497
498 ImgBufSize[i]=IconDirEntry.dwBytesInRes;
499
500 memcpy(buffer+i2,&IconDirEntry,sizeof(ICONDIRENTRY));
501 i2+=sizeof(ICONDIRENTRY);
502
503 IconDirEntry.dwImageOffset+=IconDirEntry.dwBytesInRes;
504 }
505
506 ////////////////////
507 // イメージバッファ
508 for(i=0;i<MdiInfo[WndNum]->MdiIconEditInfo->num;i++){
509 memcpy(buffer+i2,
510 MdiInfo[WndNum]->MdiIconEditInfo->pIconImage[i],
511 ImgBufSize[i]);
512
513 i2+=ImgBufSize[i];
514 }
515
516
517 //ファイルへ書き込み
518 HANDLE hFile;
519 DWORD dummy;
520 hFile=CreateFile(filepath,GENERIC_WRITE,0,NULL,CREATE_ALWAYS,FILE_ATTRIBUTE_NORMAL,NULL);
521 if(hFile==INVALID_HANDLE_VALUE){
522 //"\"%s\" ファイルへの書き込みに失敗しました。"
523 sprintf(temporary,STRING_ERROR_CANT_FILESAVE,filepath);
524 MessageBox(hOwner,temporary,STRING_ERROR,MB_OK|MB_ICONSTOP);
525 return;
526 }
527 WriteFile(hFile,buffer,i2,&dummy,NULL);
528 CloseHandle(hFile);
529}
530
531LRESULT CALLBACK MDIClientWindow_IconEdit(HWND hwnd,UINT message,WPARAM wParam,LPARAM lParam){
532 extern HWND hDocCombo;
533 int i,WndNum;
534
535 switch(message){
536 case WM_MDIACTIVATE:
537 if(!lParam) return 0;
538 i=GetWndNum((HWND)lParam);
539 if(i==-1) return 0; //ウィンドウが初期状態の場合
540
541 i=SendMessage(hDocCombo,CB_FINDSTRINGEXACT,0,(long)MdiInfo[i]->title.c_str());
542 SendMessage(hDocCombo,CB_SETCURSEL,i,0);
543 SetStatusText(NULL);
544 ResetState_EditMenu();
545 return 0;
546 case WM_SIZE:
547 WndNum=GetWndNum(hwnd);
548 if(WndNum==-1) break;
549 ResizeIconWindow(MdiInfo[WndNum]->MdiIconEditInfo->hMain,
550 MdiInfo[WndNum]->MdiIconEditInfo->hToolDlg,
551 MdiInfo[WndNum]->MdiIconEditInfo->hColorDlg,
552 LOWORD(lParam),HIWORD(lParam));
553 break;
554 case WM_CLOSE:
555 CloseDocWindow(GetWndNum(hwnd));
556 pobj_nv->bMDIZoomed=IsZoomed(hwnd);
557 i=DefMDIChildProc(hwnd,message,wParam,lParam);
558
559 //メニュー状態を設定
560 ResetState_DocMenu();
561
562 return i;
563 }
564 return DefMDIChildProc(hwnd,message,wParam,lParam);
565}
Note: See TracBrowser for help on using the repository browser.