msgbox.pas 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309
  1. {********[ SOURCE FILE OF GRAPHICAL FREE VISION ]**********}
  2. { }
  3. { System independent GRAPHICAL clone of MSGBOX.PAS }
  4. { }
  5. { Interface Copyright (c) 1992 Borland International }
  6. { }
  7. { Copyright (c) 1996, 1997, 1998, 1999 by Leon de Boer }
  8. { [email protected] - primary e-mail addr }
  9. { [email protected] - backup e-mail addr }
  10. { }
  11. {****************[ THIS CODE IS FREEWARE ]*****************}
  12. { }
  13. { This sourcecode is released for the purpose to }
  14. { promote the pascal language on all platforms. You may }
  15. { redistribute it and/or modify with the following }
  16. { DISCLAIMER. }
  17. { }
  18. { This SOURCE CODE is distributed "AS IS" WITHOUT }
  19. { WARRANTIES AS TO PERFORMANCE OF MERCHANTABILITY OR }
  20. { ANY OTHER WARRANTIES WHETHER EXPRESSED OR IMPLIED. }
  21. { }
  22. {*****************[ SUPPORTED PLATFORMS ]******************}
  23. { 16 and 32 Bit compilers }
  24. { DOS - Turbo Pascal 7.0 + (16 Bit) }
  25. { DPMI - Turbo Pascal 7.0 + (16 Bit) }
  26. { - FPC 0.9912+ (GO32V2) (32 Bit) }
  27. { WINDOWS - Turbo Pascal 7.0 + (16 Bit) }
  28. { - Delphi 1.0+ (16 Bit) }
  29. { WIN95/NT - Delphi 2.0+ (32 Bit) }
  30. { - Virtual Pascal 2.0+ (32 Bit) }
  31. { - Speedsoft Sybil 2.0+ (32 Bit) }
  32. { OS2 - Virtual Pascal 1.0+ (32 Bit) }
  33. { - Speedsoft Sybil 2.0+ (32 Bit) }
  34. { }
  35. {******************[ REVISION HISTORY ]********************}
  36. { Version Date Fix }
  37. { ------- --------- --------------------------------- }
  38. { 1.00 12 Jun 96 Initial DOS/DPMI code released. }
  39. { 1.10 18 Oct 97 Code converted to GUI & TEXT mode. }
  40. { 1.20 18 Jul 97 Windows conversion added. }
  41. { 1.30 29 Aug 97 Platform.inc sort added. }
  42. { 1.40 22 Oct 97 Delphi3 32 bit code added. }
  43. { 1.50 05 May 98 Virtual pascal 2.0 code added. }
  44. { 1.60 30 Sep 99 Complete recheck preformed }
  45. {**********************************************************}
  46. UNIT MsgBox;
  47. {<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>}
  48. INTERFACE
  49. {<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>}
  50. {====Include file to sort compiler platform out =====================}
  51. {$I Platform.inc}
  52. {====================================================================}
  53. {==== Compiler directives ===========================================}
  54. {$IFNDEF PPC_FPC}{ FPC doesn't support these switches }
  55. {$F-} { Near calls are okay }
  56. {$A+} { Word Align Data }
  57. {$B-} { Allow short circuit boolean evaluations }
  58. {$O+} { This unit may be overlaid }
  59. {$G+} { 286 Code optimization - if you're on an 8088 get a real computer }
  60. {$P-} { Normal string variables }
  61. {$N-} { No 80x87 code generation }
  62. {$E+} { Emulation is on }
  63. {$ENDIF}
  64. {$X+} { Extended syntax is ok }
  65. {$R-} { Disable range checking }
  66. {$S-} { Disable Stack Checking }
  67. {$I-} { Disable IO Checking }
  68. {$Q-} { Disable Overflow Checking }
  69. {$V-} { Turn off strict VAR strings }
  70. {====================================================================}
  71. USES objects, dialogs; { Standard GFV units }
  72. {***************************************************************************}
  73. { PUBLIC CONSTANTS }
  74. {***************************************************************************}
  75. {---------------------------------------------------------------------------}
  76. { MESSAGE BOX CLASSES }
  77. {---------------------------------------------------------------------------}
  78. CONST
  79. mfWarning = $0000; { Display a Warning box }
  80. mfError = $0001; { Dispaly a Error box }
  81. mfInformation = $0002; { Display an Information Box }
  82. mfConfirmation = $0003; { Display a Confirmation Box }
  83. mfInsertInApp = $0080; { Insert message box into }
  84. { app instead of the Desktop }
  85. {---------------------------------------------------------------------------}
  86. { MESSAGE BOX BUTTON FLAGS }
  87. {---------------------------------------------------------------------------}
  88. CONST
  89. mfYesButton = $0100; { Yes button into the dialog }
  90. mfNoButton = $0200; { No button into the dialog }
  91. mfOKButton = $0400; { OK button into the dialog }
  92. mfCancelButton = $0800; { Cancel button into the dialog }
  93. mfYesNoCancel = mfYesButton + mfNoButton + mfCancelButton;
  94. { Yes, No, Cancel dialog }
  95. mfOKCancel = mfOKButton + mfCancelButton;
  96. { Standard OK, Cancel dialog }
  97. var
  98. MsgBoxTitles: array[0..3] of string[40];
  99. {***************************************************************************}
  100. { INTERFACE ROUTINES }
  101. {***************************************************************************}
  102. procedure InitMsgBox;
  103. procedure DoneMsgBox;
  104. { Init initializes the message box display system's text strings. Init is
  105. called by TApplication.Init after a successful call to Resource.Init or
  106. Resource.Load. }
  107. {-MessageBox---------------------------------------------------------
  108. MessageBox displays the given string in a standard sized dialog box.
  109. Before the dialog is displayed the Msg and Params are passed to FormatStr.
  110. The resulting string is displayed as a TStaticText view in the dialog.
  111. 30Sep99 LdB
  112. ---------------------------------------------------------------------}
  113. FUNCTION MessageBox (Const Msg: String; Params: Pointer;
  114. AOptions: Word): Word;
  115. {-MessageBoxRect-----------------------------------------------------
  116. MessageBoxRec allows the specification of a TRect for the message box
  117. to occupy.
  118. 30Sep99 LdB
  119. ---------------------------------------------------------------------}
  120. FUNCTION MessageBoxRect (Var R: TRect; Const Msg: String; Params: Pointer;
  121. AOptions: Word): Word;
  122. {-MessageBoxRectDlg--------------------------------------------------
  123. MessageBoxRecDlg allows the specification of a TRect for the message box
  124. to occupy plus the dialog window (to allow different dialog window types).
  125. ---------------------------------------------------------------------}
  126. FUNCTION MessageBoxRectDlg (Dlg: PDialog; Var R: TRect; Const Msg: String;
  127. Params: Pointer; AOptions: Word): Word;
  128. {-InputBox-----------------------------------------------------------
  129. InputBox displays a simple dialog that allows user to type in a string
  130. 30Sep99 LdB
  131. ---------------------------------------------------------------------}
  132. FUNCTION InputBox (Const Title, ALabel: String; Var S: String;
  133. Limit: Byte): Word;
  134. {-InputBoxRect-------------------------------------------------------
  135. InputBoxRect is like InputBox but allows the specification of a rectangle.
  136. 30Sep99 LdB
  137. ---------------------------------------------------------------------}
  138. FUNCTION InputBoxRect (Var Bounds: TRect; Const Title, ALabel: String;
  139. Var S: String; Limit: Byte): Word;
  140. {<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>}
  141. IMPLEMENTATION
  142. {<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>}
  143. USES Drivers, Views, App, Resource; { Standard GFV units }
  144. {***************************************************************************}
  145. { INTERFACE ROUTINES }
  146. {***************************************************************************}
  147. const
  148. Commands: array[0..3] of word =
  149. (cmYes, cmNo, cmOK, cmCancel);
  150. var
  151. ButtonName: array[0..3] of string[40];
  152. {---------------------------------------------------------------------------}
  153. { MessageBox -> Platforms DOS/DPMI/WIN/NT/OS2 - Updated 30Sep99 LdB }
  154. {---------------------------------------------------------------------------}
  155. FUNCTION MessageBox(Const Msg: String; Params: Pointer; AOptions: Word): Word;
  156. VAR R: TRect;
  157. BEGIN
  158. R.Assign(0, 0, 40, 9); { Assign area }
  159. If (AOptions AND mfInsertInApp = 0) Then { Non app insert }
  160. R.Move((Desktop^.Size.X - R.B.X) DIV 2,
  161. (Desktop^.Size.Y - R.B.Y) DIV 2) Else { Calculate position }
  162. R.Move((Application^.Size.X - R.B.X) DIV 2,
  163. (Application^.Size.Y - R.B.Y) DIV 2); { Calculate position }
  164. MessageBox := MessageBoxRect(R, Msg, Params,
  165. AOptions); { Create message box }
  166. END;
  167. FUNCTION MessageBoxRectDlg (Dlg: PDialog; Var R: TRect; Const Msg: String;
  168. Params: Pointer; AOptions: Word): Word;
  169. VAR I, X, ButtonCount: Integer; S: String; Control: PView;
  170. ButtonList: Array[0..4] Of PView;
  171. BEGIN
  172. With Dlg^ Do Begin
  173. FormatStr(S, Msg, Params^); { Format the message }
  174. Control := New(PStaticText, Init(R, S)); { Create static text }
  175. Insert(Control); { Insert the text }
  176. X := -2; { Set initial value }
  177. ButtonCount := 0; { Clear button count }
  178. For I := 0 To 3 Do
  179. If (AOptions AND ($0100 SHL I) <> 0) Then Begin
  180. R.Assign(0, 0, 10, 2); { Assign screen area }
  181. Control := New(PButton, Init(R, ButtonName[I],
  182. Commands[i], bfNormal)); { Create button }
  183. Inc(X, Control^.Size.X + 2); { Adjust position }
  184. ButtonList[ButtonCount] := Control; { Add to button list }
  185. Inc(ButtonCount); { Inc button count }
  186. End;
  187. X := (Size.X - X) SHR 1; { Calc x position }
  188. If (ButtonCount > 0) Then
  189. For I := 0 To ButtonCount - 1 Do Begin { For each button }
  190. Control := ButtonList[I]; { Transfer button }
  191. Insert(Control); { Insert button }
  192. Control^.MoveTo(X, Size.Y - 3); { Position button }
  193. Inc(X, Control^.Size.X + 2); { Adjust position }
  194. End;
  195. SelectNext(False); { Select first button }
  196. End;
  197. If (AOptions AND mfInsertInApp = 0) Then
  198. MessageBoxRectDlg := DeskTop^.ExecView(Dlg) Else { Execute dialog }
  199. MessageBoxRectDlg := Application^.ExecView(Dlg); { Execute dialog }
  200. end;
  201. {---------------------------------------------------------------------------}
  202. { MessageBoxRect -> Platforms DOS/DPMI/WIN/NT/OS2 - Updated 30Sep99 LdB }
  203. {---------------------------------------------------------------------------}
  204. FUNCTION MessageBoxRect(Var R: TRect; Const Msg: String; Params: Pointer;
  205. AOptions: Word): Word;
  206. var
  207. Dialog: PDialog;
  208. BEGIN
  209. Dialog := New (PDialog, Init (R, MsgBoxTitles [AOptions
  210. AND $3])); { Create dialog }
  211. with Dialog^ do
  212. R.Assign(3, 2, Size.X - 2, Size.Y - 3); { Assign area for text }
  213. MessageBoxRect := MessageBoxRectDlg (Dialog, R, Msg, Params, AOptions);
  214. Dispose (Dialog, Done); { Dispose of dialog }
  215. END;
  216. {---------------------------------------------------------------------------}
  217. { InputBox -> Platforms DOS/DPMI/WIN/NT/OS2 - Updated 30Sep99 LdB }
  218. {---------------------------------------------------------------------------}
  219. FUNCTION InputBox(Const Title, ALabel: String; Var S: String;
  220. Limit: Byte): Word;
  221. VAR R: TRect;
  222. BEGIN
  223. R.Assign(0, 0, 60, 8); { Assign screen area }
  224. R.Move((Desktop^.Size.X - R.B.X) DIV 2,
  225. (Desktop^.Size.Y - R.B.Y) DIV 2); { Position area }
  226. InputBox := InputBoxRect(R, Title, ALabel, S,
  227. Limit); { Create input box }
  228. END;
  229. {---------------------------------------------------------------------------}
  230. { InputBoxRect -> Platforms DOS/DPMI/WIN/NT/OS2 - Updated 30Sep99 LdB }
  231. {---------------------------------------------------------------------------}
  232. FUNCTION InputBoxRect(Var Bounds: TRect; Const Title, ALabel: String;
  233. Var S: String; Limit: Byte): Word;
  234. VAR C: Word; R: TRect; Control: PView; Dialog: PDialog;
  235. BEGIN
  236. Dialog := New(PDialog, Init(Bounds, Title)); { Create dialog }
  237. With Dialog^ Do Begin
  238. R.Assign(4 + CStrLen(ALabel), 2, Size.X - 3, 3); { Assign screen area }
  239. Control := New(PInputLine, Init(R, Limit)); { Create input line }
  240. Insert(Control); { Insert input line }
  241. R.Assign(2, 2, 3 + CStrLen(ALabel), 3); { Assign screen area }
  242. Insert(New(PLabel, Init(R, ALabel, Control))); { Insert label }
  243. R.Assign(Size.X - 24, Size.Y - 4, Size.X - 14,
  244. Size.Y - 2); { Assign screen area }
  245. Insert(New(PButton, Init(R, 'O~K~', cmOk,
  246. bfDefault))); { Insert okay button }
  247. Inc(R.A.X, 12); { New start x position }
  248. Inc(R.B.X, 12); { New end x position }
  249. Insert(New(PButton, Init(R, 'Cancel', cmCancel,
  250. bfNormal))); { Insert cancel button }
  251. Inc(R.A.X, 12); { New start x position }
  252. Inc(R.B.X, 12); { New end x position }
  253. SelectNext(False); { Select first button }
  254. End;
  255. Dialog^.SetData(S); { Set data in dialog }
  256. C := DeskTop^.ExecView(Dialog); { Execute the dialog }
  257. If (C <> cmCancel) Then Dialog^.GetData(S); { Get data from dialog }
  258. Dispose(Dialog, Done); { Dispose of dialog }
  259. InputBoxRect := C; { Return execute result }
  260. END;
  261. procedure InitMsgBox;
  262. begin
  263. ButtonName[0] := Labels^.Get(slYes);
  264. ButtonName[1] := Labels^.Get(slNo);
  265. ButtonName[2] := Labels^.Get(slOk);
  266. ButtonName[3] := Labels^.Get(slCancel);
  267. MsgBoxTitles[0] := Strings^.Get(sWarning);
  268. MsgBoxTitles[1] := Strings^.Get(sError);
  269. MsgBoxTitles[2] := Strings^.Get(sInformation);
  270. MsgBoxTitles[3] := Strings^.Get(sConfirm);
  271. end;
  272. procedure DoneMsgBox;
  273. begin
  274. end;
  275. END.