1Prima::Grids(3) User Contributed Perl Documentation Prima::Grids(3)
2
3
4
6 Prima::Grids - grid widgets
7
8 SYNOPSIS
9 use Prima qw(Grids Application);
10
11 my $grid = Prima::Grid-> new(
12 cells => [
13 [qw(1.First 1.Second 1.Third)],
14 [qw(2.First 2.Second 2.Third)],
15 [qw(3.First 3.Second 3.Third)],
16 ],
17 onClick => sub {
18 print $_[0]-> get_cell_text( $_[0]-> focusedCell), " is selected\n";
19 }
20 );
21 run Prima;
22
24 The module provides classes for several abstraction layers of grid
25 representation. The classes hierarchy is as follows:
26
27 AbstractGridViewer
28 AbstractGrid
29 GridViewer
30 Grid
31
32 The root class, "Prima::AbstractGridViewer", provides common interface,
33 while by itself it is not directly usable. The main differences
34 between classes are centered around the way the cell data are stored.
35 The simplest organization of a text-only cell, provided by
36 "Prima::Grid", stores data as a two-dimensional array of text scalars.
37 More elaborated storage and representation types are not realized, and
38 the programmer is urged to use the more abstract classes to derive own
39 mechanisms. To organize an item storage, different from "Prima::Grid",
40 it is usually enough to overload either the "Stringify", "Measure", and
41 "DrawCell" events, or their method counterparts: "get_cell_text",
42 "columnWidth", "rowHeight", and "draw_items".
43
44 The grid widget is designed to contain cells of variable extents, of
45 two types, normal and indent. The indent rows and columns are displayed
46 in grid margins, and their cell are drawn with distinguished colors.
47 An example use for a bottom indent row is a sum row in a spreadsheet
48 application; the top indent row can be used for displaying columns'
49 headers. The normal cells can be selected by the user, scrolled, and
50 selected. The cell selection can only contain rectangular areas, and
51 therefore is operated with two integer pairs with the beginning and the
52 end of the selection.
53
54 The widget operates in two visual scrolling modes; when the space
55 allows, the scrollbars affect the leftmost and the topmost cell. When
56 the widget is not large enough to accommodate at least one cell and all
57 indent cells, the layout is scrolled pixel-wise. These modes are named
58 'cell' and 'pixel', after the scrolling units.
59
60 The widget allows the interactive changing of cell widths and heights
61 by dragging the grid lines between the cells.
62
64 "Prima::AbstractGridViewer", the base for all grid widgets in the
65 module, provides interface to generic grid browsing functionality, plus
66 functionality for text-oriented grids. The class is not usable
67 directly.
68
69 "Prima::AbstractGridViewer" is a descendant of "Prima::GroupScroller",
70 and some properties are not described here. See "Prima::GroupScroller"
71 in Prima::IntUtils.
72
73 Properties
74 allowChangeCellHeight BOOLEAN
75 If 1, the user is allowed to change vertical extents of cells by
76 dragging the horizontal grid lines. Prerequisites to the options
77 are: the lines must be set visible via "drawHGrid" property,
78 "constantCellHeight" property set to 0, and the changes to the
79 vertical extents can be recorded via "SetExtent" notification.
80
81 Default value: 0
82
83 allowChangeCellWidth BOOLEAN
84 If 1, the user is allowed to change horizontal extents of cells by
85 dragging the horizontal grid lines. Prerequisites to the options
86 are: the lines must be set visible via "drawVGrid" property,
87 "constantCellWidth" property set to 0, and the changes to the
88 horizontal extents can be recorded via "SetExtent" notification.
89
90 Default value: 0
91
92 cellIndents X1, Y1, X2, Y2
93 Marks the marginal rows and columns as 'indent' cells. The indent
94 cells are drawn with another color pair ( see indentCellColor,
95 indentCellBackColor ), cannot be selected and scrolled. X1 and X2
96 correspond to amount of indent columns, and Y1 and Y2, - to the
97 indent rows.
98
99 "leftCell" and "topCell" do not count the indent cells as the
100 leftmost or topmost visible cell; in other words, X1 and Y1 are
101 minimal values for "leftCell" and "topCell" properties.
102
103 Default value: 0,0,0,0
104
105 clipCells INTEGER
106 A three-state integer property, that governs the way clipping is
107 applied when cells are drawn. Depending on kind of graphic in
108 cells, the clipping may be necessary, or unnecessary.
109
110 If the value is 1, the clipping is applied for every column drawn,
111 as the default drawing routines proceed column-wise. If the value
112 is 2, the clipping as applied for every cell. This setting reduces
113 the drawing speed significantly. If the value is 0, no clipping is
114 applied.
115
116 This property is destined for custom-drawn grid widgets, when it is
117 the developer's task to decide what kind of clipping suits better.
118 Text grid widgets, "Prima::AbstractGrid" and "Prima::Grid", are
119 safe with "clipCells" set to 1.
120
121 Default value: 1
122
123 columns INTEGER
124 Sets number of columns, including the indent columns. The number of
125 columns must be larger than the number of indent columns.
126
127 Default value: 0.
128
129 columnWidth COLUMN [ WIDTH ]
130 A run-time property, selects width of a column. To acquire or set
131 the width, "Measure" and "SetExtent" notifications can be invoked.
132 Result of "Measure" may be cached internally using
133 "cache_geometry_requests" method.
134
135 The width does not include widths of eventual vertical grid lines.
136
137 If "constantCellWidth" is defined, the property is used as its
138 alias.
139
140 constantCellHeight HEIGHT
141 If defined, all rows have equal height, HEIGHT pixels. If "undef",
142 rows have different heights.
143
144 Default value: undef
145
146 constantCellWidth WIDTH
147 If defined, all rows have equal width, WIDTH pixels. If "undef",
148 columns have different widths.
149
150 Default value: undef
151
152 drawHGrid BOOLEAN
153 If 1, horizontal grid lines between cells are drawn with
154 "gridColor".
155
156 Default value: 1
157
158 drawVGrid
159 If 1, vertical grid lines between cells are drawn with "gridColor".
160
161 Default value: 1
162
163 dx INTEGER
164 A run-time property. Selects horizontal offset in pixels of grid
165 layout in pixel mode.
166
167 dy INTEGER
168 A run-time property. Selects vertical offset in pixels of grid
169 layout in pixel mode.
170
171 focusedCell X, Y
172 Selects coordinates or the focused cell.
173
174 gridColor COLOR
175 Selects the color of grid lines.
176
177 Default value: "cl::Black" .
178
179 gridGravity INTEGER
180 The property selects the breadth of area around the grid lines,
181 that reacts on grid-dragging mouse events. The minimal value, 0,
182 marks only grid lines as the drag area, but makes the dragging
183 operation inconvenient for the user. Larger values make the
184 dragging more convenient, but increase the chance that the user
185 will not be able to select too narrow cells with the mouse.
186
187 Default value: 3
188
189 indentCellBackColor COLOR
190 Selects the background color of indent cells.
191
192 Default value: "cl::Gray" .
193
194 indentCellColor
195 Selects the foreground color of indent cells.
196
197 Default value: "cl::Gray" .
198
199 leftCell INTEGER
200 Selects index of the leftmost visible normal cell.
201
202 multiSelect BOOLEAN
203 If 1, the normal cells in an arbitrary rectangular area can be
204 marked as selected ( see selection ). If 0, only one cell at a time
205 can be selected.
206
207 Default value: 0
208
209 rows INTEGER
210 Sets number of rows, including the indent rows. The number of rows
211 must be larger than the number of indent rows.
212
213 Default value: 0.
214
215 topCell
216 Selects index of the topmost visible normal cell.
217
218 rowHeight INTEGER
219 A run-time property, selects height of a row. To acquire or set the
220 height, "Measure" and "SetExtent" notifications can be invoked.
221 Result of "Measure" may be cached internally using
222 "cache_geometry_requests" method.
223
224 The height does not include widths of eventual horizontal grid
225 lines.
226
227 If "constantCellHeight" is defined, the property is used as its
228 alias.
229
230 selection X1, Y1, X2, Y2
231 If "multiSelect" is 1, governs the extents of a rectangular area,
232 that contains selected cells. If no such area is present, selection
233 is (-1,-1,-1,-1), and "has_selection" returns 0 .
234
235 If "multiSelect" is 0, in get-mode returns the focused cell, and
236 discards the parameters in the set-mode.
237
238 Methods
239 cache_geometry_requests CACHE
240 If CACHE is 1, starts caching results of "Measure" notification,
241 thus lighting the subsequent "columnWidth" and "rowHeight" calls;
242 if CACHE is 0, flushes the cache.
243
244 If a significant geometry change was during the caching, the cache
245 is not updated, so it is the caller's responsibility to flush the
246 cache.
247
248 deselect_all
249 Nullifies the selection, if "multiSelect" is 1.
250
251 draw_cells CANVAS, COLUMNS, ROWS, AREA
252 A bulk draw routine, called from "onPaint" to draw cells. AREA is
253 an array of four integers with inclusive-inclusive coordinates of
254 the widget inferior without borders and scrollbars ( result of
255 get_active_area(2) call; see "get_active_area" in Prima::IntUtils
256 ).
257
258 COLUMNS and ROWS are structures that reflect the columns and rows
259 of the cells to be drawn. Each item in these corresponds to a
260 column or row, and is an array with the following layout:
261
262 0: column or row index
263 1: type; 0 - normal cell, 1 - indent cell
264 2: visible cell breadth
265 3: visible cell start
266 4: visible cell end
267 5: real cell start
268 6: real cell end
269
270 The coordinates are in inclusive-inclusive coordinate system, and
271 do not include eventual grid space, nor gaps between indent and
272 normal cells. By default, internal arrays "{colsDraw}" and
273 "{rowsDraw}" are passed as COLUMNS and ROWS parameters.
274
275 In "Prima::AbstractGrid" and "Prima::Grid" classes <draw_cells> is
276 overloaded to transfer the call to "std_draw_text_cells", the text-
277 oriented optimized routine.
278
279 draw_text_cells SCREEN_RECTANGLES, CELL_RECTANGLES, CELL_INDECES,
280 FONT_HEIGHT
281 A bulk routine for drawing text cells, called from
282 "std_draw_text_cells" .
283
284 SCREEN_RECTANGLES and CELL_RECTANGLES are arrays, where each item
285 is a rectangle with exterior of a cell. SCREEN_RECTANGLES contains
286 rectangles that cover the cell visible area; CELL_RECTANGLES
287 contains rectangles that span the cell extents disregarding its
288 eventual partial visibility. For example, a 100-pixel cell with
289 only its left half visible, would contain corresponding arrays
290 [150,150,200,250] in SCREEN_RECTANGLES, and [150,150,250,250] in
291 CELL_RECTANGLES.
292
293 CELL_INDECES contains arrays of the cell coordinates; each array
294 item is an array of integer pair where item 0 is column, and item 1
295 is row of the cell.
296
297 FONT_HEIGHT is a current font height value, cached since
298 "draw_text_cells" is often used for text operations and may require
299 vertical text justification.
300
301 get_cell_area [ WIDTH, HEIGHT ]
302 Returns screen area in inclusive-inclusive pixel coordinates, that
303 is used to display normal cells. The extensions are related to the
304 current size of a widget, however, can be overridden by specifying
305 WIDTH and HEIGHT.
306
307 get_cell_alignment COLUMN, ROW
308 Returns two "ta::" constants for horizontal and vertical cell text
309 alignment. Since the class does not assume the item storage
310 organization, the values are queried via "GetAlignment"
311 notification.
312
313 get_cell_text COLUMN, ROW
314 Returns text string assigned to cell in COLUMN and ROW. Since the
315 class does not assume the item storage organization, the text is
316 queried via "Stringify" notification.
317
318 get_range VERTICAL, INDEX
319 Returns a pair of integers, minimal and maximal breadth of INDEXth
320 column or row in pixels. If VERTICAL is 1, the rows are queried; if
321 0, the columns.
322
323 The method calls "GetRange" notification.
324
325 get_screen_cell_info COLUMN, ROW
326 Returns information about a cell in COLUMN and ROW, if it is
327 currently visible. The returned parameters are indexed by
328 "gsci::XXX" constants, and explained below:
329
330 gsci::COL_INDEX - visual column number where the cell displayed
331 gsci::ROW_INDEX - visual row number where the cell displayed
332 gsci::V_FULL - cell is fully visible
333
334 gsci::V_LEFT - inclusive-inclusive rectangle of the visible
335 gsci::V_BOTTOM part of the cell. These four indices are grouped
336 gsci::V_RIGHT under list constant, gsci::V_RECT.
337 gsci::V_TOP
338
339 gsci::LEFT - inclusive-inclusive rectangle of the cell, as if
340 gsci::BOTTOM it is fully visible. These four indices are grouped
341 gsci::RIGHT under list constant, gsci::RECT. If gsci::V_FULL
342 gsci::TOP is 1, these values are identical to these in gsci::V_RECT.
343
344 If the cell is not visible, returns empty array.
345
346 has_selection
347 Returns a boolean value, indicating whether the grid contains a
348 selection (1) or not (0).
349
350 point2cell X, Y, [ OMIT_GRID = 0 ]
351 Return information about point X, Y in widget coordinates. The
352 method returns two integers, CX and CY, with cell coordinates, and
353 eventual HINTS hash, with more information about pixe localtion. If
354 OMIT_GRID is set to 1 and the pixel belongs to a grid, the pixels
355 is treated a part of adjacent cell. The call syntax:
356
357 ( $CX, $CY, %HINTS) = $self->point2cell( $X, $Y);
358
359 If the pixel lies within cell boundaries by either coordinate, CX
360 and/or CY are correspondingly set to cell column and/or row. When
361 the pixel is outside cell space, CX and/or CY are set to -1.
362
363 HINTS may contain the following values:
364
365 "x" and "y"
366 If 0, the coordinate lies within boundaries of a cell.
367
368 If -1, the coordinate is on the left/top to the cell body.
369
370 If +1, the coordinate is on the right/bottom to the cell body,
371 but within the widget.
372
373 If +2, the coordinate is on the right/bottom to the cell body,
374 but outside the widget.
375
376 "x_type" and "y_type"
377 Present when "x" or "y" values are 0.
378
379 If 0, the cell is a normal cell.
380
381 If -1, the cell is left/top indent cell.
382
383 If +1, the cell is right/bottom indent cell.
384
385 "x_grid" and "y_grid"
386 If 1, the point is over a grid line. This case can only happen
387 when OMIT_GRID is 0. If "allowChangeCellHeight" and/or
388 "allowChangeCellWidth" are set, treats also "gridGravity"-broad
389 pixels strips on both sides of the line as the grid area.
390
391 Also values of "x_left"/"x_right" or "y_bottom"/"y_top" might
392 be set.
393
394 "x_left"/"x_right" and "y_bottom"/"y_top"
395 Present together with "x_grid" or "y_grid". Select indices of
396 cells adjacent to the grid line.
397
398 "x_gap" and "y_gap"
399 If 1, the point is within a gap between the last normal cell
400 and the first right/bottom indent cell.
401
402 "normal"
403 If 1, the point lies within the boundaries of a normal cell.
404
405 "indent"
406 If 1, the point lies within the boundaries of an indent cell.
407
408 "grid"
409 If 1, the point is over a grid line.
410
411 "exterior"
412 If 1, the point is in inoperable area or outside the widget
413 boundaries.
414
415 redraw_cell X, Y
416 Repaints cell with coordinates X and Y.
417
418 reset
419 Recalculates internal geometry variables.
420
421 select_all
422 Marks all cells as selected, if "multiSelect" is 1.
423
424 std_draw_text_cells CANVAS, COLUMNS, ROWS, AREA
425 An optimized bulk routine for text-oriented grid widgets. The
426 optimization is achieved under assumption that each cell is drawn
427 with two colors only, so the color switching can be reduced.
428
429 The routine itself paints the cells background, and calls
430 "draw_text_cells" to draw text and/or otherwise draw the cell
431 content.
432
433 For explanation of COLUMNS, ROWS, and AREA parameters see
434 draw_cells .
435
436 Events
437 DrawCell CANVAS, COLUMN, ROW, INDENT, @SCREEN_RECT, @CELL_RECT,
438 SELECTED, FOCUSED, PRELIGHT
439 Called when a cell with COLUMN and ROW coordinates is to be drawn
440 on CANVAS. SCREEN_RECT is a cell rectangle in widget coordinates,
441 where the item is to be drawn. CELL_RECT is same as SCREEN_RECT,
442 but calculated as if the cell is fully visible.
443
444 SELECTED, FOCUSED, and PRELIGHT are boolean flagss, if the cell
445 must be drawn correspondingly in selected, focused, and pre-lighted
446 states.
447
448 GetAlignment COLUMN, ROW, HORIZONTAL_ALIGN_REF, VERTICAL_ALIGN_REF
449 Puts two text alignment "ta::" constants, assigned to cell with
450 COLUMN and ROW coordinates, into HORIZONTAL_ALIGN_REF and
451 VERTICAL_ALIGN_REF scalar references.
452
453 GetRange VERTICAL, INDEX, MIN, MAX
454 Puts minimal and maximal breadth of INDEXth column ( VERTICAL = 0 )
455 or row ( VERTICAL = 1) in corresponding MIN and MAX scalar
456 references.
457
458 Measure VERTICAL, INDEX, BREADTH
459 Puts breadth in pixels of INDEXth column ( VERTICAL = 0 ) or row (
460 VERTICAL = 1) into BREADTH scalar reference.
461
462 This notification by default may be called from within
463 "begin_paint_info/end_paint_info" brackets. To disable this feature
464 set internal flag "{NoBulkPaintInfo}" to 1.
465
466 SelectCell COLUMN, ROW
467 Called when a cell with COLUMN and ROW coordinates is focused.
468
469 SetExtent VERTICAL, INDEX, BREADTH
470 Reports breadth in pixels of INDEXth column ( VERTICAL = 0 ) or row
471 ( VERTICAL = 1), as a response to "columnWidth" and "rowHeight"
472 calls.
473
474 Stringify COLUMN, ROW, TEXT_REF
475 Puts text string, assigned to cell with COLUMN and ROW coordinates,
476 into TEXT_REF scalar reference.
477
479 Exactly the same as its ascendant, "Prima::AbstractGridViewer", except
480 that it does not propagate "DrawItem" message, assuming that the items
481 must be drawn as text.
482
484 The class implements cells data and geometry storage mechanism, but
485 leaves the cell data format to the programmer. The cells are accessible
486 via "cells" property and several other helper routines.
487
488 The cell data are stored in an array, where each item corresponds to a
489 row, and contains array of scalars, where each corresponds to a column.
490 All data managing routines, that accept two-dimensional arrays, assume
491 that the columns arrays are of the same widths.
492
493 For example, "[[1,2,3]]]" is a valid one-row, three-column structure,
494 and "[[1,2],[2,3],[3,4]]" is a valid three-row, two-column structure.
495 The structure "[[1],[2,3],[3,4]]" is invalid, since its first row has
496 one column, while the others have two.
497
498 "Prima::GridViewer" is derived from "Prima::AbstractGridViewer".
499
500 Properties
501 allowChangeCellHeight
502 Default value: 1
503
504 allowChangeCellWidth
505 Default value: 1
506
507 cell COLUMN, ROW, [ DATA ]
508 Run-time property. Selects the data in cell with COLUMN and ROW
509 coordinates.
510
511 cells [ ARRAY ]
512 The property accepts or returns all cells as a two-dimensional
513 rectangular array or scalars.
514
515 columns INDEX
516 A read-only property; returns number of columns.
517
518 rows INDEX
519 A read-only property; returns number of rows.
520
521 Methods
522 add_column CELLS
523 Inserts one-dimensional array of scalars to the end of columns.
524
525 add_columns CELLS
526 Inserts two-dimensional array of scalars to the end of columns.
527
528 add_row CELLS
529 Inserts one-dimensional array of scalars to the end of rows.
530
531 add_rows CELLS
532 Inserts two-dimensional array of scalars to the end of rows.
533
534 delete_columns OFFSET, LENGTH
535 Removes LENGTH columns starting from OFFSET. Negative values are
536 accepted.
537
538 delete_rows OFFSET, LENGTH
539 Removes LENGTH rows starting from OFFSET. Negative values are
540 accepted.
541
542 insert_column OFFSET, CELLS
543 Inserts one-dimensional array of scalars as column OFFSET.
544 Negative values are accepted.
545
546 insert_columns OFFSET, CELLS
547 Inserts two-dimensional array of scalars in column OFFSET.
548 Negative values are accepted.
549
550 insert_row
551 Inserts one-dimensional array of scalars as row OFFSET. Negative
552 values are accepted.
553
554 insert_rows
555 Inserts two-dimensional array of scalars in row OFFSET. Negative
556 values are accepted.
557
559 Descendant of "Prima::GridViewer", declares format of cells as a single
560 text string. Incorporating all functionality of its ascendants,
561 provides a standard text grid widget.
562
563 Methods
564 get_cell_alignment COLUMN, ROW
565 Returns two "ta::" constants for horizontal and vertical cell text
566 alignment. Since the item storage organization is implemented,
567 does so without calling "GetAlignment" notification.
568
569 get_cell_text COLUMN, ROW
570 Returns text string assigned to cell in COLUMN and ROW. Since the
571 item storage organization is implemented, does so without calling
572 "Stringify" notification.
573
575 Dmitry Karasik, <dmitry@karasik.eu.org>.
576
578 Prima, Prima::Widget, examples/grid.pl
579
580
581
582perl v5.30.1 2020-01-30 Prima::Grids(3)