summaryrefslogtreecommitdiff
path: root/demo/wince/SysInfo/sysinfo.pp
blob: 3b34b41a8eeb8c77ac97c4a36ec771fcdad01414 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
{WinCE API call sample : sysinfo
 show how to :
   - handle messages with loop using TObject.Dispatch
   - create form,
   - load resources (accelators/menubar)
   - show system informations using HDC

 sysinfo.rc file require .inc file for consts, if needed update #include path in this file

 changes :

 10-05-2005 : orinaudo@gmail.com
  first release
  win32(xp) cross compiled with fpc 2.1.x from today, tested on PPC arm-wince 4.21
  Tested on WM5
}

Program sysinfo;

{$APPTYPE GUI}
{$MODE DELPHI}
{$PACKRECORDS C}

Uses Strings, Windows, SysUtils, strutils, aygshell;

{$include appconst.inc}

{$R sysinfo.rc}


//*****************************************************************************
// Base Object (dispatch messages using FPC/TObject capabilities)
//*****************************************************************************
Function SysInfoMainWndProc (pMainHWnd:HWnd; piMessage : UINT; pWParam : WParam; pLParam:LParam): LResult; stdcall; forward;

type
 TMainSysInfo = Class(TObject)
  FPWClassName,
  FPWTitleName           : PWideChar;
  FAccelTable            : HACCEL;
  FMainHWnd              : HWND;
  FMenuBarHWnd           : HWND;
  FShellActivateInfo     : SHACTIVATEINFO;
  constructor Create;

  function WInit: boolean;
  function FWndProc( pMainHWnd:HWnd; piMessage : UINT; pWParam : WParam; pLParam:LParam): LResult;
  procedure DefaultHandler(var message); override;
  procedure DoCommand( var vAMessage : TMessage); message WM_COMMAND; virtual;
  procedure DoCreate( var vAMessage : TMessage); message WM_CREATE; virtual;
  procedure DoPaint( var vAMessage : TMessage); message WM_PAINT; virtual;
  procedure DoDestroy( var vAMessage : TMessage); message WM_DESTROY; virtual;
  procedure DoActivate( var vAMessage : TMessage); message WM_ACTIVATE; virtual;
  procedure DoSettingChange( var vAMessage : TMessage); message WM_SETTINGCHANGE; virtual;
 end;

//*****************************************************************************
// Global variables
//*****************************************************************************

var
  GMainSysInfo : TMainSysInfo;
  GMsg: MSG;

//*****************************************************************************

constructor TMainSysInfo.Create;
Begin
  inherited Create;
  FPWClassName:='TFormSysInfo';
  FPWTitleName:='SysInfo';
  FMainHWnd:=0;
  FMenuBarHWnd:=0;
  FAccelTable:=0;
end;

function TMainSysInfo.WInit : boolean;
var rc : RECT;
    wc : WNDCLASS;
begin
  //requirements of the Pocket PC shell, only one instance
  //If it is already running, then focus on the window
  FMainHWnd:=FindWindow( FPWClassName, FPWTitleName);
  if (FMainHWnd=0) then begin
    //register windows class
    With wc do begin
      Style := cs_hRedraw or cs_vRedraw;
      lpfnWndProc := WndProc(@SysInfoMainWndProc);
      cbClsExtra := 0;
      cbWndExtra := 0;
      hInstance := system.MainInstance;
      hIcon := LoadIcon(system.MainInstance,IDI_SYSINFO);
      hCursor := 0;
      hbrBackground := GetStockObject(WHITE_BRUSH);
      lpszMenuName := 0;
      lpszClassName := FPWClassName;
    End;
    RegisterClass(@wc);

    //create window
    FMainHWnd := CreateWindow (
                   FPWClassName, FPWTitleName, WS_VISIBLE, CW_USEDEFAULT,
                   CW_USEDEFAULT,CW_USEDEFAULT, CW_USEDEFAULT, 0,
                   0, system.MainInstance, 0);

    GetWindowRect(FMainHWnd, @rc);
    rc.bottom:= rc.bottom - 26; //26 is the menubar height
    if (FMenuBarHWnd>0)
    then MoveWindow(FMainHWnd, rc.left, rc.top, rc.right, rc.bottom, FALSE);

    ShowWindow(FMainHWnd, SW_SHOW);
    UpdateWindow(FMainHWnd);
    FAccelTable:= LoadAccelerators(System.MainInstance , MAKEINTRESOURCE(IDC_SYSINFO));
    Result:=True;
   end else begin
    SetForegroundWindow(FMainHWnd);
    Result:=False;
   end;
   //MessageBox(0,PWideChar(WideFormat('hMainInst/hMainWindow/hAccel = %d/%d/%d/ler: %d',[system.MainInstance,FMainHWnd, FAccelTable,GetLastError])),'Info', MB_OK);
end;

function TMainSysInfo.FWndProc( pMainHWnd:HWnd; piMessage : UINT; pWParam : WParam; pLParam:LParam): LResult;
var AMessage: TMessage;
begin
 //small hack, wm_create occur during creation -> createwindows function is not returned
 //so FMainHWnd still 0 and menubar need a parent !
 if (FMainHWnd=0) and (piMessage=WM_CREATE) then FMainHWnd:=pMainHWnd;

 with AMessage do begin
  msg := piMessage;
  wParam := pWParam;
  lParam := pLParam;
 end;
 Dispatch(AMessage);
 Result:=AMessage.Result;
end;

procedure TMainSysInfo.DefaultHandler(var message);
var PAMessage : PMessage;
begin
 with TMessage(message) do
  Result:=DefWindowProc(FMainHWnd, msg, wParam, lParam);
end;

procedure TMainSysInfo.DoCommand( var vAMessage : TMessage);
begin
  vAMessage.Result:=0;
  // Parse the menu selections:
  Case vAMessage.wParamlo of
    IDM_HELP_ABOUT:
      begin
        MessageBox(0,'SysInfo v1','About', MB_OK);
      end;
    IDOK:
      begin
        SendMessage(FMainHWnd, WM_ACTIVATE, MAKEWPARAM(WA_INACTIVE, 0), FMainHWnd);
	SendMessage (FMainHWnd, WM_CLOSE, 0, 0);
      end;
    IDM_QUIT:
      begin
        DestroyWindow(FMainHWnd);
      end;
    else vAMessage.Result:=DefWindowProc(FMainHWnd, vAMessage.msg, vAMessage.WParam, vAMessage.LParam);
  end;
end;

procedure TMainSysInfo.DoCreate( var vAMessage : TMessage);
var AMenuBarInfo : SHMENUBARINFO;
begin
  vAMessage.Result:=0;
  //create MenuBar
  FillByte(AMenuBarInfo,sizeof(SHMENUBARINFO),0);
  with AMenuBarInfo do begin
    cbSize := sizeof(SHMENUBARINFO);
    dwFlags:= 0; //SHCMBF_EMPTYBAR;
    hwndParent:= FMainHWnd;
    nToolBarId:= IDR_MENUBAR;
    hInstRes:= System.MainInstance;
    nBmpId:= 0;
    cBmpImages:= 0;
    hwndMB:= 0;
    clrBk :=0;
  end;
  if SHCreateMenuBar(@AMenuBarInfo)
  then FMenuBarHWnd:=AMenuBarInfo.hwndMB
  else FMenuBarHWnd:=0;
  //MessageBox(0,PWideChar(WideFormat('menu bar hwnd = %d / %d',[FMenuBarHWnd, GetLastError])),'Info', MB_OK);

  //Initialize the shell activate info structure
  FillByte(FShellActivateInfo,sizeof(SHACTIVATEINFO),0);
  FShellActivateInfo.cbSize := sizeof(SHACTIVATEINFO);
end;

procedure TMainSysInfo.DoPaint( var vAMessage : TMessage);
var rt     : RECT;
    ps     : PAINTSTRUCT;
    AHDC   : HDC;
    wzData : WideString;
begin
   vAMessage.Result:=0;
   AHDC:= BeginPaint(FMainHWnd, @ps);
   try
    GetClientRect(FMainHWnd, @rt);
    wzData:=WideFormat('Build : %d, WinCE v : %d.%d'#13+
                       'Plateform : %d'#13+
                       'CDS Version : %s',
                       [Sysutils.WinCEBuildNumber, Sysutils.WinCEMajorVersion,
                        Sysutils.WinCEMinorVersion, SysUtils.WinCEPlatform,
                        Sysutils.WinCECSDVersion]);

    DrawText(Ahdc, PWideChar(wzData), -1, @rt, DT_LEFT);

   finally EndPaint(FMainHWnd, @ps); end;
end;

procedure TMainSysInfo.DoDestroy( var vAMessage : TMessage);
begin
  vAMessage.Result:=0;
  DestroyWindow(FMenuBarHWnd); //MenuBar Destroy
  FMenuBarHWnd:=0;
  PostQuitMessage(0);
end;

procedure TMainSysInfo.DoActivate( var vAMessage : TMessage);
begin
  with vAMessage do begin
   Result:=0;
   // Notify shell of our activate message
   SHHandleWMActivate(FMainHWnd, wParam, lParam, @FShellActivateInfo, 0); //SHA_INPUTDIALOG
  end;
end;

procedure TMainSysInfo.DoSettingChange( var vAMessage : TMessage);
begin
  with vAMessage do begin
   Result:=0;
   SHHandleWMSettingChange(FMainHWnd, wParam, lParam, @FShellActivateInfo);
  end;
end;

//*****************************************************************************
// SysInfoMainWndProc
// Process messages for the main window
//*****************************************************************************

// registerclass accept only static proc not objects methods
// lpfnWndProc := WndProc(@SysInfoMainWndProc) -> redirection to object method

Function SysInfoMainWndProc (pMainHWnd:HWnd; piMessage : UINT; pWParam : WParam; pLParam:LParam): LResult; stdcall;
begin
 Result:=GMainSysInfo.FWndProc( pMainHWnd,piMessage,pWParam,pLParam);
end;

//*****************************************************************************
// Main entry point
//*****************************************************************************
Begin
 try

  GMainSysInfo:=TMainSysInfo.Create;
  try
    if GMainSysInfo.WInit
    then While GetMessage(@GMsg,0,0,0)
         do if TranslateAccelerator(GMsg.hwnd, GMainSysInfo.FAccelTable, @GMsg)=0 then begin
             Windows.TranslateMessage(@GMsg);
             Windows.DispatchMessage(@GMsg);
            end;

  finally GMainSysInfo.Free; end;

 except
  On E:Exception do MessageBox(0,PWideChar(WideFormat('message = %s',[E.message])),'Error', MB_OK);
 end;
End.