rbcurse 0.1.3 → 1.1.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (74) hide show
  1. data/CHANGELOG +126 -0
  2. data/Manifest.txt +53 -20
  3. data/README.markdown +423 -0
  4. data/Rakefile +3 -1
  5. data/examples/keytest.rb +177 -0
  6. data/examples/mpad2.rb +156 -0
  7. data/examples/newtesttabp.rb +121 -0
  8. data/examples/rfe.rb +48 -10
  9. data/examples/rfe_renderer.rb +4 -4
  10. data/examples/rvimsplit.rb +376 -0
  11. data/examples/sqlc.rb +97 -106
  12. data/examples/sqlm.rb +446 -0
  13. data/examples/test1.rb +4 -4
  14. data/examples/test2.rb +12 -12
  15. data/examples/testchars.rb +140 -0
  16. data/examples/testkeypress.rb +9 -4
  17. data/examples/testmulticomp.rb +72 -0
  18. data/examples/testscroller.rb +136 -0
  19. data/examples/testscrolllb.rb +86 -0
  20. data/examples/testscrollp.rb +87 -0
  21. data/examples/testscrollta.rb +80 -0
  22. data/examples/testscrolltable.rb +166 -0
  23. data/examples/testsplit.rb +87 -0
  24. data/examples/testsplit2.rb +123 -0
  25. data/examples/testsplit3.rb +215 -0
  26. data/examples/testsplit3_1.rb +244 -0
  27. data/examples/testsplit3a.rb +215 -0
  28. data/examples/testsplit3b.rb +237 -0
  29. data/examples/testsplitta.rb +148 -0
  30. data/examples/testsplittv.rb +142 -0
  31. data/examples/testsplittvv.rb +144 -0
  32. data/examples/testtable.rb +1 -1
  33. data/examples/testtabp.rb +3 -2
  34. data/examples/testtestw.rb +69 -0
  35. data/examples/testtodo.rb +5 -3
  36. data/examples/testtpane.rb +203 -0
  37. data/examples/testtpane2.rb +145 -0
  38. data/examples/testtpanetable.rb +199 -0
  39. data/examples/viewtodo.rb +5 -3
  40. data/lib/rbcurse.rb +1 -1
  41. data/lib/rbcurse/celleditor.rb +2 -2
  42. data/lib/rbcurse/colormap.rb +5 -5
  43. data/lib/rbcurse/defaultlistselectionmodel.rb +3 -3
  44. data/lib/rbcurse/io.rb +663 -0
  45. data/lib/rbcurse/listeditable.rb +306 -0
  46. data/lib/rbcurse/listkeys.rb +15 -15
  47. data/lib/rbcurse/listscrollable.rb +168 -27
  48. data/lib/rbcurse/mapper.rb +35 -13
  49. data/lib/rbcurse/rchangeevent.rb +28 -0
  50. data/lib/rbcurse/rform.rb +845 -0
  51. data/lib/rbcurse/rlistbox.rb +144 -34
  52. data/lib/rbcurse/rmessagebox.rb +10 -5
  53. data/lib/rbcurse/rmulticontainer.rb +325 -0
  54. data/lib/rbcurse/rmultitextview.rb +306 -0
  55. data/lib/rbcurse/rscrollform.rb +369 -0
  56. data/lib/rbcurse/rscrollpane.rb +511 -0
  57. data/lib/rbcurse/rsplitpane.rb +820 -0
  58. data/lib/rbcurse/rtabbedpane.rb +737 -109
  59. data/lib/rbcurse/rtabbedwindow.rb +326 -0
  60. data/lib/rbcurse/rtable.rb +220 -64
  61. data/lib/rbcurse/rtextarea.rb +340 -181
  62. data/lib/rbcurse/rtextview.rb +237 -101
  63. data/lib/rbcurse/rviewport.rb +203 -0
  64. data/lib/rbcurse/rwidget.rb +919 -95
  65. data/lib/rbcurse/scrollable.rb +7 -7
  66. data/lib/rbcurse/selectable.rb +4 -4
  67. data/lib/rbcurse/table/tablecellrenderer.rb +3 -0
  68. data/lib/rbcurse/undomanager.rb +181 -0
  69. data/lib/rbcurse/vieditable.rb +100 -0
  70. data/lib/ver/window.rb +471 -21
  71. metadata +66 -22
  72. data/README.txt +0 -312
  73. data/examples/testd.db +0 -0
  74. data/examples/todocsv.csv +0 -28
@@ -0,0 +1,511 @@
1
+ =begin
2
+ * Name: Scrollpane
3
+ * Description: a scrollable widget allowing user to scroll and view
4
+ parts of underlying object that typically are larger than screen area.
5
+ Mainly, contains a viewport, scrollbars and manages viewport through usage
6
+ of scrollbars.
7
+ Also contains viewport for row and columns.
8
+ * Author: rkumar
9
+ Todo section:
10
+ - add events, property changed etc at least for scrolling - DONE
11
+ SCrollpane normall should listen in to changes in viewport, however Scro calls those very methods
12
+ and what's more, other classes would listen to SCR and not to VP.
13
+ - scrollbars to be classes - shall we avoid over-engineering, and KISS
14
+ - if scrollpane reduced it should also resize, as example inside splitpane.
15
+ * file created 2009-10-27 19:20
16
+ * Added a call to child's set_form_col from set_form_row
17
+ Major changes 2010-02-11 19:51 to simplify version RFED16
18
+ * Still need to clean up this and viewport. make as light as possible
19
+ * If scrolling, no repainting should happen. Scrollpane could get the buffer
20
+ and scroll itself. Or ensure that inner object does not rework...
21
+
22
+ Pass handle_key to child, also repaint refer child.
23
+ Avoid passing to viewport as this would slow down alot.
24
+
25
+ NOTE: if a caller is interested in knowing what scrolling has happened, pls bind to :STATE_CHANGE, you will receive the viewport object. If you find this cumbersome, and wish to know only about scrolling, we can put in a scrolling event and inform of row or col scrolling. Or we can fire a property change with row or col increment.
26
+
27
+
28
+ --------
29
+ * License:
30
+ Same as Ruby's License (http://www.ruby-lang.org/LICENSE.txt)
31
+
32
+ =end
33
+ #require 'rubygems'
34
+ require 'ncurses'
35
+ require 'logger'
36
+ require 'rbcurse'
37
+ require 'rbcurse/rviewport'
38
+
39
+ include Ncurses
40
+ include RubyCurses
41
+ module RubyCurses
42
+ extend self
43
+
44
+ ##
45
+ # A scrollable box throgh which one can see portions of underlying object
46
+ # such as textarea, table or a form, usually the underlying data is larger
47
+ # than what can be displayed.
48
+
49
+ class ScrollPane < Widget
50
+ # viewport
51
+ # row_viewport
52
+ # column_viewport
53
+ # horizontal scrollbar 0-NONE, 1=ALWAYS, 2=AS_NEEDED
54
+ # vertical scrollbar 0-NONE, 1=ALWAYS, 2=AS_NEEDED
55
+ attr_accessor :cascade_changes # should changes in size go down to child, default false
56
+
57
+ def initialize form, config={}, &block
58
+ @focusable = true
59
+ @editable = false
60
+ #@left_margin = 1
61
+ @row = 0
62
+ @col = 0
63
+ super
64
+ @row_offset = @col_offset = 1
65
+ init_vars
66
+ # $log.debug " SCROLLPANE recvs form #{form.name}, #{form.window.name} " unless form.nil?
67
+
68
+
69
+ end
70
+ ##
71
+ # set child component being used in viewport
72
+ # @see set_viewport_view
73
+ def child ch
74
+ if ch != nil
75
+ @child = ch # added 2010-02-11 15:28 we might do away with viewport, setting panned to child
76
+ @child.rows_panned = @child.cols_panned = 0
77
+
78
+ ch.parent_component = self # added 2010-01-13 12:55 so offsets can go down ?
79
+
80
+ @child.should_create_buffer = true
81
+ @form.add_rows += 2 # related to scr_top XXX What if form not set. i cannot keep accumulating
82
+ update_child
83
+ # -3 since we start row +1 to get indented by 1, also we use
84
+ # height -1 in scrollpane, so we need -2 to indent, and one more
85
+ # for row
86
+ set_viewport_view(ch)
87
+ end
88
+ end
89
+ ##
90
+ # update of child's coordinates, needs to be called whenever it
91
+ # changes, so i need to call it before calling child's update
92
+ # FIXME - this is become 2 calls, make it one - becoming expensive
93
+ # if called often
94
+ def update_child
95
+ scr_top = 3 # for Pad, if Pad passed as in SplitPane
96
+ scr_left = 1 # for Pad, if Pad passed as in SplitPane
97
+ if @form.window.window_type == :WINDOW
98
+ scr_top = @row + 1
99
+ scr_left = @col + 1
100
+ @child.row(@row+@row_offset)
101
+ @child.col(@col+@col_offset)
102
+ else
103
+ # PAD case
104
+ @child.row(scr_top)
105
+ @child.col(scr_left)
106
+ end
107
+ @child.set_buffering(:target_window => @target_window || @form.window, :form => @form, :bottom => @height-3, :right => @width-3 )
108
+ @child.set_buffering(:screen_top => scr_top, :screen_left => scr_left)
109
+ # lets set the childs ext offsets
110
+ $log.debug "SCRP #{name} adding (to #{@child.name}) ext_row_off: #{@child.ext_row_offset} += #{@ext_row_offset} +#{@row_offset} "
111
+ $log.debug "SCRP adding ext_col_off: #{@child.ext_col_offset} += #{@ext_col_offset} +#{@col_offset} "
112
+ ## 2010-02-09 18:58 i think we should not put col_offset since the col
113
+ ## of child would take care of that. same for row_offset. XXX
114
+ @child.ext_col_offset += @ext_col_offset + @col + @col_offset - @screen_left # 2010-02-09 19:14
115
+ # added row and col setting to child RFED16 2010-02-17 00:22 as
116
+ # in splitpane. seems we are not using ext_offsets now ? texta
117
+ # and TV are not. and i've commented off from widget
118
+
119
+ $log.debug " #{@child.ext_row_offset} += #{@ext_row_offset} + #{@row} -#{@screen_top} "
120
+ @child.ext_row_offset += @ext_row_offset + @row + @row_offset - @screen_top
121
+ # adding this since child's ht should not be less. or we have a
122
+ # copywin failure
123
+ @child.height ||= @height
124
+ @child.width ||= @width
125
+ if @child.height < @height
126
+ @child.height = @height
127
+ end
128
+ if @child.width < @width
129
+ @child.width = @width
130
+ end
131
+
132
+ end
133
+ def init_vars
134
+ #@curpos = @pcol = @toprow = @current_index = 0
135
+ @hsb_policy = :AS_NEEDED
136
+ @vsb_policy = :AS_NEEDED
137
+ @repaint_required = true
138
+ @repaint_border = true
139
+ @row_outofbounds=0
140
+ @col_outofbounds=0
141
+ @border_width = 2
142
+ @screen_top = 0
143
+ @screen_left = 0
144
+ end
145
+ # set the component to be viewed
146
+ def set_viewport_view ch
147
+ @viewport = Viewport.new nil
148
+ @viewport.set_view ch
149
+ ## this -2 should depend on whether we are putting border/scrollbars or not.
150
+ # -1 added on 2010-02-16 23:35 since we are red 1, and bw
151
+ @viewport.set_view_size(@height-@border_width-0, @width-@border_width-0) # XXX make it one less
152
+ @viewport.cascade_changes = @cascade_changes # added 2010-02-04 18:19
153
+ @viewport.bind(:STATE_CHANGE) { |e| view_state_changed(e) }
154
+ @viewport.bind(:PROPERTY_CHANGE) { |e| view_property_changed(e) }
155
+ end
156
+ # return underlying viewport
157
+ # in order to run some of its methods
158
+ def get_viewport
159
+ return @viewport
160
+ end
161
+ # Directly set the viewport.
162
+ # Usually it is best to use set_viewport_view instead
163
+ def set_viewport vp
164
+ old = @viewport
165
+ @viewport = vp
166
+ fire_property_change "viewport", old, @viewport
167
+ end
168
+ # sets the component to be used as a rowheader TODO
169
+ def set_rowheader_view ch
170
+ old = @rowheader
171
+ @rowheader = Viewport.new
172
+ @rowheader.set_view ch
173
+ fire_property_change "row_header", old, @rowheader
174
+ end
175
+ # sets the component to be used as a column header TODO
176
+ def set_columnheader_view ch
177
+ old = @columnheader
178
+ @columnheader = Viewport.new
179
+ @columnheader.set_view ch
180
+ fire_property_change "column_header", old, @columnheader
181
+ end
182
+ def set_view_size h,w
183
+ # calling the property shoudl uniformally trigger fire_property_change
184
+ @viewport.set_view_size h,w
185
+ #height(h)
186
+ #width(w)
187
+ #fire_handler :PROPERTY_CHANGE, self # XXX should it be an event STATE_CHANGED with details
188
+ end
189
+ ## seems i wrote this only so i could set repaint_required to true
190
+ # However, now that VP calls state changed, that will happen XXX
191
+ def set_view_position r,c
192
+ ret = @viewport.set_view_position r,c
193
+ if ret
194
+ @repaint_required = true if ret
195
+ # fire_property_change("view_position",
196
+ end
197
+ return ret
198
+ end
199
+ # this method is registered with Viewport for changes
200
+ def view_state_changed ev
201
+ fire_handler :STATE_CHANGE, ev #???
202
+ @repaint_required = true
203
+ end
204
+ # this method is registered with Viewport for changes to properties
205
+ def view_property_changed ev
206
+ fire_handler :PROPERTY_CHANGE, ev #???
207
+ @repaint_required = true
208
+ end
209
+ # @return [true, false] false if r,c not changed
210
+ def increment_view_row num
211
+ #x r = @viewport.row() #- @viewport.top_margin
212
+ #x c = @viewport.col() #- @viewport.left_margin
213
+ r, c = @viewport.get_pad_top_left()
214
+ $log.debug " SCR inc viewport currently : r #{r} c #{c} "
215
+ r += num
216
+ ret = set_view_position r, c
217
+ v_scroll_bar if ret
218
+ return ret
219
+ end
220
+ # @return [true, false] false if r,c not changed
221
+ def increment_view_col num
222
+ r, c = @viewport.get_pad_top_left()
223
+ #r = @viewport.row() #- @viewport.top_margin
224
+ #c = @viewport.col() #- @viewport.left_margin
225
+ c += num
226
+ ret = set_view_position r, c
227
+ h_scroll_bar if ret
228
+ return ret
229
+ end
230
+ def repaint # scrollpane
231
+ # viewports child should repaint onto pad
232
+ # viewport then clips
233
+ # this calls viewports refresh from its refresh
234
+ return unless @repaint_required
235
+ if @viewport
236
+ update_child
237
+ $log.debug "SCRP #{@name} calling viewport repaint"
238
+ #@viewport.repaint_all true # 2010-01-16 23:09
239
+ @viewport.repaint_required true # changed 2010-01-19 19:34
240
+ @viewport.repaint # child's repaint should do it on its pad
241
+ $log.debug " #{@name} SCRP scrollpane repaint #{@graphic.name} "
242
+ end
243
+ # TODO this only if major change
244
+ if @repaint_border && @repaint_all # added 2010-01-16 20:15
245
+ #@graphic.wclear
246
+ $log.debug " #{@name} repaint all scroll: r #{@row} c #{@col} h #{@height}-1 w #{@width} "
247
+ bordercolor = @border_color || $datacolor
248
+ borderatt = @border_attrib || Ncurses::A_NORMAL
249
+ # NOTE - should be width-1 print_b reduces one from width, but
250
+ # not height !
251
+
252
+ @graphic.print_border_only(@row, @col, @height-1, @width, bordercolor, borderatt)
253
+ h_scroll_bar
254
+ v_scroll_bar
255
+ #x XXX @viewport.repaint_all(true) unless @viewport.nil? # brought here 2010-01-19 19:34
256
+ #@repaint_border = false # commented off on 2010-01-16 20:15 so repaint_all can have effect
257
+ end
258
+ return if @viewport == nil
259
+ $log.debug "SCRP #{@name} calling viewport to SCRP b2s #{@graphic.name} "
260
+ paint
261
+ end
262
+ def getvalue
263
+ # TODO
264
+ end
265
+ ## handle keys for scrollpane.
266
+ # First hands key to child object
267
+ # If unused, checks to see if it has anything mapped.
268
+ # If not consumed, returns :UNHANDLED, else 0.
269
+ def handle_key ch
270
+ # if this gets key it should just hand it to child
271
+ return :UNHANDLED if @viewport.nil? # added 2010-02-02 12:44
272
+ if @viewport != nil
273
+ $log.debug " calling child handle_key #{ch} "
274
+ ret = @viewport.handle_key ch
275
+ # XXX ret returns 0under normal circumstance, so will next line work ?
276
+ # what i mean is if ret == 0
277
+
278
+ @repaint_required = true if ret == 0 # added 2009-12-27 22:21 BUFFERED
279
+ $log.debug " ... child ret #{ret}"
280
+
281
+
282
+ ## Here's the only option scrollpane has of checking whether the child has
283
+ ##+ exceeded boundary BUFFERED 2009-12-29 23:12
284
+ # TEMPORARILY COMMENTED WHILE TESTING SCROLL UP AND DOWN XXX
285
+ #fr = @form.row
286
+ #fc = @form.col
287
+ #if fr >= @row + @height -2
288
+ #@form.setrowcol @row + @height -2, fc
289
+ #elsif fr < @row
290
+ #@form.setrowcol @row, fc
291
+ #end
292
+ #if fc >= @col + @width -1
293
+ #@form.setrowcol fr, @col + @width -1
294
+ #end
295
+ ##
296
+
297
+ return ret if ret != :UNHANDLED
298
+ end
299
+ ret = 0 # default return value
300
+ ks = keycode_tos(ch)
301
+ $log.debug " scrollpane gets KEY #{ch}, ks #{ks} "
302
+ case ch
303
+ when ?\M-n.getbyte(0)
304
+ ## scroll down one row (unless multiplier set)
305
+ ret = down
306
+ when ?\M-p.getbyte(0)
307
+ ## scroll up one row (unless multiplier set)
308
+ ret = up
309
+ #when ?0.getbyte(0), ?\C-[.getbyte(0)
310
+ #goto_start #start of buffer # cursor_start
311
+ #when ?\C-].getbyte(0)
312
+ #goto_end # end / bottom cursor_end # TODO
313
+ when ?\M-\<.getbyte(0)
314
+ @height.times { up ; }
315
+ when ?\M-\>.getbyte(0)
316
+ @height.times { down ; }
317
+ when KEY_DOWN
318
+ ret = down
319
+ #check_curpos
320
+ when ?\M-h.getbyte(0)
321
+ ## scroll left one position
322
+ repeatm {
323
+ ret = cursor_backward
324
+ @child.cols_panned = @child.cols_panned+1 if ret
325
+ @form.setrowcol @form.row, @form.col+1+@col_outofbounds if ret
326
+ }
327
+ when ?\M-l.getbyte(0)
328
+ ## scroll right one position
329
+ repeatm {
330
+ ret = cursor_forward
331
+ @child.cols_panned = @child.cols_panned-1 if ret
332
+ @form.setrowcol @form.row, @form.col-1+@col_outofbounds if ret
333
+ }
334
+ when KEY_BACKSPACE, 127
335
+ ret = cursor_backward
336
+ #when ?\C-u.getbyte(0)
337
+ ## multiplier. Series is 4 16 64
338
+ #@multiplier = (@multiplier == 0 ? 4 : @multiplier *= 4)
339
+ #return 0
340
+ when ?\C-c.getbyte(0)
341
+ $multiplier = 0
342
+ return 0
343
+ else
344
+ return :UNHANDLED
345
+ end
346
+ ret = :UNHANDLED if !ret
347
+ $multiplier = 0
348
+ return ret # 0 2010-02-04 18:47 returning ret else repaint is happening when UNHANDLED
349
+ end
350
+ # private
351
+ def _down
352
+ increment_view_row(1)
353
+ end
354
+ # private
355
+ def _up
356
+ increment_view_row(-1)
357
+ end
358
+ def cursor_forward
359
+ increment_view_col(1)
360
+ end
361
+ def cursor_backward
362
+ increment_view_col(-1)
363
+ end
364
+ def down
365
+ ## scroll down one row (currently one only)
366
+ $log.debug " MULT DOWN #{$multiplier} "
367
+ repeatm {
368
+ ret = _down
369
+ return unless ret # 2010-02-04 18:29
370
+ ## we've scrolled down, but we need to keep the cursor where
371
+ ##+ editing actually is. Isn't this too specific to textarea ?
372
+ $log.debug " SCRP setting row to #{@form.row-1} upon scrolling down "
373
+ ## only move up the cursor if its within bounds
374
+ # if @form.row > @row
375
+ @child.rows_panned = @child.rows_panned-1 if ret
376
+ @form.setrowcol @form.row-1+@row_outofbounds, @form.col if ret
377
+ }
378
+ end
379
+ def up
380
+ ## scroll up one row (currently one only)
381
+ repeatm {
382
+ ret = _up
383
+ return unless ret # 2010-02-04 18:29
384
+ $log.debug " SCRP setting row to #{@form.row+1} upon scrolling up R:#{@row} H:#{@height} "
385
+ # if @form.row < @row + @height
386
+ @child.rows_panned = @child.rows_panned+1 if ret
387
+ @form.setrowcol @form.row+1+@row_outofbounds, @form.col if ret
388
+ }
389
+ end
390
+ def on_enter
391
+ #super 2010-01-02 18:53 leading to a stack overflow XXX ???
392
+ set_form_row
393
+ end
394
+ # this is called once externally, on on_enter
395
+ #+ after that its called internally only, which in this case is never
396
+ def set_form_row
397
+ #@form.row = @row + 1 unless @form.nil?
398
+ if @viewport != nil
399
+ #$log.debug " calling scrollpane set_form_row"
400
+ ret = @viewport.child.set_form_row # added 2009-12-27 23:23 BUFFERED
401
+ ret = @viewport.child.set_form_col # added 2010-01-16 21:09
402
+ end
403
+ $log.debug " FORM SCRP #{@form.name} "
404
+ $log.debug "SCRP set_form_row #{@form.row} #{@form.col} "
405
+ end
406
+ ## added 2010-02-09 10:17
407
+ # Sometimes some parent objects may just call this.
408
+ # Would be better if they only called row and row called both ??? or is that less reliable
409
+ # In any case we have to combine this someday!!
410
+ def set_form_col
411
+ #@form.row = @row + 1 unless @form.nil?
412
+ if @viewport != nil
413
+ #$log.debug " calling scrollpane set_form_row"
414
+ ret = @viewport.child.set_form_col # added 2010-01-16 21:09
415
+ end
416
+ $log.debug " FORM SCRP #{@form.name} "
417
+ $log.debug "SCRP set_form_col #{@form.row} #{@form.col} "
418
+ end
419
+
420
+ ## this is called once only, on select_field by form.
421
+ ##+ after that not at all.
422
+ def rowcol
423
+ r1 = @row #+@row_offset
424
+ c1 = @col #+@col_offset
425
+ return r1, c1 if @viewport.nil? # added 2010-02-02 12:41
426
+
427
+ r,c = @viewport.child.rowcol # added 2009-12-28 15:23 BUFFERED
428
+ $log.debug "SCRP rowcol: #{r1} + #{r} , #{c1} + #{c} "
429
+ return r1+r, c1+c
430
+ end
431
+
432
+ def paint
433
+ @repaint_required = false
434
+ @repaint_all = false
435
+ end
436
+ def h_scroll_bar
437
+ return if @viewport.nil?
438
+ sz = (@viewport.width*1.00/@viewport.child().width)*@viewport.width
439
+ #$log.debug " h_scroll_bar sz #{sz}, #{@viewport.width} #{@viewport.child().width}"
440
+ sz = sz.ceil
441
+ return if sz < 1
442
+ start = 1
443
+ start = ((@viewport.col*1.00+@viewport.width)/@viewport.child().width)*@viewport.width
444
+ start -= sz
445
+ start = start.ceil
446
+ # # the problem with next 2 lines is that attributes of border could be overwritten
447
+ # draw horiz line
448
+ r = @row #+ @ext_row_offset # 2010-02-11 11:57 RFED16
449
+ c = @col #+ @ext_col_offset # 2010-02-11 11:57 RFED16
450
+ $log.debug " h_scroll_bar start #{start}, r #{r} c #{c} h:#{@height} "
451
+ @graphic.rb_mvwhline(r+@height-1, c+1, ACS_HLINE, @width-2)
452
+ # draw scroll bar
453
+ #sz.times{ |i| @graphic.mvaddch(r+@height-1, c+start+1+i, ACS_CKBOARD) }
454
+ sz.times{ |i| @graphic.rb_mvaddch(r+@height-1, c+start+1+i, ACS_CKBOARD) }
455
+ end
456
+ def v_scroll_bar
457
+ return if @viewport.nil?
458
+ sz = (@viewport.height*1.00/@viewport.child().height)*@viewport.height
459
+ #$log.debug " v_scroll_bar sz #{sz}, #{@viewport.width} #{@viewport.child().width}"
460
+ sz = sz.ceil
461
+ return if sz < 1
462
+ start = 1
463
+ start = ((@viewport.row*1.00+@viewport.height)/@viewport.child().height)*@viewport.height
464
+ start -= sz
465
+ r = @row #+ @ext_row_offset # 2010-02-11 11:57 RFED16
466
+ c = @col #+ @ext_col_offset # 2010-02-11 11:57 RFED16
467
+ $log.debug " v_scroll_bar start #{start}, col:#{@col} w:#{@width}, r #{r}+1 c #{c}+w-1 "
468
+ start = start.ceil
469
+ # # the problem with next 2 lines is that attributes of border could be overwritten
470
+ # draw verti line
471
+ # this is needed to erase previous bar when shrinking
472
+ #@graphic.mvwvline(r+1,c+@width-1, ACS_VLINE, @height-2)
473
+ @graphic.rb_mvwvline(r+1,c+@width-1, ACS_VLINE, @height-2)
474
+ # draw scroll bar
475
+ #sz.times{ |i| @graphic.mvaddch(r+start+1+i, c+@width-1, ACS_CKBOARD) }
476
+ sz.times{ |i| @graphic.rb_mvaddch(r+start+1+i, c+@width-1, ACS_CKBOARD) }
477
+ end
478
+ # set height
479
+ # a container must pass down changes in size to it's children
480
+ # 2010-02-04 18:06 - i am not sure about this. When viewport is set then it passes down
481
+ # changes to child which user did not intend. Maybe in splitpane it is okay but other cases?
482
+ # Perhaps its okay if scrollpane gets larger than child, not otherwise.
483
+ # added 2010-01-16 23:55
484
+ def height(*val)
485
+ return @height if val.empty?
486
+ oldvalue = @height || 0
487
+ super
488
+ @height = val[0]
489
+ return if @viewport == nil
490
+ delta = @height - oldvalue
491
+ return if delta == 0
492
+ @repaint_required = true
493
+ @viewport.height += delta
494
+ end
495
+ # set width
496
+ # a container must pass down changes in size to it's children
497
+ # added 2010-01-16 23:55
498
+ def width(*val)
499
+ return @width if val.empty?
500
+ oldvalue = @width || 0
501
+ super
502
+ @width = val[0]
503
+ return if @viewport == nil
504
+ delta = @width - oldvalue
505
+ return if delta == 0
506
+ @repaint_required = true
507
+ @viewport.width += delta
508
+ end
509
+
510
+ end # class ScrollPane
511
+ end # module