/*[]=====================================================================[]*/ /*[] LeadTools Run Time Library - Version 14 []*/ /*[] []*/ /*[] []*/ /*[] Copyright (c) 1991-2004 LEAD Technologies, Inc. []*/ /*[] All Rights Reserved. []*/ /*[]=====================================================================[]*/ #include "ImgPF.h" static L_BOOL HistoEqDlg_OnCommand (HWND hWnd, L_INT nID, HWND hWndCtl, L_UINT codeNotify); static L_BOOL HistoEqDlg_OnInitDialog (HWND hWnd, HWND hWndFocus, LPARAM lParam); static L_VOID HistoEqDlg_OnTimer (HWND hWnd, L_INT nID); static L_VOID L_ApplyFilter (HWND hWnd); L_BOOL CALLBACK HsEqDlgProc (HWND hWnd, L_UINT uMessage, WPARAM wParam, LPARAM lParam) { switch(uMessage) { HANDLE_MSG (hWnd, WM_COMMAND, HistoEqDlg_OnCommand); HANDLE_MSG (hWnd, WM_INITDIALOG, HistoEqDlg_OnInitDialog); HANDLE_MSG (hWnd, WM_TIMER, HistoEqDlg_OnTimer); case WM_USER_UPDATEVIEW: StatusProc.ProgressValue = 100; L_ApplyFilter(hWnd); break; } return FALSE; } static L_BOOL HistoEqDlg_OnInitDialog (HWND hWnd, HWND hWndFocus, LPARAM lParam) { LPHSEQDLGDATA pHsEqDlgData; pCHILDDATA pData; HWND hWndParent; hWndParent = FORWARD_WM_MDIGETACTIVE(hWndClient,SendMessage); pData = LOCKCHILDDATA (hWndParent); pHsEqDlgData = (LPHSEQDLGDATA)lParam; MoveDialogToMiddle(hWnd); SetWindowLong(hWnd,GWL_USERDATA,(LONG)pHsEqDlgData); Progress_SetRange(StatusProc.ProgWnd, 0, 100); Progress_SetPos(StatusProc.ProgWnd, 0); //MEMDISK...// MemorizeAndCopyBitmap (hWndParent, &pHsEqDlgData->Bitmap); StatusProc.bProgress = TRUE; StatusProc.bInvalidate = FALSE; StatusProc.bEnd = FALSE; StatusProc.DlgWnd = hWnd; StatusProc.ProgressValue = 100; StatusProc.ProgWnd = GetDlgItem(hWnd, IDC_HSEQ_PROG); UpdateWindow(hWnd); ShowWindow(hWnd, SW_SHOW); pHsEqDlgData->nRdoBaseID = IDC_HSEQ_RGBSPACE_RAD; pHsEqDlgData->nRadioNum = 3; pHsEqDlgData->uFlage = YUV_SPACE; Button_SetCheck(GetDlgItem(hWnd, IDC_HSEQ_YUVSPACE_RAD), TRUE); pData->uTimerID = SetTimer(hWnd, 1, 100, NULL); L_ApplyFilter (hWnd); return ( TRUE ); } static L_VOID HistoEqDlg_OnTimer (HWND hWnd, L_INT nID) { Dialog_Timer(nID); } static L_BOOL HistoEqDlg_OnCommand (HWND hWnd, L_INT nID, HWND hWndCtl, L_UINT codeNotify) { HWND hWndParent; pCHILDDATA pData; L_INT nIndex; LPHSEQDLGDATA pHsEqDlgData; hWndParent = FORWARD_WM_MDIGETACTIVE(hWndClient,SendMessage); pData = LOCKCHILDDATA (hWndParent); pHsEqDlgData = (LPHSEQDLGDATA) GetWindowLong(hWnd, GWL_USERDATA); if (nID >= pHsEqDlgData->nRdoBaseID && nID < pHsEqDlgData->nRdoBaseID + pHsEqDlgData->nRadioNum) { nIndex = nID - pHsEqDlgData->nRdoBaseID; if (pHsEqDlgData->uFlage == (L_UINT)(1 << nIndex)) return FALSE; pHsEqDlgData->uFlage = 1 << nIndex; L_ApplyFilter (hWnd); return TRUE; } switch (nID) { case IDCANCEL: StatusProc.bProgress = FALSE; StatusProc.bKillProgress = TRUE ; StatusProc.ProgressValue = 100 ; EndDialog(hWnd, FALSE); break; case IDOK: ShowStatusWindow(FALSE); StatusProc.bStillWork = TRUE; StatusProc.bInvalidate = TRUE; StatusProc.bEnd = TRUE; EndDialog(hWnd, TRUE); break; } return TRUE; } static L_VOID L_ApplyFilter (HWND hWnd) { pCHILDDATA pData; L_INT nRet = 0; HWND hWndParent; LPHSEQDLGDATA pHsEqDlgData; if ( 100 != StatusProc.ProgressValue ) { StatusProc.bKillProgress = TRUE ; return ; } pHsEqDlgData = (LPHSEQDLGDATA) GetWindowLong(hWnd,GWL_USERDATA); hWndParent = FORWARD_WM_MDIGETACTIVE(hWndClient,SendMessage); pData = LOCKCHILDDATA (hWndParent); FreeMemorizedBitmap (hWndParent); //MEMDISK// L_CopyBitmap(&pData->LeadBitmap, &pHsEqDlgData->Bitmap, sizeof(BITMAPHANDLE)); nRet = L_HistoEqualizeBitmap(&pData->LeadBitmap, pHsEqDlgData->uFlage); if(nRet == SUCCESS) { InvalidateRect(hWndParent, NULL, FALSE); StatusProc.ProgressValue = 100; Progress_SetPos(StatusProc.ProgWnd , 0); if(StatusProc.bEnd) { StatusProc.bProgress = FALSE; StatusProc.bKillProgress = TRUE ; } } }