glimmer-dsl-swt 4.20.12.1 → 4.20.13.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +20 -0
- data/README.md +5 -5
- data/VERSION +1 -1
- data/glimmer-dsl-swt.gemspec +0 -0
- data/lib/glimmer/dsl/swt/dsl.rb +1 -1
- data/lib/glimmer/dsl/swt/{widget_listener_expression.rb → listener_expression.rb} +4 -4
- data/lib/glimmer/swt/custom/shape.rb +122 -10
- data/lib/glimmer/ui/custom_shape.rb +10 -0
- data/samples/hello/hello_canvas_drag_and_drop.rb +27 -39
- data/samples/hello/hello_custom_shape.rb +7 -1
- data/samples/hello/hello_shape.rb +7 -1
- metadata +3 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 3f381c0b3d2f94fb562307642fe38f69d806f1bd48432e49f1039dc19f23084e
|
4
|
+
data.tar.gz: 9e9965fcbc725ef7da7a4fb1b79d6026dc5ed4865fa4e81d19805ce93fd63db8
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 4fb4fb09032cf57af92d9afd700ee81c6bf7ebb5969abbf5e1927bfccb3604269f49a6e79a9761cddd005ea506146e50aa76dbcd34cb64aba16136b18b4b191c
|
7
|
+
data.tar.gz: b5c319a6c4d14d014297ffaa2f1a6d3195a662cd7d4604bd4685cbd026feee873c80ec400c1b47f680867f3176fef854048359bbbbba1db21f5dc89a25c3f9e7
|
data/CHANGELOG.md
CHANGED
@@ -1,5 +1,25 @@
|
|
1
1
|
# Change Log
|
2
2
|
|
3
|
+
### 4.20.13.0
|
4
|
+
|
5
|
+
- Shape `drag_and_move true` property to make shapes movable via dragging
|
6
|
+
- Shape `drag_source true` and `on_drop {|event| }` built-in support for drag and drop
|
7
|
+
- Refactor Hello, Canvas Drag and Drop! to use new Shape built-in support for drag and drop
|
8
|
+
|
9
|
+
### 4.20.12.4
|
10
|
+
|
11
|
+
- Update Hello, Shape! to take advantage of shape listeners (on mouse click, change color)
|
12
|
+
|
13
|
+
### 4.20.12.3
|
14
|
+
|
15
|
+
- Make Custom Shapes support on_event listeners just like Shapes
|
16
|
+
- Update Hello, Custom Shape! to take advantage of custom shape listeners (on mouse click, change color)
|
17
|
+
|
18
|
+
### 4.20.12.2
|
19
|
+
|
20
|
+
- Make Shape listeners check inclusion against all sub-shapes
|
21
|
+
- Refactor Hello, Canvas Drag & Drop! sample to use composite shapes (e.g. ball containing a ball border)
|
22
|
+
|
3
23
|
### 4.20.12.1
|
4
24
|
|
5
25
|
- Hello, Canvas Drag & Drop! sample
|
data/README.md
CHANGED
@@ -1,4 +1,4 @@
|
|
1
|
-
# [<img src="https://raw.githubusercontent.com/AndyObtiva/glimmer/master/images/glimmer-logo-hi-res.png" height=85 />](https://github.com/AndyObtiva/glimmer) Glimmer DSL for SWT 4.20.
|
1
|
+
# [<img src="https://raw.githubusercontent.com/AndyObtiva/glimmer/master/images/glimmer-logo-hi-res.png" height=85 />](https://github.com/AndyObtiva/glimmer) Glimmer DSL for SWT 4.20.13.0
|
2
2
|
## JRuby Desktop Development GUI Framework
|
3
3
|
[![Gem Version](https://badge.fury.io/rb/glimmer-dsl-swt.svg)](http://badge.fury.io/rb/glimmer-dsl-swt)
|
4
4
|
[![Travis CI](https://travis-ci.com/AndyObtiva/glimmer-dsl-swt.svg?branch=master)](https://travis-ci.com/github/AndyObtiva/glimmer-dsl-swt)
|
@@ -15,7 +15,7 @@
|
|
15
15
|
[<img src="https://covers.oreillystatic.com/images/9780596519650/lrg.jpg" width=105 /><br />
|
16
16
|
Featured in JRuby Cookbook](http://shop.oreilly.com/product/9780596519650.do) and [Chalmers/Gothenburg University Software Engineering Master's Lecture Material](http://www.cse.chalmers.se/~bergert/slides/guest_lecture_DSLs.pdf)
|
17
17
|
|
18
|
-
[Glimmer DSL for SWT](https://rubygems.org/gems/glimmer-dsl-swt) 4.20.
|
18
|
+
[Glimmer DSL for SWT](https://rubygems.org/gems/glimmer-dsl-swt) 4.20.13.0 includes [SWT 4.20](https://download.eclipse.org/eclipse/downloads/drops4/R-4.20-202106111600/), which was released on June 11, 2021. Gem version numbers are in sync with the SWT library versions. The first two digits represent the SWT version number. The last two digits represent the minor and patch versions of Glimmer DSL for SWT. Note that SWT now supports AARCH64 on Mac and Linux, but it is not fully tested in Glimmer DSL for SWT yet, so deem its support experimental for the time being without guarantees for functionality until declared otherwise (report any issues you may encounter).
|
19
19
|
|
20
20
|
**Starting in version 4.20.0.0, [Glimmer DSL for SWT](https://rubygems.org/gems/glimmer-dsl-swt) comes with the new [***Shine***](/docs/reference/GLIMMER_GUI_DSL_SYNTAX.md#shine) syntax** for highly intuitive and visually expressive View/Model Attribute Mapping, relying on `<=>` for bidirectional (two-way) data-binding and `<=` for unidirectional (one-way) data-binding, providing an alternative to the `bind` keyword (keep in mind that it is still a beta, so default back to `bind` whenever needed).
|
21
21
|
|
@@ -326,7 +326,7 @@ jgem install glimmer-dsl-swt
|
|
326
326
|
|
327
327
|
Or this command if you want a specific version:
|
328
328
|
```
|
329
|
-
jgem install glimmer-dsl-swt -v 4.20.
|
329
|
+
jgem install glimmer-dsl-swt -v 4.20.13.0
|
330
330
|
```
|
331
331
|
|
332
332
|
`jgem` is JRuby's version of `gem` command.
|
@@ -354,7 +354,7 @@ Note: if you're using activerecord or activesupport, keep in mind that Glimmer u
|
|
354
354
|
|
355
355
|
Add the following to `Gemfile`:
|
356
356
|
```
|
357
|
-
gem 'glimmer-dsl-swt', '~> 4.20.
|
357
|
+
gem 'glimmer-dsl-swt', '~> 4.20.13.0'
|
358
358
|
```
|
359
359
|
|
360
360
|
And, then run:
|
@@ -375,7 +375,7 @@ glimmer
|
|
375
375
|
```
|
376
376
|
|
377
377
|
```
|
378
|
-
Glimmer (JRuby Desktop Development GUI Framework) - JRuby Gem: glimmer-dsl-swt v4.20.
|
378
|
+
Glimmer (JRuby Desktop Development GUI Framework) - JRuby Gem: glimmer-dsl-swt v4.20.13.0
|
379
379
|
|
380
380
|
Usage: glimmer [--bundler] [--pd] [--quiet] [--debug] [--log-level=VALUE] [[ENV_VAR=VALUE]...] [[-jruby-option]...] (application.rb or task[task_args]) [[application2.rb]...]
|
381
381
|
|
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
4.20.
|
1
|
+
4.20.13.0
|
data/glimmer-dsl-swt.gemspec
CHANGED
Binary file
|
data/lib/glimmer/dsl/swt/dsl.rb
CHANGED
@@ -22,17 +22,17 @@
|
|
22
22
|
require 'glimmer/dsl/expression'
|
23
23
|
require 'glimmer/swt/display_proxy'
|
24
24
|
require 'glimmer/swt/custom/shape'
|
25
|
+
require 'glimmer/ui/custom_shape'
|
25
26
|
|
26
27
|
module Glimmer
|
27
28
|
module DSL
|
28
29
|
module SWT
|
29
|
-
|
30
|
-
|
31
|
-
|
30
|
+
# Widget, Shape, and Display listener experssion
|
31
|
+
class ListenerExpression < Expression
|
32
32
|
def can_interpret?(parent, keyword, *args, &block)
|
33
33
|
Glimmer::Config.logger.debug {"keyword starts with on_: #{keyword.start_with?('on_')}"}
|
34
34
|
return false unless keyword.start_with?('on_')
|
35
|
-
proper_parent = parent.respond_to?(:swt_widget) || parent.is_a?(Glimmer::SWT::DisplayProxy) || parent.is_a?(Glimmer::SWT::Custom::Shape)
|
35
|
+
proper_parent = parent.respond_to?(:swt_widget) || parent.is_a?(Glimmer::SWT::DisplayProxy) || parent.is_a?(Glimmer::SWT::Custom::Shape) || parent.is_a?(Glimmer::UI::CustomShape)
|
36
36
|
Glimmer::Config.logger.debug {"parent #{parent} is a widget, shape, or display: #{proper_parent}"}
|
37
37
|
return false unless proper_parent
|
38
38
|
Glimmer::Config.logger.debug {"block exists?: #{!block.nil?}"}
|
@@ -62,7 +62,12 @@ module Glimmer
|
|
62
62
|
class Shape
|
63
63
|
include Properties
|
64
64
|
|
65
|
+
DropEvent = Struct.new(:x, :y, :dragged_shape, :dragged_shape_original_x, :dragged_shape_original_y, :dragging_x, :dragging_y, keyword_init: true)
|
66
|
+
|
65
67
|
class << self
|
68
|
+
attr_accessor :dragging, :dragging_x, :dragging_y, :dragged_shape, :dragged_shape_original_x, :dragged_shape_original_y
|
69
|
+
alias dragging? dragging
|
70
|
+
|
66
71
|
def create(parent, keyword, *args, &property_block)
|
67
72
|
potential_shape_class_name = keyword.to_s.camelcase(:upper).to_sym
|
68
73
|
if constants.include?(potential_shape_class_name)
|
@@ -509,6 +514,7 @@ module Glimmer
|
|
509
514
|
def set_attribute(attribute_name, *args)
|
510
515
|
options = args.last if args.last.is_a?(Hash)
|
511
516
|
args.pop if !options.nil? && !options[:redraw].nil?
|
517
|
+
options ||= {}
|
512
518
|
perform_redraw = @perform_redraw
|
513
519
|
perform_redraw = options[:redraw] if perform_redraw.nil? && !options.nil?
|
514
520
|
perform_redraw ||= true
|
@@ -529,11 +535,12 @@ module Glimmer
|
|
529
535
|
@properties[ruby_attribute_getter_name] = args
|
530
536
|
amend_method_name_options_based_on_properties! if @content_added && new_property
|
531
537
|
property_change = true
|
538
|
+
calculated_paint_args_changed! if container?
|
532
539
|
end
|
533
540
|
if @content_added && perform_redraw && !drawable.is_disposed
|
534
541
|
redrawn = false
|
535
542
|
unless property_change
|
536
|
-
|
543
|
+
calculated_paint_args_changed!(children: false)
|
537
544
|
if is_a?(PathSegment)
|
538
545
|
root_path&.calculated_path_args = @calculated_path_args = false
|
539
546
|
calculated_args_changed!
|
@@ -549,7 +556,7 @@ module Glimmer
|
|
549
556
|
end
|
550
557
|
# TODO consider redrawing an image proxy's gc in the future
|
551
558
|
# TODO consider ensuring only a single redraw happens for a hierarchy of nested shapes
|
552
|
-
drawable.redraw
|
559
|
+
drawable.redraw if !redrawn && !drawable.is_a?(ImageProxy)
|
553
560
|
end
|
554
561
|
end
|
555
562
|
|
@@ -563,17 +570,41 @@ module Glimmer
|
|
563
570
|
@properties[attribute_name.to_s]
|
564
571
|
end
|
565
572
|
end
|
566
|
-
|
573
|
+
|
567
574
|
def can_handle_observation_request?(observation_request)
|
568
575
|
drawable.can_handle_observation_request?(observation_request)
|
569
576
|
end
|
570
577
|
|
571
578
|
def handle_observation_request(observation_request, &block)
|
572
579
|
shape_block = lambda do |event|
|
573
|
-
|
574
|
-
|
575
|
-
|
576
|
-
|
580
|
+
included = include?(event.x, event.y)
|
581
|
+
included ||= expanded_shapes.detect { |shape| shape.include?(event.x, event.y) }
|
582
|
+
block.call(event) if included
|
583
|
+
end
|
584
|
+
if observation_request == 'on_drop'
|
585
|
+
handle_observation_request('on_mouse_up') do |event|
|
586
|
+
if Shape.dragged_shape
|
587
|
+
drop_event = DropEvent.new(
|
588
|
+
dragged_shape: Shape.dragged_shape,
|
589
|
+
dragged_shape_original_x: Shape.dragged_shape_original_x,
|
590
|
+
dragged_shape_original_y: Shape.dragged_shape_original_y,
|
591
|
+
dragging_x: Shape.dragging_x,
|
592
|
+
dragging_y: Shape.dragging_y,
|
593
|
+
x: event.x,
|
594
|
+
y: event.y
|
595
|
+
)
|
596
|
+
begin
|
597
|
+
shape_block.call(drop_event)
|
598
|
+
rescue => e
|
599
|
+
Glimmer::Config.logger.error e.full_message
|
600
|
+
ensure
|
601
|
+
Shape.dragging = false
|
602
|
+
Shape.dragged_shape = nil
|
603
|
+
end
|
604
|
+
end
|
605
|
+
end
|
606
|
+
else
|
607
|
+
drawable.handle_observation_request(observation_request, &shape_block)
|
577
608
|
end
|
578
609
|
end
|
579
610
|
|
@@ -597,7 +628,7 @@ module Glimmer
|
|
597
628
|
set_attribute(method_name, *args)
|
598
629
|
elsif has_attribute?(method_name)
|
599
630
|
get_attribute(method_name)
|
600
|
-
else
|
631
|
+
else # TODO support proxying calls to handle_observation_request for listeners just like WidgetProxy
|
601
632
|
super
|
602
633
|
end
|
603
634
|
end
|
@@ -611,6 +642,80 @@ module Glimmer
|
|
611
642
|
super
|
612
643
|
end
|
613
644
|
end
|
645
|
+
|
646
|
+
def drag_and_move=(drag_and_move_value)
|
647
|
+
drag_and_move_old_value = @drag_and_move
|
648
|
+
@drag_and_move = drag_and_move_value
|
649
|
+
if @drag_and_move && !drag_and_move_old_value
|
650
|
+
@on_drag_detected = handle_observation_request('on_drag_detected') do |event|
|
651
|
+
if !Shape.dragging
|
652
|
+
Shape.dragging = true
|
653
|
+
Shape.dragging_x = event.x
|
654
|
+
Shape.dragging_y = event.y
|
655
|
+
Shape.dragged_shape = self
|
656
|
+
Shape.dragged_shape_original_x = x
|
657
|
+
Shape.dragged_shape_original_y = y
|
658
|
+
end
|
659
|
+
end
|
660
|
+
@drawable_on_mouse_move = drawable.handle_observation_request('on_mouse_move') do |event|
|
661
|
+
if Shape.dragging && Shape.dragged_shape == self
|
662
|
+
Shape.dragged_shape.move_by((event.x - Shape.dragging_x), (event.y - Shape.dragging_y))
|
663
|
+
Shape.dragging_x = event.x
|
664
|
+
Shape.dragging_y = event.y
|
665
|
+
end
|
666
|
+
end
|
667
|
+
@drawable_on_mouse_up = drawable.handle_observation_request('on_mouse_up') do |event|
|
668
|
+
if Shape.dragging && Shape.dragged_shape == self
|
669
|
+
Shape.dragging = false
|
670
|
+
end
|
671
|
+
end
|
672
|
+
elsif !@drag_and_move && drag_and_move_old_value
|
673
|
+
@on_drag_detected.deregister
|
674
|
+
@drawable_on_mouse_move.deregister
|
675
|
+
@drawable_on_mouse_up.deregister
|
676
|
+
end
|
677
|
+
end
|
678
|
+
|
679
|
+
def drag_and_move
|
680
|
+
@drag_and_move
|
681
|
+
end
|
682
|
+
|
683
|
+
def drag_source=(drag_source_value)
|
684
|
+
drag_source_old_value = @drag_source
|
685
|
+
@drag_source = drag_source_value
|
686
|
+
if @drag_source && !drag_source_old_value
|
687
|
+
@on_drag_detected = handle_observation_request('on_drag_detected') do |event|
|
688
|
+
if !Shape.dragging
|
689
|
+
Shape.dragging = true
|
690
|
+
Shape.dragging_x = event.x
|
691
|
+
Shape.dragging_y = event.y
|
692
|
+
Shape.dragged_shape = self
|
693
|
+
Shape.dragged_shape_original_x = x
|
694
|
+
Shape.dragged_shape_original_y = y
|
695
|
+
end
|
696
|
+
end
|
697
|
+
@drawable_on_mouse_move = drawable.handle_observation_request('on_mouse_move') do |event|
|
698
|
+
if Shape.dragging && Shape.dragged_shape == self
|
699
|
+
Shape.dragged_shape.move_by((event.x - Shape.dragging_x), (event.y - Shape.dragging_y))
|
700
|
+
Shape.dragging_x = event.x
|
701
|
+
Shape.dragging_y = event.y
|
702
|
+
end
|
703
|
+
end
|
704
|
+
@drawable_on_mouse_up = drawable.handle_observation_request('on_mouse_up') do |event|
|
705
|
+
if Shape.dragging && Shape.dragged_shape == self
|
706
|
+
Shape.dragging = false
|
707
|
+
end
|
708
|
+
end
|
709
|
+
elsif !@drag_source && drag_source_old_value
|
710
|
+
@on_drag_detected.deregister
|
711
|
+
@drawable_on_mouse_move.deregister
|
712
|
+
@drawable_on_mouse_up.deregister
|
713
|
+
end
|
714
|
+
end
|
715
|
+
|
716
|
+
def drag_source
|
717
|
+
@drag_source
|
718
|
+
end
|
614
719
|
|
615
720
|
def pattern(*args, type: nil)
|
616
721
|
instance_variable_name = "@#{type}_pattern"
|
@@ -790,7 +895,7 @@ module Glimmer
|
|
790
895
|
extent_args << extent_flags unless extent_flags.nil?
|
791
896
|
self.extent = paint_event.gc.send("#{@name}Extent", *extent_args)
|
792
897
|
end
|
793
|
-
if !@extent.nil? && (old_extent&.x != @extent&.x || old_extent&.y != @extent&.y)
|
898
|
+
if !@extent.nil? && (old_extent&.x != @extent&.x || old_extent&.y != @extent&.y) # TODO add a check to text content changing too
|
794
899
|
calculated_args_changed!
|
795
900
|
parent.calculated_args_changed_for_defaults! if parent.is_a?(Shape)
|
796
901
|
end
|
@@ -812,6 +917,12 @@ module Glimmer
|
|
812
917
|
shapes.each(&:calculated_args_changed!) if children
|
813
918
|
end
|
814
919
|
|
920
|
+
def calculated_paint_args_changed!(children: true)
|
921
|
+
@calculated_paint_args = nil
|
922
|
+
@all_parent_properties = nil
|
923
|
+
shapes.each(&:calculated_paint_args_changed!) if children
|
924
|
+
end
|
925
|
+
|
815
926
|
# Notifies object that calculated args changed for defaults. Returns true if redrawing and false otherwise.
|
816
927
|
def calculated_args_changed_for_defaults!
|
817
928
|
has_default_dimensions = default_width? || default_height?
|
@@ -1205,7 +1316,8 @@ module Glimmer
|
|
1205
1316
|
end
|
1206
1317
|
end
|
1207
1318
|
else
|
1208
|
-
@
|
1319
|
+
@original_properties ||= @properties
|
1320
|
+
@properties = all_parent_properties.merge(@original_properties)
|
1209
1321
|
@properties['background'] = [@drawable.background] if fill? && !has_some_background?
|
1210
1322
|
@properties['foreground'] = [@drawable.foreground] if @drawable.respond_to?(:foreground) && draw? && !has_some_foreground?
|
1211
1323
|
# TODO regarding alpha, make sure to reset it to parent stored alpha once we allow setting shape properties on parents directly without shapes
|
@@ -254,6 +254,16 @@ module Glimmer
|
|
254
254
|
end
|
255
255
|
end
|
256
256
|
|
257
|
+
# TODO consider bringing observer_registrations method from CustomWidget if needed
|
258
|
+
|
259
|
+
def can_handle_observation_request?(observation_request)
|
260
|
+
body_root&.can_handle_observation_request?(observation_request)
|
261
|
+
end
|
262
|
+
|
263
|
+
def handle_observation_request(observation_request, &block)
|
264
|
+
body_root.handle_observation_request(observation_request, &block)
|
265
|
+
end
|
266
|
+
|
257
267
|
def method_missing(method, *args, &block)
|
258
268
|
# TODO Consider supporting a glimmer error silencing option for methods defined here
|
259
269
|
# but fail the glimmer DSL for the right reason to avoid seeing noise in the log output
|
@@ -25,15 +25,16 @@ class HelloCanvasDragAndDrop
|
|
25
25
|
}
|
26
26
|
|
27
27
|
background :white
|
28
|
-
|
29
|
-
@
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
28
|
+
|
29
|
+
@drop_square = rectangle(150, 260, 50, 50) {
|
30
|
+
background :white
|
31
|
+
|
32
|
+
# unspecified width and height become max width and max height by default
|
33
|
+
@drop_square_border = rectangle(0, 0) {
|
34
|
+
foreground :black
|
35
|
+
line_width 3
|
36
|
+
line_style :dash
|
37
|
+
}
|
37
38
|
|
38
39
|
@number_shape = text {
|
39
40
|
x :default
|
@@ -42,50 +43,37 @@ class HelloCanvasDragAndDrop
|
|
42
43
|
}
|
43
44
|
|
44
45
|
on_mouse_move do
|
45
|
-
if
|
46
|
-
@drop_square_border.foreground = :red
|
47
|
-
end
|
46
|
+
@drop_square_border.foreground = :red if Glimmer::SWT::Custom::Shape.dragging?
|
48
47
|
end
|
49
48
|
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
@
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
string (ball_count + 1).to_s
|
59
|
-
}
|
49
|
+
on_drop do |event|
|
50
|
+
ball_count = @number_shape.string.to_i
|
51
|
+
@number_shape.dispose
|
52
|
+
@drop_square.content {
|
53
|
+
@number_shape = text {
|
54
|
+
x :default
|
55
|
+
y :default
|
56
|
+
string (ball_count + 1).to_s
|
60
57
|
}
|
61
|
-
|
62
|
-
|
58
|
+
}
|
59
|
+
event.dragged_shape.dispose
|
63
60
|
end
|
64
61
|
}
|
65
62
|
|
66
63
|
10.times do |n|
|
67
64
|
an_oval = oval((rand*300).to_i, (rand*200).to_i, 50, 50) {
|
68
65
|
background rgb(255, 165, 0)
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
66
|
+
drag_source true
|
67
|
+
|
68
|
+
# unspecified width and height become max width and max height by default
|
69
|
+
oval(0, 0) {
|
70
|
+
foreground :black
|
71
|
+
}
|
75
72
|
}
|
76
73
|
end
|
77
74
|
|
78
75
|
on_mouse_up do
|
79
76
|
@drop_square_border.foreground = :black
|
80
|
-
@dragging = nil
|
81
|
-
end
|
82
|
-
|
83
|
-
on_mouse_move do |event|
|
84
|
-
if @dragging
|
85
|
-
@dragging.move_by((event.x - @last_x), (event.y - @last_y))
|
86
|
-
@last_x = event.x
|
87
|
-
@last_y = event.y
|
88
|
-
end
|
89
77
|
end
|
90
78
|
}
|
91
79
|
}
|
@@ -65,8 +65,14 @@ class HelloCustomShape
|
|
65
65
|
y_location = (rand*HEIGHT/2).to_i%HEIGHT + (rand*15).to_i
|
66
66
|
foreground_color = rgb(rand*255, rand*255, rand*255)
|
67
67
|
|
68
|
-
stick_figure(x: x_location, y: y_location, width: 35+n*2, height: 35+n*2) {
|
68
|
+
a_stick_figure = stick_figure(x: x_location, y: y_location, width: 35+n*2, height: 35+n*2) {
|
69
69
|
foreground foreground_color
|
70
|
+
drag_and_move true
|
71
|
+
|
72
|
+
# on mouse click, change color
|
73
|
+
on_mouse_up do
|
74
|
+
a_stick_figure.foreground = rgb(rand*255, rand*255, rand*255)
|
75
|
+
end
|
70
76
|
}
|
71
77
|
}
|
72
78
|
}
|
@@ -37,8 +37,14 @@ class HelloShape
|
|
37
37
|
y_location = (rand*125).to_i%200 + (rand*15).to_i
|
38
38
|
foreground_color = rgb(rand*255, rand*255, rand*255)
|
39
39
|
|
40
|
-
stick_figure(x_location, y_location, 35+n*2, 35+n*2) {
|
40
|
+
a_stick_figure = stick_figure(x_location, y_location, 35+n*2, 35+n*2) {
|
41
41
|
foreground foreground_color
|
42
|
+
drag_and_move true
|
43
|
+
|
44
|
+
# on mouse click, change color
|
45
|
+
on_mouse_up do
|
46
|
+
a_stick_figure.foreground = rgb(rand*255, rand*255, rand*255)
|
47
|
+
end
|
42
48
|
}
|
43
49
|
}
|
44
50
|
}
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: glimmer-dsl-swt
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 4.20.
|
4
|
+
version: 4.20.13.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Andy Maleh
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2021-07-
|
11
|
+
date: 2021-07-27 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
requirement: !ruby/object:Gem::Requirement
|
@@ -438,6 +438,7 @@ files:
|
|
438
438
|
- lib/glimmer/dsl/swt/layout_data_expression.rb
|
439
439
|
- lib/glimmer/dsl/swt/layout_expression.rb
|
440
440
|
- lib/glimmer/dsl/swt/list_selection_data_binding_expression.rb
|
441
|
+
- lib/glimmer/dsl/swt/listener_expression.rb
|
441
442
|
- lib/glimmer/dsl/swt/menu_bar_expression.rb
|
442
443
|
- lib/glimmer/dsl/swt/menu_expression.rb
|
443
444
|
- lib/glimmer/dsl/swt/message_box_expression.rb
|
@@ -462,7 +463,6 @@ files:
|
|
462
463
|
- lib/glimmer/dsl/swt/tree_items_data_binding_expression.rb
|
463
464
|
- lib/glimmer/dsl/swt/tree_properties_expression.rb
|
464
465
|
- lib/glimmer/dsl/swt/widget_expression.rb
|
465
|
-
- lib/glimmer/dsl/swt/widget_listener_expression.rb
|
466
466
|
- lib/glimmer/launcher.rb
|
467
467
|
- lib/glimmer/rake_task.rb
|
468
468
|
- lib/glimmer/rake_task/list.rb
|