Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.10.30;
Скачать: CL | DM;

Вниз

Перетаскивание формы   Найти похожие ветки 

 
vvvaaa   (2005-08-25 15:13) [0]

procedure WMNCHitTest(var M: TWMNCHitTest); message wm_NCHitTest;

   ...

procedure TForm1.WMNCHitTest(var M: TWMNCHitTest);
begin
 inherited;
 if M.Result = htClient then M.Result := htCaption;
end;

А как сделать этоже на чистом API?


 
Leonid Troyanovsky ©   (2005-08-25 15:31) [1]


> vvvaaa   (25.08.05 15:13)  
> А как сделать этоже на чистом API?


Например, можно сделать на грязном,
а потом слегка почистить.

--
Regards, LVT.


 
vvvaaa   (2005-08-25 15:57) [2]

ok покажи как на на грязном, а на счет почисить чёнить придумаю


 
alpet ©   (2005-08-25 15:59) [3]

Создай окно, организуй ему оконную процедуру, и запусти цикл сообщений. Для сообщения сделай проверку в оконной процедуре.

Simple demonstration code:

Uses Windows, Messages, ExtCtrls, Printers;
var hMainWnd: THandle;
   hCtrls: array of THandle;
   msg: tagMSG;

function RegClassEx (name: PAnsiChar; wFunc: Pointer; style: dword): Boolean;
var
  wclass: WNDCLASSEXA;
begin
result := true;
fillchar (wclass, sizeof (wclass), 0);
wclass.cbSize := sizeof (wclass);
if not GetClassInfoEx (hInstance, PChar (name), wclass) then
 begin
  wclass.cbSize := sizeof (wclass);
  wclass.lpszClassName := name;
  wclass.lpfnWndProc := wFunc;
  wclass.style := style;
  wclass.hInstance := hInstance;
  wclass.hbrBackground := GetSysColorBrush (COLOR_BTNFACE);
  wclass.hCursor := LoadCursor (0, IDC_ARROW);
  result := RegisterClassEx (wclass) <> 0;
 end;
end;

function OnCreate: Bool;
begin
// some actions on create
result := false;
end;

function MainWndFunc (hWnd: THandle; uMsg, wParam, lParam: dword): Integer; stdcall;
var bHandled: Bool;
begin
result := 0;
bHandled := false;
case uMsg of
 WM_CREATE: bHandled := OnCreate;
 WM_CLOSE: bHandled := DestroyWindow (hWnd);
end;
if not bHandled then result := DefWindowProc (hWnd, uMsg, wParam, lParam);
end; // MainWndFunc

function CreateWndIndirect (const cs: tagCREATESTRUCTA; ctrl_id: dword = 0): HWND;
begin
with cs do
result := CreateWindowEx (dwExStyle, lpszClass, lpszName,
                          style, x, y, cx, cy,
                          hwndParent, 0, hInstance, @cs);
if (ctrl_id <> 0) and (result <> 0) then
   SetWindowLong (result, GWL_ID, ctrl_id);
end;

procedure SetCSRect (var cs: tagCREATESTRUCTA; x, y, cx, cy: Integer);
begin
cs.x := x;
cs.y := y;
cs.cx := cx;
cs.cy := cy;
end;

const wClassName = "DemoWindowClass";
var cs: tagCREATESTRUCTA;
begin
{ ... }
if not RegClassEx (wClassName, @MainWndFunc,
                      CS_HREDRAW or CS_VREDRAW or CS_OWNDC) then exit;

fillChar (cs, sizeof (cs), 0);
cs.dwExStyle := WS_EX_APPWINDOW or WS_EX_CONTROLPARENT or WS_EX_DLGMODALFRAME;
cs.style := WS_VISIBLE or WS_CLIPCHILDREN or WS_OVERLAPPEDWINDOW or WS_TABSTOP;
cs.lpszName := "Caption";
cs.lpszClass := wClassName;
cs.hInstance := hInstance;
SetCSRect (cs, CW_USEDEFAULT, CW_USEDEFAULT, 240, 150);
hMainWnd := CreateWndIndirect (cs);
{ Creating child controls }
SetLength (hCtrls, 2);
cs.lpszClass := "button";
cs.lpszName := "ok";
cs.hwndParent := hMainWnd;
cs.style := BS_PUSHBUTTON or WS_VISIBLE or WS_CLIPSIBLINGS or WS_CHILD or WS_TABSTOP;
cs.dwExStyle := 0;
SetCSREct (cs, 10, 10, 200, 25);
hCtrls [0] := CreateWndIndirect (cs, 101);
cs.lpszName := "cancel";
SetCSRect (cs, 10, 50, 200, 25);
hCtrls [1] := CreateWndIndirect (cs, 102);

while (IsWindow (hMainWnd) and GetMessage (msg, 0, 0, 0)) do
 begin
  TranslateMessage (msg);
  DispatchMessage (msg);
  if (msg.message = WM_CHAR) and (msg.wParam = VK_TAB) then
   begin
    //PostMessage (hMainWnd, WM_NEXTDLGCTL, 0, 0);
    if GetFocus = hCtrls [0] then SetFocus (hCtrls [1]) else SetFocus (hCtrls [0]);
   end;
 end;
end.


 
vvvaaa   (2005-08-25 16:06) [4]

Спасибо конечно, но как создавать форму и объекты я знаю. Меня интересует конкретно обработка собщения WM_NCHITTEST


 
Leonid Troyanovsky ©   (2005-08-25 16:19) [5]


> vvvaaa   (25.08.05 15:57) [2]
> ok покажи как на на грязном, а на счет почисить чёнить придумаю


Вставь в оконную процедуру, что-то вроде:


 case msg of
  ..
  WM_NCHITTEST:
    begin
      Result := DefWindowProc(wnd, msg, awparam, alparam);
        if Result = HTCLIENT then
          begin
            Result := HTCAPTION;
            Exit;
          end;
    end;


--
Regards, LVT.


 
vvvaaa   (2005-08-25 16:26) [6]

> Leonid Troyanovsky ©   (25.08.05 16:19) [5]
Спасибо, то что надо



Страницы: 1 вся ветка

Текущий архив: 2005.10.30;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.043 c
3-1126694978
erika
2005-09-14 14:49
2005.10.30
Соединение с ервером через инет


14-1128540143
Kerk
2005-10-05 23:22
2005.10.30
Достали спамеры!


2-1128778852
Виталий09
2005-10-08 17:40
2005.10.30
Как получить информацию из файла с инета


2-1128759906
KLOD
2005-10-08 12:25
2005.10.30
помогите пожалуйста считать из типизированного файла записи


3-1127203717
suharew
2005-09-20 12:08
2005.10.30
Индексы, поиск





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский