Class: Processing::App

Inherits:
PApplet
  • Object
show all
Includes:
Math, MathTool, HelperMethods, Render
Defined in:
lib/jruby_art/app.rb

Overview

All sketches extend this class

Class Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods included from HelperMethods

#blend_color, #buffer, #color, #dist, #find_method, #frame_rate, #grid, #hsb_color, #int_to_ruby_colors, #java_self, #kamera, #key, #key_pressed?, #lerp_color, #load_strings, #max, #min, #mouse_pressed?, #perspektiv, #proxy_java_fields, #save_strings, #thread, #web_to_color_array

Constructor Details

#initializeApp

Since processing-3.0 you should prefer setting the sketch width and height and renderer using the size method in the settings loop of the sketch (as with vanilla processing) but is hidden see created java. Options are no longer relevant, define post_initialize method to use custom options (see Sandi Metz POODR)



97
98
99
100
101
102
103
104
105
106
107
108
109
110
# File 'lib/jruby_art/app.rb', line 97

def initialize
  super()
  $app = self
  proxy_java_fields
  mix_proxy_into_inner_classes
  java.lang.Thread.default_uncaught_exception_handler = proc do |_thread_, exception|
    puts(exception.class.to_s)
    puts(exception.message)
    puts(exception.backtrace.map { |trace| "\t#{trace}" })
    close
  end
  # NB: this is the processing runSketch() method as used by processing.py
  run_sketch
end

Class Attribute Details

.library_loaderObject

Handy getters and setters on the class go here:



59
60
61
# File 'lib/jruby_art/app.rb', line 59

def library_loader
  @library_loader
end

.sketch_classObject

Handy getters and setters on the class go here:



59
60
61
# File 'lib/jruby_art/app.rb', line 59

def sketch_class
  @sketch_class
end

Class Method Details

.inherited(subclass) ⇒ Object

Keep track of what inherits from the Processing::App, because we’re going to want to instantiate one.



52
53
54
55
# File 'lib/jruby_art/app.rb', line 52

def self.inherited(subclass)
  super(subclass)
  @sketch_class = subclass
end

.library_loaded?(library_name) ⇒ Boolean

Returns:

  • (Boolean)


67
68
69
# File 'lib/jruby_art/app.rb', line 67

def library_loaded?(library_name)
  library_loader.library_loaded?(library_name)
end

.load_java_library(*args) ⇒ Object



75
76
77
# File 'lib/jruby_art/app.rb', line 75

def load_java_library(*args)
  library_loader.load_java_library(*args)
end

.load_libraries(*args) ⇒ Object Also known as: load_library



61
62
63
64
# File 'lib/jruby_art/app.rb', line 61

def load_libraries(*args)
  library_loader ||= LibraryLoader.new
  library_loader.load_library(*args)
end

.load_ruby_library(*args) ⇒ Object



71
72
73
# File 'lib/jruby_art/app.rb', line 71

def load_ruby_library(*args)
  library_loader.load_ruby_library(*args)
end

.method_added(method_name) ⇒ Object

When certain special methods get added to the sketch, we need to let Processing call them by their expected Java names.



81
82
83
84
# File 'lib/jruby_art/app.rb', line 81

def method_added(method_name) #:nodoc:
  return unless METHODS_TO_ALIAS.key?(method_name)
  alias_method METHODS_TO_ALIAS[method_name], method_name
end

Instance Method Details

#closeObject

Close and shutter a running sketch. But don’t exit. way of disposing of sketch window…



155
156
157
158
159
160
161
# File 'lib/jruby_art/app.rb', line 155

def close
  control_panel.remove if respond_to?(:control_panel)
  surface.stopThread
  surface.setVisible(false) if surface.isStopped
  dispose
  $app = nil
end

#data_path(dat) ⇒ Object



130
131
132
133
134
# File 'lib/jruby_art/app.rb', line 130

def data_path(dat)
  dat_root = File.join(SKETCH_ROOT, 'data')
  Dir.mkdir(dat_root) unless File.exist?(dat_root)    
  File.join(dat_root, dat)      
end

#exitObject



163
164
165
166
# File 'lib/jruby_art/app.rb', line 163

def exit
  control_panel.remove if respond_to?(:control_panel)
  super()
end

#library_loaded?(library_name) ⇒ Boolean

Returns:

  • (Boolean)


87
88
89
# File 'lib/jruby_art/app.rb', line 87

def library_loaded?(library_name)
  self.class.library_loaded?(library_name)
end

#on_top(arg = true) ⇒ Object



144
145
146
# File 'lib/jruby_art/app.rb', line 144

def on_top(arg = true)
  surface.set_always_on_top(arg)
end

#post_initialize(_args) ⇒ Object



148
149
150
# File 'lib/jruby_art/app.rb', line 148

def post_initialize(_args)
  nil
end

#resizable(arg = true) ⇒ Object



140
141
142
# File 'lib/jruby_art/app.rb', line 140

def resizable(arg = true)
  surface.set_resizable(arg)
end

#size(*args) ⇒ Object



112
113
114
115
116
117
118
119
# File 'lib/jruby_art/app.rb', line 112

def size(*args)
  w, h, mode = *args
  @width ||= w
  @height ||= h
  @render_mode ||= mode
  import_opengl if /opengl/ =~ mode
  super(*args)
end

#sketch_classObject



46
47
48
# File 'lib/jruby_art/app.rb', line 46

def sketch_class
  self.class.sketch_class
end

#sketch_path(spath = nil) ⇒ Object



125
126
127
128
# File 'lib/jruby_art/app.rb', line 125

def sketch_path(spath = nil)
  return super() if spath.nil?
  super(spath)
end

#sketch_size(x, y) ⇒ Object



136
137
138
# File 'lib/jruby_art/app.rb', line 136

def sketch_size(x, y)
  surface.set_size(x, y)
end

#sketch_title(title) ⇒ Object



121
122
123
# File 'lib/jruby_art/app.rb', line 121

def sketch_title(title)
  surface.set_title(title)
end