Class: Processing::Context

Inherits:
Object
  • Object
show all
Includes:
GraphicsContext, Xot::Inspectable
Defined in:
lib/processing/context.rb

Overview

Processing context

Constant Summary collapse

Capture =
Processing::Capture
Font =
Processing::Font
Graphics =
Processing::Graphics
Image =
Processing::Image
Shader =
Processing::Shader
TextBounds =
Processing::TextBounds
Touch =
Processing::Touch
Vector =
Processing::Vector
PORTRAIT =

Portrait for windowOrientation

:portrait
LANDSCAPE =

Landscape for windowOrientation

:landscape

Constants included from GraphicsContext

GraphicsContext::ADD, GraphicsContext::ALT, GraphicsContext::ARC, GraphicsContext::BACKSPACE, GraphicsContext::BASELINE, GraphicsContext::BEVEL, GraphicsContext::BLEND, GraphicsContext::BLUR, GraphicsContext::BOTTOM, GraphicsContext::CAPSLOCK, GraphicsContext::CENTER, GraphicsContext::CLAMP, GraphicsContext::CLEAR, GraphicsContext::CLOSE, GraphicsContext::COLOR_CODES, GraphicsContext::COMMAND, GraphicsContext::CONTROL, GraphicsContext::CORNER, GraphicsContext::CORNERS, GraphicsContext::DARKEST, GraphicsContext::DEGREES, GraphicsContext::DELETE, GraphicsContext::DOWN, GraphicsContext::ELLIPSE, GraphicsContext::ENTER, GraphicsContext::ESC, GraphicsContext::EXCLUSION, GraphicsContext::F1, GraphicsContext::F10, GraphicsContext::F11, GraphicsContext::F12, GraphicsContext::F13, GraphicsContext::F14, GraphicsContext::F15, GraphicsContext::F16, GraphicsContext::F17, GraphicsContext::F18, GraphicsContext::F19, GraphicsContext::F2, GraphicsContext::F20, GraphicsContext::F21, GraphicsContext::F22, GraphicsContext::F23, GraphicsContext::F24, GraphicsContext::F3, GraphicsContext::F4, GraphicsContext::F5, GraphicsContext::F6, GraphicsContext::F7, GraphicsContext::F8, GraphicsContext::F9, GraphicsContext::FUNCTION, GraphicsContext::GRAY, GraphicsContext::GROUP, GraphicsContext::HALF_PI, GraphicsContext::HELP, GraphicsContext::HOME, GraphicsContext::HSB, GraphicsContext::IMAGE, GraphicsContext::INVERT, GraphicsContext::LEFT, GraphicsContext::LIGHTEST, GraphicsContext::LINE, GraphicsContext::LINES, GraphicsContext::MITER, GraphicsContext::MULTIPLY, GraphicsContext::NORMAL, GraphicsContext::OPEN, GraphicsContext::OPTION, GraphicsContext::P5JS, GraphicsContext::PAGEDOWN, GraphicsContext::PAGEUP, GraphicsContext::PI, GraphicsContext::POINTS, GraphicsContext::PROCESSING, GraphicsContext::PROJECT, GraphicsContext::QUAD, GraphicsContext::QUADS, GraphicsContext::QUAD_STRIP, GraphicsContext::QUARTER_PI, GraphicsContext::RADIANS, GraphicsContext::RADIUS, GraphicsContext::RECT, GraphicsContext::REPEAT, GraphicsContext::REPLACE, GraphicsContext::RGB, GraphicsContext::RGBA, GraphicsContext::RIGHT, GraphicsContext::ROUND, GraphicsContext::SCREEN, GraphicsContext::SECTION, GraphicsContext::SHIFT, GraphicsContext::SPACE, GraphicsContext::SQUARE, GraphicsContext::SUBTRACT, GraphicsContext::TAB, GraphicsContext::TAU, GraphicsContext::TESS, GraphicsContext::THRESHOLD, GraphicsContext::TOP, GraphicsContext::TRIANGLE, GraphicsContext::TRIANGLES, GraphicsContext::TRIANGLE_FAN, GraphicsContext::TRIANGLE_STRIP, GraphicsContext::TWO_PI, GraphicsContext::UP, GraphicsContext::WIN

Instance Method Summary collapse

Methods included from GraphicsContext

#abs, #acos, #alpha, #angleMode, #applyMatrix, #arc, #asin, #atan, #atan2, #background, #beginContour, #beginShape, #bezier, #bezierDetail, #bezierPoint, #bezierTangent, #bezierVertex, #blend, #blendMode, #blue, #brightness, #ceil, #circle, #clear, #clip, #color, #colorMode, #constrain, #copy, #cos, #createCapture, #createFont, #createGraphics, #createImage, #createShader, #createShape, #createVector, #curve, #curveDetail, #curvePoint, #curveTangent, #curveTightness, #curveVertex, #degrees, #dist, #ellipse, #ellipseMode, #endContour, #endShape, #exp, #fill, #filter, #floor, #green, #height, #hue, #image, #imageMode, #lerp, #lerpColor, #line, #loadFont, #loadImage, #loadPixels, #loadShader, #loadShape, #log, #mag, #map, #max, #min, #noClip, #noFill, #noStroke, #noTint, #noise, #noiseDetail, #noiseSeed, #norm, #pixelHeight, #pixelWidth, #pixels, #point, #pop, #popMatrix, #popStyle, #pow, #printMatrix, #push, #pushMatrix, #pushStyle, #quad, #quadraticVertex, #radians, #random, #randomGaussian, #randomSeed, #rect, #rectMode, #red, #renderMode, #requestImage, #resetMatrix, #resetShader, #rotate, #rotateX, #rotateY, #rotateZ, #round, #saturation, #save, #scale, #shader, #shape, #shapeMode, #shearX, #shearY, #sin, #sq, #sqrt, #square, #stroke, #strokeCap, #strokeJoin, #strokeWeight, #tan, #text, #textAlign, #textAscent, #textDescent, #textFont, #textLeading, #textSize, #textWidth, #texture, #textureMode, #textureWrap, #tint, #translate, #triangle, #updatePixels, #vertex, #width

Instance Method Details

#createCanvas(width, height, pixelDensity: self.pixelDensity) ⇒ nil

Changes canvas size.

Parameters:

  • width (Integer)

    new width

  • height (Integer)

    new height

  • pixelDensity (Numeric) (defaults to: self.pixelDensity)

    new pixel density

Returns:

  • (nil)

    nil

See Also:



435
436
437
438
439
# File 'lib/processing/context.rb', line 435

def createCanvas(width, height, pixelDensity: self.pixelDensity)
  windowResize width, height
  resizeCanvas__ width, height, pixelDensity
  nil
end

#deltaTimeFloat

Returns the elapsed time after previous drawing event

Returns:

  • (Float)

    elapsed time in milliseconds

See Also:



675
676
677
# File 'lib/processing/context.rb', line 675

def deltaTime()
  @window__.event.dt * 1000
end

#displayDensityNumeric

Returns the pixel density of the display.



545
546
547
# File 'lib/processing/context.rb', line 545

def displayDensity()
  @window__.painter.pixel_density
end

#displayHeightNumeric

Returns the height of the display.



534
535
536
# File 'lib/processing/context.rb', line 534

def displayHeight()
  @window__.screen.height
end

#displayWidthNumeric

Returns the width of the display.



523
524
525
# File 'lib/processing/context.rb', line 523

def displayWidth()
  @window__.screen.width
end

#doubleClicked(&block) ⇒ nil

Defines doubleClicked block.

Returns:

  • (nil)

    nil

See Also:



327
328
329
330
# File 'lib/processing/context.rb', line 327

def doubleClicked(&block)
  @doubleClickedBlock__ = block if block
  nil
end

#draw(&block) ⇒ nil

Defines draw block.



219
220
221
222
# File 'lib/processing/context.rb', line 219

def draw(&block)
  @drawBlock__ = block if block
  nil
end

#focusedBoolean

Returns weather the window is active or not.



643
644
645
# File 'lib/processing/context.rb', line 643

def focused()
  @window__.active?
end

#frameCountInteger

Returns the number of frames since the program started.



654
655
656
# File 'lib/processing/context.rb', line 654

def frameCount()
  @frameCount__
end

#frameRateFloat

Returns the number of frames per second.



665
666
667
# File 'lib/processing/context.rb', line 665

def frameRate()
  @window__.event.fps
end

#fullscreen(state = nil) ⇒ Boolean Also known as: fullScreen

Toggles full-screen state or returns the current state.

Parameters:

  • state (Boolean) (defaults to: nil)

    Whether to display full-screen or not

Returns:

  • (Boolean)

    current state

See Also:



477
478
479
480
# File 'lib/processing/context.rb', line 477

def fullscreen(state = nil)
  @window__.fullscreen = state if state != nil
  @window__.fullscreen?
end

#keyString

Returns the last key that was pressed or released.



686
687
688
# File 'lib/processing/context.rb', line 686

def key()
  @key__
end

#keyCodeSymbol

Returns the last key code that was pressed or released.



697
698
699
# File 'lib/processing/context.rb', line 697

def keyCode()
  @keyCode__
end

#keyIsDown(keyCode) ⇒ Boolean

Returns weather or not the key is currently pressed.

Parameters:

  • keyCode (Numeric)

    code for the key

Returns:

  • (Boolean)

    is the key pressed or not

See Also:



719
720
721
# File 'lib/processing/context.rb', line 719

def keyIsDown(keyCode)
  @keysPressed__.include? keyCode
end

#keyIsPressedBoolean

Returns whether or not any key is pressed.

Returns:

  • (Boolean)

    is any key pressed or not

See Also:



707
708
709
# File 'lib/processing/context.rb', line 707

def keyIsPressed()
  not @keysPressed__.empty?
end

#keyPressed(&block) ⇒ Boolean

Defines keyPressed block.

Returns:

  • (Boolean)

    is any key pressed or not

See Also:



231
232
233
234
# File 'lib/processing/context.rb', line 231

def keyPressed(&block)
  @keyPressedBlock__ = block if block
  keyIsPressed
end

#keyReleased(&block) ⇒ nil

Defines keyReleased block.



243
244
245
246
# File 'lib/processing/context.rb', line 243

def keyReleased(&block)
  @keyReleasedBlock__ = block if block
  nil
end

#keyTyped(&block) ⇒ nil

Defines keyTyped block.



255
256
257
258
# File 'lib/processing/context.rb', line 255

def keyTyped(&block)
  @keyTypedBlock__ = block if block
  nil
end

#loopnil

Enables calling draw block on every frame.



803
804
805
# File 'lib/processing/context.rb', line 803

def loop()
  @loop__ = true
end

#motion(&block) ⇒ nil

Defines motion block.

Returns:

  • (nil)

    nil



404
405
406
407
# File 'lib/processing/context.rb', line 404

def motion(&block)
  @motionBlock__ = block if block
  nil
end

#motionGravityVector

Returns vector for real world gravity

Returns:



792
793
794
# File 'lib/processing/context.rb', line 792

def motionGravity()
  @motionGravity__
end

#mouseButtonNumeric

Returns which mouse button was pressed



774
775
776
# File 'lib/processing/context.rb', line 774

def mouseButton()
  ((@pointersPressed__ + @pointersReleased__) & [LEFT, RIGHT, CENTER]).last
end

#mouseClicked(&block) ⇒ nil

Defines mouseClicked block.



316
317
318
319
# File 'lib/processing/context.rb', line 316

def mouseClicked(&block)
  @mouseClickedBlock__ = block if block
  nil
end

#mouseDragged(&block) ⇒ nil

Defines mouseDragged block.



304
305
306
307
# File 'lib/processing/context.rb', line 304

def mouseDragged(&block)
  @mouseDraggedBlock__ = block if block
  nil
end

#mouseMoved(&block) ⇒ nil

Defines mouseMoved block.



292
293
294
295
# File 'lib/processing/context.rb', line 292

def mouseMoved(&block)
  @mouseMovedBlock__ = block if block
  nil
end

#mousePressed(&block) ⇒ Boolean

Defines mousePressed block.



268
269
270
271
# File 'lib/processing/context.rb', line 268

def mousePressed(&block)
  @mousePressedBlock__ = block if block
  not @pointersPressed__.empty?
end

#mouseReleased(&block) ⇒ nil

Defines mouseReleased block.



280
281
282
283
# File 'lib/processing/context.rb', line 280

def mouseReleased(&block)
  @mouseReleasedBlock__ = block if block
  nil
end

#mouseWheel(&block) ⇒ nil

Defines mouseWheel block.



339
340
341
342
# File 'lib/processing/context.rb', line 339

def mouseWheel(&block)
  @mouseWheelBlock__ = block if block
  nil
end

#mouseXNumeric

Returns mouse x position

Returns:

  • (Numeric)

    horizontal position of mouse

See Also:



730
731
732
# File 'lib/processing/context.rb', line 730

def mouseX()
  @pointer__&.x || 0
end

#mouseYNumeric

Returns mouse y position

Returns:

  • (Numeric)

    vertical position of mouse

See Also:



741
742
743
# File 'lib/processing/context.rb', line 741

def mouseY()
  @pointer__&.y || 0
end

#noLoopnil

Disables calling draw block on every frame.



814
815
816
# File 'lib/processing/context.rb', line 814

def noLoop()
  @loop__ = false
end

#noSmoothnil

Disables anti-aliasing.



505
506
507
508
# File 'lib/processing/context.rb', line 505

def noSmooth()
  @smooth__ = false
  resizeCanvas__ width, height, pixelDensity
end

#pixelDensity(density = nil) ⇒ Numeric

Changes and returns canvas pixel density.

Parameters:

  • density (Numeric) (defaults to: nil)

    new pixel density

Returns:

  • (Numeric)

    current pixel density

See Also:



463
464
465
466
# File 'lib/processing/context.rb', line 463

def pixelDensity(density = nil)
  resizeCanvas__ width, height, density if density
  @window__.canvas.pixel_density
end

#pmouseXNumeric

Returns mouse x position in previous frame

Returns:

  • (Numeric)

    horizontal position of mouse

See Also:



752
753
754
# File 'lib/processing/context.rb', line 752

def pmouseX()
  @pointerPrev__&.x || 0
end

#pmouseYNumeric

Returns mouse y position in previous frame

Returns:

  • (Numeric)

    vertical position of mouse

See Also:



763
764
765
# File 'lib/processing/context.rb', line 763

def pmouseY()
  @pointerPrev__&.y || 0
end

#redrawnil

Calls draw block to redraw frame.



825
826
827
# File 'lib/processing/context.rb', line 825

def redraw()
  @redraw__ = true
end

#setTitle(title) ⇒ nil

Changes title of window.

Parameters:

  • title (String)

    new title

Returns:

  • (nil)

    nil

See Also:



449
450
451
452
# File 'lib/processing/context.rb', line 449

def setTitle(title)
  @window__.title = title
  nil
end

#setup(&block) ⇒ nil

Defines setup block.



186
187
188
189
# File 'lib/processing/context.rb', line 186

def setup(&block)
  @window__.setup = block if block
  nil
end

#size(width, height, pixelDensity: self.pixelDensity) ⇒ nil

Changes canvas size.

Parameters:

  • width (Integer)

    new width

  • height (Integer)

    new height

  • pixelDensity (Numeric) (defaults to: self.pixelDensity)

    new pixel density

Returns:

  • (nil)

    nil

See Also:



419
420
421
422
423
# File 'lib/processing/context.rb', line 419

def size(width, height, pixelDensity: self.pixelDensity)
  windowResize width, height
  resizeCanvas__ width, height, pixelDensity
  nil
end

#smoothnil

Enables anti-aliasing. (Anti-aliasing is disabled on high DPI screen)



492
493
494
495
496
# File 'lib/processing/context.rb', line 492

def smooth()
  @smooth__ = true
  resizeCanvas__ width, height, pixelDensity
  nil
end

#touchEnded(&block) ⇒ nil

Defines touchEnded block.

Returns:

  • (nil)

    nil

See Also:



361
362
363
364
# File 'lib/processing/context.rb', line 361

def touchEnded(&block)
  @touchEndedBlock__ = block if block
  nil
end

#touchesArray

Returns array of touches

Returns:

  • (Array)

    Touch objects

See Also:



784
785
786
# File 'lib/processing/context.rb', line 784

def touches()
  @touches__
end

#touchMoved(&block) ⇒ nil

Defines touchMoved block.

Returns:

  • (nil)

    nil

See Also:



372
373
374
375
# File 'lib/processing/context.rb', line 372

def touchMoved(&block)
  @touchMovedBlock__ = block if block
  nil
end

#touchStarted(&block) ⇒ nil

Defines touchStarted block.

Returns:

  • (nil)

    nil

See Also:



350
351
352
353
# File 'lib/processing/context.rb', line 350

def touchStarted(&block)
  @touchStartedBlock__ = block if block
  nil
end

#windowHeightNumeric

Returns the height of the window.

Returns:

  • (Numeric)

    window height

See Also:



632
633
634
# File 'lib/processing/context.rb', line 632

def windowHeight()
  @window__.height
end

#windowMove(x, y) ⇒ nil

Move the position of the window.

Parameters:

  • x (Numeric)

    x position of the window

  • y (Numeric)

    y position of the window

Returns:

  • (nil)

    nil

See Also:



558
559
560
561
# File 'lib/processing/context.rb', line 558

def windowMove(x, y)
  @window__.pos = [x, y]
  nil
end

#windowMoved(&block) ⇒ nil

Defines windowMoved block.

Returns:

  • (nil)

    nil

See Also:



383
384
385
386
# File 'lib/processing/context.rb', line 383

def windowMoved(&block)
  @windowMovedBlock__ = block if block
  nil
end

#windowOrientation(*orientations) ⇒ nil

Sets window orientation mask

Parameters:

Returns:

  • (nil)

    nil



596
597
598
# File 'lib/processing/context.rb', line 596

def windowOrientation(*orientations)
  @window__.orientations = orientations.flatten.uniq
end

#windowResizable(resizable) ⇒ nil

Makes the window resizable or not.

Parameters:

  • resizable (Boolean)

    resizable or not

Returns:

  • (nil)

    nil

See Also:



585
586
587
588
# File 'lib/processing/context.rb', line 585

def windowResizable(resizable)
  @window__.resizable = resizable
  nil
end

#windowResize(width, height) ⇒ nil

Sets the size of the window.

Parameters:

  • width (Numeric)

    width of the window

  • height (Numeric)

    height of the window

Returns:

  • (nil)

    nil

See Also:



572
573
574
575
# File 'lib/processing/context.rb', line 572

def windowResize(width, height)
  @window__.size = [width, height]
  nil
end

#windowResized(&block) ⇒ nil

Defines windowResized block.



395
396
397
398
# File 'lib/processing/context.rb', line 395

def windowResized(&block)
  @windowResizedBlock__ = block if block
  nil
end

#windowWidthNumeric

Returns the width of the window.

Returns:

  • (Numeric)

    window width

See Also:



622
623
624
# File 'lib/processing/context.rb', line 622

def windowWidth()
  @window__.width
end

#windowXNumeric

Returns the x position of the window.

Returns:

  • (Numeric)

    horizontal position of the window



604
605
606
# File 'lib/processing/context.rb', line 604

def windowX()
  @window__.x
end

#windowYNumeric

Returns the y position of the window.

Returns:

  • (Numeric)

    vertical position of the window



612
613
614
# File 'lib/processing/context.rb', line 612

def windowY()
  @window__.y
end