/*[]=====================================================================[]*/ /*[] LeadTools Run Time Library - Version 14 []*/ /*[] []*/ /*[] []*/ /*[] Copyright (c) 1991-2004 LEAD Technologies, Inc. []*/ /*[] All Rights Reserved. []*/ /*[]=====================================================================[]*/ #include "ImgPF.h" static L_BOOL RippleDialog_OnCommand (HWND hWnd, L_INT id, HWND hWndCtl, L_UINT codeNotify); static L_BOOL RippleDialog_OnHScroll (HWND hWnd, HWND hWndCtl, L_UINT nCode, L_INT nPos); static L_BOOL RippleDialog_OnInitDialog (HWND hWnd, HWND hWndFocus, LPARAM lParam); static L_BOOL RippleDialog_OnPaint (HWND hWnd); static L_VOID RippleDialog_OnTimer (HWND hWnd, L_INT ID); static L_VOID L_ApplyFilter (HWND hWnd); L_BOOL CALLBACK RippleDlgProc (HWND hWnd, L_UINT message, WPARAM wParam, LPARAM lParam) { switch(message) { HANDLE_MSG (hWnd, WM_COMMAND, RippleDialog_OnCommand); HANDLE_MSG (hWnd, WM_INITDIALOG, RippleDialog_OnInitDialog); HANDLE_MSG (hWnd, WM_HSCROLL, RippleDialog_OnHScroll); HANDLE_MSG (hWnd, WM_PAINT, RippleDialog_OnPaint); HANDLE_MSG (hWnd, WM_TIMER, RippleDialog_OnTimer); case WM_USER_UPDATEVIEW: StatusProc.ProgressValue = 100; L_ApplyFilter (hWnd); break; } return FALSE; } static LRESULT CALLBACK Mouse(L_INT nCode, WPARAM wParam, LPARAM lParam) { LPRIPDLGDATA pRipDlgData; LPMOUSEHOOKSTRUCT pMouseHook; HWND hWndParent; pCHILDDATA pData; RECT rcRect; POINT TmpPoint; DWORD dwStyle; hWndParent = FORWARD_WM_MDIGETACTIVE(hWndClient,SendMessage); pData = LOCKCHILDDATA (hWndParent); pRipDlgData = (LPRIPDLGDATA)GetWindowLong(hGlobalWnd, GWL_USERDATA); pMouseHook = (LPMOUSEHOOKSTRUCT)lParam; GetWindowRect(hGlobalWnd, &rcRect); if (PtInRect(&rcRect, pMouseHook->pt)) return 0; switch(LOWORD(wParam)) { case WM_NCMOUSEMOVE: TmpPoint = pMouseHook->pt; if (PtInRect(&rcRect, TmpPoint)) break; if (pRipDlgData->bPushed) { PostMessage (hWndParent, WM_USER_CHANGECURSOR, 0, (LONG)IDC_CROSS); } else { dwStyle = GetWindowLong (hWndParent, GWL_STYLE); if ((WS_VSCROLL & dwStyle) || (WS_HSCROLL & dwStyle)) PostMessage(hWndParent, WM_USER_CHANGECURSOR, (WPARAM)hInst, (LONG)MAKEINTRESOURCE(IDC_CURS11)); ScreenToClient(hWndParent, &pMouseHook->pt); GetClientRect(hGlobalWnd, &rcRect); if (!PtInRect(&rcRect, pMouseHook->pt)) SendMessage((hWndParent), WM_MOUSEMOVE, wParam, MAKELPARAM((pMouseHook->pt.x), (pMouseHook->pt.y))); } break; case WM_NCLBUTTONDOWN: TmpPoint = pMouseHook->pt; if (PtInRect(&rcRect, TmpPoint)) break; if (pRipDlgData->bPushed) { PostMessage (hWndParent, WM_USER_CHANGECURSOR, 0, (LONG)IDC_CROSS); ScreenToClient(hWndParent, &pMouseHook->pt); GetClientRect(hWndParent, &rcRect); if (PtInRect(&pData->rcView, pMouseHook->pt)) { if (L_BitmapHasRgn(&pData->LeadBitmap)) { L_GetBitmapRgnBounds(&pData->LeadBitmap, NULL, &rcRect); TmpPoint.x = pMouseHook->pt.x + pData->nHScrollPos; TmpPoint.y = pMouseHook->pt.y + pData->nVScrollPos; if (!PtInRect(&rcRect, TmpPoint)) return CallNextHookEx(pRipDlgData->hMouseHook , nCode, wParam, lParam); } pData->ptCenter.x = pRipDlgData->ptCenter.x = pMouseHook->pt.x + pData->nHScrollPos; pData->ptCenter.y = pRipDlgData->ptCenter.y = pMouseHook->pt.y + pData->nVScrollPos; SetDlgItemInt(hGlobalWnd, IDC_RIP_XPOS_EDT, pRipDlgData->ptCenter.x, TRUE); SetDlgItemInt(hGlobalWnd, IDC_RIP_YPOS_EDT, pRipDlgData->ptCenter.y, TRUE); InvalidateRect(hWndParent, NULL, FALSE); L_ApplyFilter (hGlobalWnd); PostMessage (hWndParent, WM_USER_CHANGECURSOR, 0, (LONG)IDC_CROSS); } else { PostMessage (hWndParent, WM_USER_CHANGECURSOR, 0, (LONG)IDC_ARROW); } } else { dwStyle = GetWindowLong (hWndParent, GWL_STYLE); if ((WS_VSCROLL & dwStyle) || (WS_HSCROLL & dwStyle)) PostMessage(hWndParent, WM_USER_CHANGECURSOR, (WPARAM)hInst, (LONG)MAKEINTRESOURCE(IDC_CURS11)); ScreenToClient(hWndParent, &pMouseHook->pt); SendMessage(hWndParent, WM_LBUTTONDOWN, wParam, MAKELPARAM((pMouseHook->pt.x), (pMouseHook->pt.y))); } break; case WM_NCLBUTTONUP: TmpPoint = pMouseHook->pt; if (PtInRect(&rcRect, TmpPoint)) break; if (pRipDlgData->bPushed) { PostMessage (hWndParent, WM_USER_CHANGECURSOR, 0, (LONG)IDC_CROSS); } else { dwStyle = GetWindowLong (hWndParent, GWL_STYLE); if ((WS_VSCROLL & dwStyle) || (WS_HSCROLL & dwStyle)) PostMessage(hWndParent, WM_USER_CHANGECURSOR, (WPARAM)hInst, (LONG)MAKEINTRESOURCE(IDC_CURS11)); ScreenToClient(hWndParent, &pMouseHook->pt); GetClientRect(hGlobalWnd, &rcRect); if (!PtInRect(&rcRect, pMouseHook->pt)) SendMessage(hWndParent, WM_LBUTTONUP, wParam, MAKELPARAM((pMouseHook->pt.x), (pMouseHook->pt.y))); } break; } if (pRipDlgData) { if (LOWORD(wParam) >= WM_NCMOUSEMOVE && LOWORD(wParam) <= WM_NCMBUTTONDBLCLK) return TRUE; else return CallNextHookEx(pRipDlgData->hMouseHook , nCode, wParam, lParam); } else return FALSE; } static L_BOOL RippleDialog_OnInitDialog (HWND hWnd, HWND hWndFocus, LPARAM lParam) { LPRIPDLGDATA pRipDlgData; HWND hWndParent; pCHILDDATA pData; RECT rcRgn; L_INT nRangeMax[] = {100, 100, 1000, 360, 0, 0}; L_INT nRangeMin[] = {0, 1, 0, -360, 0, 0}; L_INT nPosInit [] = {30, 6, 0, 0, 0, 0}; L_INT nSlider; hWndParent = FORWARD_WM_MDIGETACTIVE(hWndClient,SendMessage); pData = LOCKCHILDDATA (hWndParent); pRipDlgData = (LPRIPDLGDATA)lParam; hGlobalWnd = hWnd; pData->bCross = TRUE; MoveDialogToMiddle(hWnd); SetWindowLong(hWnd,GWL_USERDATA,(LONG)pRipDlgData); //MEMDISK...// MemorizeAndCopyBitmap (hWndParent, &pRipDlgData->Bitmap); L_GetBitmapRgnBounds(&pRipDlgData->Bitmap, NULL, &rcRgn); ComboBox_AddString(GetDlgItem(hWnd, IDC_RIP_FILL_COM), TEXT("Fill Color")); ComboBox_AddString(GetDlgItem(hWnd, IDC_RIP_FILL_COM), TEXT("Repeat Edge")); ComboBox_AddString(GetDlgItem(hWnd, IDC_RIP_FILL_COM), TEXT("No Change")); ComboBox_SetCurSel(GetDlgItem(hWnd, IDC_RIP_FILL_COM), 1); Progress_SetRange(StatusProc.ProgWnd, 0, 100); Progress_SetPos(StatusProc.ProgWnd, 0); StatusProc.bProgress = TRUE; StatusProc.bInvalidate = FALSE; StatusProc.bEnd = FALSE; StatusProc.DlgWnd = hWnd; StatusProc.ProgressValue = 100; StatusProc.ProgWnd = GetDlgItem(hWnd, IDC_RIP_PROG); memset (pRipDlgData->nPostionH, 0, 6 * sizeof(L_INT)); nPosInit[4] = pRipDlgData->ptCenter.x = pData->ptCenter.x = (rcRgn.right + rcRgn.left) / 2; nPosInit[5] = pRipDlgData->ptCenter.y = pData->ptCenter.y = (rcRgn.bottom + rcRgn.top) / 2; pRipDlgData->nAmp = 30; pRipDlgData->nFreq = 6; pRipDlgData->nAtten = 0; pRipDlgData->nPhase = 0; pRipDlgData->uFlag = FILL_RPT ; pRipDlgData->nPostionH[1] = 1; nRangeMax[4] = rcRgn.right; nRangeMax[5] = rcRgn.bottom; nRangeMin[4] = rcRgn.left; nRangeMin[5] = rcRgn.top; pRipDlgData->nSlideNum = 6; pRipDlgData->nSldBaseID = IDC_RIP_AMP_SLD; pRipDlgData->nEdtBaseID = IDC_RIP_AMP_EDT; for (nSlider = 0; nSlider < pRipDlgData->nSlideNum; nSlider++) { Trackbar_SetRange(GetDlgItem(hWnd, pRipDlgData->nSldBaseID + nSlider), TRUE, nRangeMin[nSlider], nRangeMax[nSlider]); SetDlgItemInt(hWnd, pRipDlgData->nEdtBaseID + nSlider, nPosInit[nSlider], TRUE); SetNumericEditBox(GetDlgItem(hWnd, pRipDlgData->nEdtBaseID + nSlider), nRangeMin[nSlider], nRangeMax[nSlider], 1, 0, FALSE); } pRipDlgData->bPushed = FALSE; pRipDlgData->hIcon = LoadIcon(hInst, MAKEINTRESOURCE(IDI_MOUSE)); SendMessage(GetDlgItem(hWnd, IDC_RIP_POS_BTN), BM_SETIMAGE, IMAGE_ICON, (LPARAM)(HICON)pRipDlgData->hIcon); pRipDlgData->hMouseHook = SetWindowsHookEx(WH_MOUSE, Mouse, hInst, GetCurrentThreadId()); pData->uTimerID = SetTimer(hWnd, 1, 100, NULL); ShowWindow(hWnd, SW_SHOW); L_ApplyFilter(hWnd); return ( TRUE ); } static L_VOID RippleDialog_OnTimer (HWND hWnd, L_INT ID) { Dialog_Timer(ID); } static L_BOOL RippleDialog_OnPaint(HWND hWnd) { HDC hdc; PAINTSTRUCT ps; RECT Rect; HBRUSH hbrush; LPRIPDLGDATA pRipDlgData; pRipDlgData = (LPRIPDLGDATA) GetWindowLong(hWnd, GWL_USERDATA); GetClientRect(GetDlgItem(hWnd , IDC_RIP_COLOR_TXT), &Rect); hdc = BeginPaint(GetDlgItem(hWnd, IDC_RIP_COLOR_TXT),&ps); hbrush = CreateSolidBrush(pRipDlgData->crColor); FillRect(hdc, &Rect, !ComboBox_GetCurSel(GetDlgItem(hWnd, IDC_RIP_FILL_COM)) ? hbrush : (HBRUSH) COLOR_WINDOW); DeleteObject (hbrush); EndPaint(GetDlgItem(hWnd, IDC_RIP_COLOR_TXT), &ps); return FALSE; } static L_BOOL RippleDialog_OnCommand (HWND hWnd, L_INT id, HWND hWndCtl, L_UINT codeNotify) { LPRIPDLGDATA pRipDlgData; HWND hWndParent; L_INT nRangeMax[] = {100, 100, 1000, 360, 0, 0}; L_INT nRangeMin[] = {0, 1, 0, -360, 0, 0}; HWND hCtl; pCHILDDATA pData; L_INT nValue, nIndex; RECT rcRgn; COLORREF crColor; hWndParent = FORWARD_WM_MDIGETACTIVE(hWndClient,SendMessage); pData = LOCKCHILDDATA (hWndParent); pRipDlgData = (LPRIPDLGDATA) GetWindowLong(hWnd, GWL_USERDATA); L_GetBitmapRgnBounds(&pRipDlgData->Bitmap, NULL, &rcRgn); nRangeMax[4] = rcRgn.right; nRangeMax[5] = rcRgn.bottom; nRangeMin[4] = rcRgn.left; nRangeMin[5] = rcRgn.top; if (id >= pRipDlgData->nEdtBaseID && id < pRipDlgData->nEdtBaseID + pRipDlgData->nSlideNum) { if(codeNotify == EN_CHANGE) { nValue = GetDlgItemInt(hWnd, id, NULL, TRUE); hCtl = GetDlgItem(hWnd,id + pRipDlgData->nSlideNum); nIndex = id - pRipDlgData->nEdtBaseID; Trackbar_SetPos(hCtl, TRUE, nValue); if(nValue > nRangeMax[nIndex]) { SetDlgItemInt(hWnd, id, nRangeMax[nIndex], TRUE); return FALSE; } if(nValue < nRangeMin[nIndex]) { SetDlgItemInt(hWnd, id, nRangeMin[nIndex], TRUE); return FALSE; } switch (nIndex) { case 0: if(pRipDlgData->nAmp == (L_UINT)nValue) return TRUE; pRipDlgData->nAmp = nValue; break; case 1: if(pRipDlgData->nFreq == (L_UINT)nValue) return TRUE; pRipDlgData->nFreq = nValue; break; case 2: if(pRipDlgData->nAtten== (L_UINT)nValue) return TRUE; pRipDlgData->nAtten = nValue; break; case 3: if(pRipDlgData->nPhase == nValue) return TRUE; pRipDlgData->nPhase = nValue; break; case 4: if(pRipDlgData->ptCenter.x == nValue) return TRUE; pRipDlgData->ptCenter.x = nValue; pData->ptCenter.x = nValue; break; case 5: if(pRipDlgData->ptCenter.y == nValue) return TRUE; pRipDlgData->ptCenter.y = nValue; pData->ptCenter.y = nValue; break; } L_ApplyFilter (hWnd); } } switch (id) { case IDC_RIP_POS_BTN: pRipDlgData->bPushed = Button_GetCheck(hWndCtl); break; case IDC_RIP_COLOR_BTN: crColor = pRipDlgData->crColor; pRipDlgData->crColor = ShowColorDialog(hWnd, crColor); if (crColor != pRipDlgData->crColor) { InvalidateRect(hWnd, NULL, FALSE); L_ApplyFilter (hWnd); } break; case IDC_RIP_FILL_COM: if (codeNotify == CBN_SELCHANGE) { nIndex = (ComboBox_GetCurSel(GetDlgItem(hWnd, IDC_RIP_FILL_COM))); if (pRipDlgData->uFlag != ((pRipDlgData->uFlag & 0xFFFFFFF0) | nIndex)) { EnableWindow(GetDlgItem(hWnd, IDC_RIP_COLOR_BTN), !ComboBox_GetCurSel(hWndCtl)); pRipDlgData->uFlag = pRipDlgData->uFlag & 0xFFFFFFF0; pRipDlgData->uFlag = pRipDlgData->uFlag | nIndex; InvalidateRect(hWnd, NULL, FALSE); InvalidateRect(hWndCtl, NULL, FALSE); L_ApplyFilter (hWnd); } } break; case IDCANCEL: pData->bCross = FALSE; StatusProc.bProgress = FALSE; StatusProc.bKillProgress = TRUE ; StatusProc.ProgressValue = 100 ; UnhookWindowsHookEx(pRipDlgData->hMouseHook); DestroyIcon(pRipDlgData->hIcon); EndDialog(hWnd, FALSE); break; case IDOK: pData->bCross = FALSE; ShowStatusWindow(FALSE); StatusProc.bStillWork = TRUE; StatusProc.bInvalidate = TRUE; StatusProc.bEnd = TRUE; UnhookWindowsHookEx(pRipDlgData->hMouseHook); DestroyIcon(pRipDlgData->hIcon); EndDialog(hWnd, TRUE); break; } return TRUE; } static L_BOOL RippleDialog_OnHScroll (HWND hWnd, HWND hWndCtl, L_UINT nCode, L_INT nPos) { LPRIPDLGDATA pRipDlgData; pRipDlgData = (LPRIPDLGDATA) GetWindowLong(hWnd, GWL_USERDATA); SetDlgItemInt(hWnd, GetDlgCtrlID(hWndCtl) - pRipDlgData->nSlideNum , Trackbar_GetPos(hWndCtl), TRUE); return TRUE; } L_VOID L_ApplyFilter (HWND hWnd) { pCHILDDATA pData; L_INT nRet = 0; HWND hWndParent; LPRIPDLGDATA pRipDlgData; if ( 100 != StatusProc.ProgressValue ) { StatusProc.bKillProgress = TRUE ; return ; } pRipDlgData = (LPRIPDLGDATA) GetWindowLong(hWnd,GWL_USERDATA); hWndParent = FORWARD_WM_MDIGETACTIVE(hWndClient,SendMessage); pData = LOCKCHILDDATA (hWndParent); FreeMemorizedBitmap (hWndParent); //MEMDISK// L_CopyBitmap(&pData->LeadBitmap, &pRipDlgData->Bitmap, sizeof(BITMAPHANDLE)); nRet = L_RippleBitmap(&pData->LeadBitmap, pRipDlgData->nAmp, pRipDlgData->nFreq, pRipDlgData->nPhase * 100, pRipDlgData->nAtten, pRipDlgData->ptCenter, pRipDlgData->crColor, pRipDlgData->uFlag); if(nRet == SUCCESS) { InvalidateRect(hWndParent, NULL, FALSE); StatusProc.ProgressValue = 100; Progress_SetPos(StatusProc.ProgWnd , 0); if(StatusProc.bEnd) { StatusProc.bProgress = FALSE; StatusProc.bKillProgress = TRUE ; } } }