Rev 6800 | Rev 6875 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
2455 | mario79 | 1 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
2 | ;; ;; |
||
6272 | pathoswith | 3 | ;; Copyright (C) KolibriOS team 2004-2016. All rights reserved. ;; |
2455 | mario79 | 4 | ;; Distributed under terms of the GNU General Public License ;; |
5 | ;; ;; |
||
6 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
||
7 | |||
1662 | Nasarus | 8 | SYSTEM FUNCTIONS of OS Kolibri 0.7.7.0 |
114 | mikedld | 9 | |
10 | Number of the function is located in the register eax. |
||
118 | diamond | 11 | The call of the system function is executed by "int 0x40" command. |
12 | All registers except explicitly declared in the returned value, |
||
13 | including eflags, are preserved. |
||
114 | mikedld | 14 | |
15 | |||
16 | ====================================================================== |
||
17 | ============== Function 0 - define and draw the window. ============== |
||
18 | ====================================================================== |
||
19 | Defines an application window. Draws a frame of the window, header and |
||
133 | diamond | 20 | working area. For skinned windows defines standard close and minimize |
21 | buttons. |
||
114 | mikedld | 22 | Parameters: |
118 | diamond | 23 | * eax = 0 - function number |
114 | mikedld | 24 | * ebx = [coordinate on axis x]*65536 + [size on axis x] |
25 | * ecx = [coordinate on axis y]*65536 + [size on axis y] |
||
26 | * edx = 0xXYRRGGBB, where: |
||
27 | * Y = style of the window: |
||
118 | diamond | 28 | * Y=1 - only define window area, draw nothing |
131 | diamond | 29 | * Y=3 - skinned window |
641 | diamond | 30 | * Y=4 - skinned fixed-size window |
6473 | pathoswith | 31 | * Y=0,2 window types are outdated and should not be used anymore, |
6171 | leency | 32 | they are retained for compatibility with old programs. |
33 | * other possible values (from 5 to 15) are reserved, |
||
34 | function call with such Y is ignored |
||
118 | diamond | 35 | * RR, GG, BB = accordingly red, green, blue components of a color |
4051 | heavyiron | 36 | of the working area of the window (are ignored for style Y=1) |
114 | mikedld | 37 | * X = DCBA (bits) |
6168 | leency | 38 | * A = 1 - window has caption |
118 | diamond | 39 | * B = 1 - coordinates of all graphics primitives are relative to |
40 | window client area |
||
303 | mikedld | 41 | * C = 1 - don't fill working area on window draw |
118 | diamond | 42 | * D = 0 - normal filling of the working area, 1 - gradient |
43 | The following parameters are intended for windows |
||
44 | of a type I and II, and ignored for styles Y=1,3: |
||
45 | * esi = 0xXYRRGGBB - color of the header |
||
46 | * RR, GG, BB define color |
||
4051 | heavyiron | 47 | * Y=0 - usual window, Y=1 - unmovable window (works for all window styles) |
6168 | leency | 48 | * X not used, other values of Y are reserved |
49 | * edi = caption string for styles Y=3,4 (also can be set by func 71.1) |
||
114 | mikedld | 50 | Returned value: |
51 | * function does not return value |
||
52 | Remarks: |
||
118 | diamond | 53 | * Position and sizes of the window are installed by the first |
54 | call of this function and are ignored at subsequent; to change |
||
55 | position and/or sizes of already created window use function 67. |
||
641 | diamond | 56 | * For windows with styles Y=3,4 and caption (A=1) caption string |
57 | is set by the first call of this function and is ignored |
||
58 | at subsequent (strictly speaking, is ignored after a call to |
||
59 | subfunction 2 of function 12 - end redraw); to change caption of |
||
60 | already created window use subfunction 1 of function 71. |
||
118 | diamond | 61 | * If the window has appropriate styles, position and/or sizes can be |
62 | changed by user. Current position and sizes can be obtained |
||
63 | by function 9. |
||
64 | * The window must fit on the screen. If the transferred |
||
65 | coordinates and sizes do not satisfy to this condition, |
||
66 | appropriate coordinate (or, probably, both) is considered as zero, |
||
131 | diamond | 67 | and if it does not help too, the appropriate size |
118 | diamond | 68 | (or, probably, both) is installed in a size of the screen. |
2409 | Serge | 69 | |
131 | diamond | 70 | Further let us designate xpos,ypos,xsize,ysize - values passed |
71 | in ebx,ecx. The coordinates are resulted concerning |
||
118 | diamond | 72 | the left upper corner of the window, which, thus, is set as (0,0), |
73 | coordinates of the right lower corner essence (xsize,ysize). |
||
74 | * The sizes of the window are understood in sence of coordinates |
||
75 | of the right lower corner. This concerns all other functions too. |
||
76 | It means, that the real sizes are on 1 pixel more. |
||
77 | * The window of style Y=1 looks as follows: |
||
114 | mikedld | 78 | * completely defined by the application |
6168 | leency | 79 | * The skinned window Y=3,4 looks as follows: |
114 | mikedld | 80 | * draw external frame of width 1 pixel |
118 | diamond | 81 | with color 'outer' from the skin |
82 | * draw intermediate frame of width 3 pixel |
||
83 | with color 'frame' from the skin |
||
84 | * draw internal frame of width 1 pixel |
||
85 | with color 'inner' from the skin |
||
86 | * draw header (on bitmaps from the skin) in a rectangle |
||
114 | mikedld | 87 | (0,0) - (xsize,_skinh-1) |
118 | diamond | 88 | * if ysize>=26, fill the working area of the window - |
89 | rectangle with the left upper corner (5,_skinh) and right lower |
||
90 | (xsize-5,ysize-5) with color indicated in edx |
||
91 | (taking a gradient into account) |
||
133 | diamond | 92 | * define two standard buttons: close and minimize |
114 | mikedld | 93 | (see function 8) |
118 | diamond | 94 | * if A=1 and edi contains (nonzero) pointer to caption string, |
95 | it is drawn in place in header defined in the skin |
||
96 | * value _skinh is accessible as the result of call |
||
97 | subfunction 4 of function 48 |
||
114 | mikedld | 98 | |
6057 | IgorA | 99 | ---------------------- Constants for registers: ---------------------- |
100 | eax - SF_CREATE_WINDOW (0) |
||
114 | mikedld | 101 | ====================================================================== |
118 | diamond | 102 | ================ Function 1 - put pixel in the window. =============== |
114 | mikedld | 103 | ====================================================================== |
104 | Parameters: |
||
118 | diamond | 105 | * eax = 1 - function number |
106 | * ebx = x-coordinate (relative to the window) |
||
107 | * ecx = y-coordinate (relative to the window) |
||
108 | * edx = 0x00RRGGBB - color of a pixel |
||
109 | edx = 0x01xxxxxx - invert color of a pixel |
||
110 | (low 24 bits are ignored) |
||
114 | mikedld | 111 | Returned value: |
112 | * function does not return value |
||
113 | |||
6057 | IgorA | 114 | ---------------------- Constants for registers: ---------------------- |
115 | eax - SF_PUT_PIXEL (1) |
||
114 | mikedld | 116 | ====================================================================== |
118 | diamond | 117 | ============ Function 2 - get the code of the pressed key. =========== |
114 | mikedld | 118 | ====================================================================== |
119 | Takes away the code of the pressed key from the buffer. |
||
120 | Parameters: |
||
118 | diamond | 121 | * eax = 2 - function number |
114 | mikedld | 122 | Returned value: |
118 | diamond | 123 | * if the buffer is empty, function returns eax=1 |
124 | * if the buffer is not empty, function returns al=0, |
||
4588 | mario79 | 125 | ah=code of the pressed key, |
4612 | mario79 | 126 | bits 16-23 = contain scancode for pressed key in ASCII mode, |
127 | in the scancodes mode this bits cleared. |
||
4588 | mario79 | 128 | bits 23-31 = zero |
118 | diamond | 129 | * if there is "hotkey", function returns al=2, |
130 | ah=scancode of the pressed key (0 for control keys), |
||
131 | high word of eax contains a status of control keys at the moment |
||
132 | of pressing a hotkey |
||
114 | mikedld | 133 | Remarks: |
118 | diamond | 134 | * There is a common system buffer of the pressed keys |
135 | by a size of 120 bytes, organized as queue. |
||
136 | * There is one more common system buffer on 120 "hotkeys". |
||
137 | * If the application with the inactive window calls this function, |
||
138 | the buffer of the pressed keys is considered to be empty. |
||
139 | * By default this function returns ASCII-codes; to switch |
||
140 | to the scancodes mode (and back) use function 66. |
||
141 | However, hotkeys are always notificated as scancodes. |
||
142 | * To find out, what keys correspond to what codes, start |
||
143 | the application keyascii and scancode. |
||
144 | * Scancodes come directly from keyboard and are fixed; |
||
145 | ASCII-codes turn out with usage of the conversion tables, |
||
146 | which can be set by subfunction 2 of function 21 |
||
147 | and get by subfunction 2 of function 26. |
||
148 | * As a consequence, ASCII-codes take into account current |
||
149 | keyboard layout (rus/en) as opposed to scancodes. |
||
150 | * This function notifies only about those hotkeys, which were |
||
151 | defined by this thread by subfunction 4 of function 66. |
||
114 | mikedld | 152 | |
6057 | IgorA | 153 | ---------------------- Constants for registers: ---------------------- |
154 | eax - SF_GET_KEY (2) |
||
114 | mikedld | 155 | ====================================================================== |
118 | diamond | 156 | ==================== Function 3 - get system time. =================== |
114 | mikedld | 157 | ====================================================================== |
158 | Parameters: |
||
118 | diamond | 159 | * eax = 3 - function number |
114 | mikedld | 160 | Returned value: |
161 | * eax = 0x00SSMMHH, where HH:MM:SS = Hours:Minutes:Seconds |
||
118 | diamond | 162 | * each item is BCD-number, for example, |
163 | for time 23:59:59 function returns 0x00595923 |
||
114 | mikedld | 164 | Remarks: |
118 | diamond | 165 | * See also subfunction 9 of function 26 - get time from |
166 | the moment of start of the system; it is more convenient, because |
||
167 | returns simply DWORD-value of the time counter. |
||
168 | * System time can be set by function 22. |
||
114 | mikedld | 169 | |
6057 | IgorA | 170 | ---------------------- Constants for registers: ---------------------- |
171 | eax - SF_GET_SYS_TIME (3) |
||
114 | mikedld | 172 | ====================================================================== |
5848 | pathoswith | 173 | =================== Function 4 - draw text string. =================== |
114 | mikedld | 174 | ====================================================================== |
175 | Parameters: |
||
118 | diamond | 176 | * eax = 4 - function number |
5848 | pathoswith | 177 | * ebx = X*65536+Y, coordinates in the window or buffer |
178 | * ecx = 0xXXRRGGBB, where |
||
118 | diamond | 179 | * RR, GG, BB specify text color |
5848 | pathoswith | 180 | * XX = ABFFCSSS (bits): |
5682 | leency | 181 | * A=1 - output zero terminated string |
5848 | pathoswith | 182 | * B=1 - fill background (color = edi) |
5682 | leency | 183 | * FF specifies the font and encoding: |
184 | |||