melonJS
    Preparing search index...

    Class Camera3d

    A perspective camera that extends Camera2d with a view Frustum (fov / aspect / near / far) and orientation (pitch / yaw / roll). Slots into Stage.cameras as a drop-in replacement for Camera2d — inherits the post-effect FBO bracket, color-matrix, fade / shake / follow plumbing, and screen viewport.

    WebGL required. Camera3d's perspective projection, depth-buffer painter sort and mesh draw path all live in the WebGL renderer; the Canvas backend has none of these and would render a stuck blank scene. Construct the Application with renderer: video.WEBGL to get a hard throw at construction time if WebGL is unavailable. Pairing cameraClass: Camera3d with video.AUTO will emit a console.warn at construction (and silently misrender) when AUTO falls back to Canvas — see ApplicationSettings.renderer for the contract.

    Conventions:

    • Y-down + +Z forward. Sprite at higher pos.y appears lower on screen (same as Camera2d). Sprite at higher pos.z is farther from the camera and renders smaller. Matches melonJS's 2D conventions so existing Camera2d code translates directly.
    • Rotations are extrinsic XYZ. pitch (X axis, look up/down), yaw (Y axis, look left/right), roll (Z axis, screen-plane bank — also exposed as Camera2d.rotation via Renderable inheritance for backward compatibility).
    • Follow offset (PR B scope). When a target is set, followOffset is applied in world space: camera.pos = target.pos + followOffset. Target-rotation-aware follow (Cinemachine / Unreal spring-arm style, where the offset rotates with the target's orientation) is deferred until a showcase needs it (e.g. AfterBurner's banking jet).

    Known limitations (PR B scope):

    • Light2d is 2D-only — visible artifacts under perspective. Avoid combining with Camera3d for now.
    • localToWorld / worldToLocal overrides fall back to the ortho-equivalent 2D projection at z=0. Full 3D unproject for arbitrary depth is future work.
    // opt in app-wide:
    const app = new Application(1024, 768, {
    parent: "screen",
    cameraClass: Camera3d,
    });

    // or per-stage with custom fov:
    class GameStage extends Stage {
    constructor() {
    super({
    cameras: [new Camera3d(0, 0, 1024, 768, { fov: Math.PI / 3 })],
    });
    }
    }

    Hierarchy (View Summary)

    Index

    Constructors

    • Parameters

      • minX: number

        start x offset

      • minY: number

        start y offset

      • maxX: number

        end x offset

      • maxY: number

        end y offset

      • Optionalopts: FrustumOptions

        perspective parameters (see FrustumOptions)

      Returns Camera3d

    Properties

    alpha: number

    Define the renderable opacity
    Set to zero if you do not wish an object to be drawn

    • Renderable#setOpacity
    • Renderable#getOpacity
    1.0
    
    alwaysUpdate: boolean

    Whether the renderable object will always update, even when outside of the viewport

    false
    
    ancestor: Container | Entity

    a reference to the parent object that contains this renderable

    undefined
    
    anchorPoint: ObservablePoint

    The anchor point is used for attachment behavior, and/or when applying transformations.
    The coordinate system places the origin at the top left corner of the frame (0, 0) and (1, 1) means the bottom-right corner

    a Renderable's anchor point defaults to (0.5,0.5), which corresponds to the center position.

    Note: Object created through Tiled will have their anchorPoint set to (0, 0) to match Tiled Level editor implementation. To specify a value through Tiled, use a json expression like json:{"x":0.5,"y":0.5}.

    <0.5,0.5>
    
    autoResize: boolean

    Whether this camera should automatically resize when the canvas resizes. Set to false for non-default cameras with fixed dimensions (e.g. minimap, split-screen viewports).

    true
    
    autoTransform: boolean

    When enabled, an object container will automatically apply any defined transformation before calling the child draw method.

    true
    
    // enable "automatic" transformation when the object is activated
    onActivateEvent: function () {
    // reset the transformation matrix
    this.currentTransform.identity();
    // ensure the anchor point is the renderable center
    this.anchorPoint.set(0.5, 0.5);
    // enable auto transform
    this.autoTransform = true;
    ....
    }
    AXIS: AxisEnum

    Axis definition NONE no axis HORIZONTAL horizontal axis only VERTICAL vertical axis only BOTH both axis

    blendMode: string

    the blend mode to be applied to this renderable (see renderer setBlendMode for available blend mode)

    "normal"
    
    • CanvasRenderer#setBlendMode
    • WebGLRenderer#setBlendMode
    body: PhysicsBody

    the renderable physics body — the handle returned by the active PhysicsAdapter's addBody (or constructed imperatively via new Body(...)). Typed as the portable PhysicsBody interface; cast to the adapter-specific concrete type (MatterAdapter.Body, BuiltinAdapter.Body, or the legacy Body class) to reach native fields.

    // define a new Player Class
    class PlayerEntity extends me.Sprite {
    // constructor
    constructor(x, y, settings) {
    // call the parent constructor
    super(x, y , settings);

    // define a basic walking animation
    this.addAnimation("walk", [...]);
    // define a standing animation (using the first frame)
    this.addAnimation("stand", [...]);
    // set the standing animation as default
    this.setCurrentAnimation("stand");

    // add a physic body
    this.body = new me.Body(this);
    // add a default collision shape
    this.body.addShape(new me.Rect(0, 0, this.width, this.height));
    // configure max speed, friction, and initial force to be applied
    this.body.setMaxVelocity(3, 15);
    this.body.setFriction(0.4, 0);
    this.body.force.set(3, 0);
    this.isKinematic = false;

    // set the display to follow our position on both axis
    app.viewport.follow(this.pos, app.viewport.AXIS.BOTH);
    }

    ...

    }
    bodyDef: object | undefined

    Declarative body definition consumed by the active PhysicsAdapter when this renderable is added to a container. Adapter API only — leave undefined if you build a body imperatively via this.body = new Body(...).

    When set, the parent container forwards it to world.adapter.addBody(this, this.bodyDef), which constructs the underlying physics body (matter, builtin SAT, …) and assigns the engine-portable wrapper to this.body. This is the engine-portable path: the same bodyDef produces an equivalent body under any adapter.

    Typical fields: type ("static"/"dynamic"/"kinematic"), shapes, collisionType, collisionMask, restitution, frictionAir, density, gravityScale, isSensor, maxVelocity, fixedRotation. See BodyDefinition.

    undefined
    
    bounds: Bounds

    Camera bounds

    cameraEffects: CameraEffect[]

    active camera effects (shake, fade, etc.)

    colorMatrix: ColorMatrix

    A built-in color transformation matrix applied as the final post-processing pass. Provides convenient color grading (brightness, contrast, saturation, etc.) that is always applied after any effects added via addPostEffect. When set to identity (default), no effect is applied and there is zero overhead.

    // warm HDR-like color grading
    camera.colorMatrix.contrast(1.2).saturate(1.1);
    // reset to no color grading
    camera.colorMatrix.identity();
    currentTransform: Matrix3d

    the renderable transformation matrix (4x4). For standard 2D use, only the 2D components are used (rotate around Z, scale X/Y, translate X/Y). For 3D use (e.g. Mesh), the full 4x4 matrix supports rotation around any axis, 3D translation, and perspective projection. Use the rotate(), scale(), and translate() methods rather than modifying this directly.

    damping: number

    Camera damping for smooth follow [0 .. 1]. 1 snaps the camera to the target every frame (no smoothing); lower values produce a trailing follow — 0.1 is a soft springy follow, 0.5 is snappy.

    Frame-rate independent (since 19.7 / #1478). The value is the fraction of the gap covered per frame at the engine's target framerate (timer.maxfps, default 60). The underlying implementation switched from pos.lerp to pos.damp with lambda = -ln(1 - damping) * timer.maxfps, so the legacy per-frame fraction is recovered exactly at the target rate AND the wall-clock convergence stays constant when the actual frame rate drifts (slow machine, throttled tab, high-refresh display). Existing damping tuning carries over with no changes.

    1.0
    
    deadzone: Rect

    the camera deadzone

    edges: Vector2d[]

    The edges here are the direction of the nth edge of the polygon, relative to the nth point. If you want to draw a given edge from the edge value, you must first translate to the position of the starting point.

    far: number

    the furthest point relative to the camera. Widened from 1000 in 19.7 — see Camera2d#near.

    1e6
    
    floating: boolean

    If true, this renderable will be rendered using screen coordinates, as opposed to world coordinates. Use this, for example, to define UI elements.

    false
    
    follow_axis: number

    default value follow

    followOffset: Vector3d

    World-space offset from the followed target. When target is set via Camera2d#follow, the camera position resolves to target.pos + followOffset. Common usage: (0, -2, -8) for a behind-and-above third-person view.

    Treated as world-space in this release — target-rotation-aware follow (where the offset rotates with the target's orientation, Cinemachine / Unreal spring-arm style) is deferred until a showcase needs it (e.g. AfterBurner's banking jet).

    (0, 0, 0)
    
    frustum: Frustum

    the view frustum (perspective parameters + projection matrix). Mutating frustum.fov / aspect / near / far directly requires calling frustum.update() to rebuild the matrix; the proxy setters on this camera (camera.fov = ...) handle that automatically.

    GUID: string

    (G)ame (U)nique (Id)entifier"
    a GUID will be allocated for any renderable object added
    to an object container (including the app.world container)

    indices: number[]

    a list of indices for all vertices composing this polygon

    isDirty: boolean

    when true the renderable will be redrawn during the next update cycle

    true
    
    isKinematic: boolean

    If true then physic collision and input events will not impact this renderable

    true
    
    isPersistent: boolean

    make the renderable object persistent over level changes

    false
    
    lookAhead: Vector3d

    Reserved for future follow-look-ahead support — currently unused by updateTarget. The intent is: when wired in, the camera will look at target.pos + lookAhead instead of target.pos, so a follow-cam stays slightly ahead of its target (e.g. for a cinematic forward-looking shot in AfterBurner). Field is exposed now so user code can set it without waiting for the wiring.

    (0, 0, 1)
    

    A mask limits rendering elements to the shape and position of the given mask object. So, if the renderable is larger than the mask, only the intersecting part of the renderable will be visible.

    undefined
    
    // apply a mask in the shape of a Star
    myNPCSprite.mask = new me.Polygon(myNPCSprite.width / 2, 0, [
    // draw a star
    {x: 0, y: 0},
    {x: 14, y: 30},
    {x: 47, y: 35},
    {x: 23, y: 57},
    {x: 44, y: 90},
    {x: 0, y: 62},
    {x: -44, y: 90},
    {x: -23, y: 57},
    {x: -47, y: 35},
    {x: -14, y: 30}
    ]);
    name: string

    The name of the renderable

    ""
    
    near: number

    the closest point relative to the camera. Widened from -1000 in 19.7 to accommodate sprites at large depth values now that aVertex.z participates in clip-space (PR A): the default Container.autoDepth = true assigns pos.z = childCount so any container with >1000 children would otherwise clip-cull, and the common Y-sort pattern sprite.depth = sprite.pos.y exceeds 1000 on tall maps. Override per-camera if you need tighter z clipping.

    -1e6
    
    offset: Vector2d

    offset for shake effect

    onVisibilityChange: Function

    an event handler that is called when the renderable leave or enter a camera viewport

    undefined
    
    this.onVisibilityChange = function(inViewport) {
    if (inViewport === true) {
    console.log("object has entered the in a camera viewport!");
    }
    };
    pitch: number

    X-axis rotation in radians (look up/down). Positive values pitch the camera up.

    0
    
    points: Vector2d[]

    Array of points defining the Polygon
    Note: If you manually change points, you must call recalcafterwards so that the changes get applied correctly.

    origin point of the Polygon

    postEffects: any[]

    the list of post-processing shader effects applied to this renderable (WebGL only). Effects are applied in order. Use addPostEffect, getPostEffect, and removePostEffect to manage effects, or assign directly. In Canvas mode, this property is ignored.

    []
    
    // add effects via helper methods
    mySprite.addPostEffect(new DesaturateEffect(renderer));
    mySprite.addPostEffect(new VignetteEffect(renderer));
    // assign directly
    mySprite.postEffects = [new SepiaEffect(renderer), new VignetteEffect(renderer)];
    projectionMatrix: Matrix3d

    the default camera projection matrix (2d cameras use an orthographic projection by default).

    screenProjection: Matrix3d

    the screen-space projection matrix for non-default cameras. Maps coordinates so that (0,0) aligns with the camera's screenX/screenY position. Used for rendering floating elements (e.g. background layers) in the correct screen area.

    screenX: number

    the x position on the screen where this camera viewport is rendered.

    0
    
    screenY: number

    the y position on the screen where this camera viewport is rendered.

    0
    
    smoothFollow: boolean

    enable or disable damping

    true
    
    target: Vector2d | Vector3d | null

    target to follow

    type: string = "Rectangle"

    The shape type (used internally).

    updateWhenPaused: boolean

    Whether to update this object when the game is paused.

    false
    
    visibleInAllCameras: boolean

    If true, this floating renderable will be rendered by all cameras (e.g. background image layers). If false (default), floating elements are only rendered by the default camera (e.g. UI/HUD elements). Only applies to floating renderables in multi-camera setups.

    false
    
    worldProjection: Matrix3d

    the world-space projection matrix for non-default cameras (offset/zoomed). Maps world coordinates to the camera's screen viewport.

    yaw: number

    Y-axis rotation in radians (look left/right). Positive values yaw the camera to the right.

    0
    
    defaultSortOn: "depth" | "x" | "y" | "z" = "depth"

    Override Camera2d.defaultSortOn to declare "depth" as this camera's preferred sort mode. Application / Stage apply this to world.sortOn at bootstrap, so games opting into Camera3d via cameraClass: Camera3d get camera-distance painter's sort for free — the only correct sort for alpha-blended sprites under perspective.

    Accessors

    • get isDefault(): boolean

      Whether this camera is using default settings (no screen offset, no zoom). Non-default cameras use custom projections for viewport positioning and scaling.

      Returns boolean

      true if this camera has no screen offset and zoom is 1

    • get isFloating(): boolean

      Whether the renderable object is floating (i.e. used screen coordinates), or contained in a floating parent container

      Returns boolean

      Renderable#floating

    • get zoom(): number

      the zoom level of this camera. Values less than 1 zoom out (show more of the world), values greater than 1 zoom in (show less of the world).

      Returns number

      1
      
      // zoom out to show the full level in a 180x100 minimap
      camera.zoom = Math.min(180 / levelWidth, 100 / levelHeight);
    • set zoom(value: number): void

      Parameters

      • value: number

      Returns void

    Methods

    • Returns true if the polygon contains the given point.
      (Note: it is highly recommended to first do a hit test on the corresponding
      bounding rect, as the function can be highly consuming with complex shapes)

      Parameters

      • x: number

        x coordinate or a vector point to check

      • y: number

        y coordinate

      Returns boolean

      True if the polygon contain the point, otherwise false

      if (polygon.contains(10, 10)) {
      // do something
      }
      // or
      if (polygon.contains(myVector2d)) {
      // do something
      }
    • Returns true if the polygon contains the given point.
      (Note: it is highly recommended to first do a hit test on the corresponding
      bounding rect, as the function can be highly consuming with complex shapes)

      Parameters

      Returns boolean

      True if the polygon contain the point, otherwise false

      if (polygon.contains(10, 10)) {
      // do something
      }
      // or
      if (polygon.contains(myVector2d)) {
      // do something
      }
    • fadeIn effect

      fade to the specified color

      Parameters

      • color: string | Color

        a CSS color value

      • Optionalduration: number = 1000

        expressed in milliseconds

      • OptionalonComplete: () => void

        callback once effect is over

      Returns void

      // flash the camera to white for 75ms
      app.viewport.fadeIn("#FFFFFF", 75);
    • fadeOut(flash) effect

      screen is filled with the specified color and slowly goes back to normal

      Parameters

      • color: string | Color

        a CSS color value

      • Optionalduration: number = 1000

        expressed in milliseconds

      • OptionalonComplete: () => void

        callback once effect is over

      Returns void

      // fade the camera to white upon dying, reload the level, and then fade out back
      app.viewport.fadeIn("#fff", 150, function() {
      me.audio.play("die", false);
      me.level.reload();
      app.viewport.fadeOut("#fff", 150);
      });
    • set the camera to follow the specified renderable.
      (this will put the camera center around the given target)

      Parameters

      Returns void

      // set the camera to follow this renderable on both axis, and enable damping
      app.viewport.follow(this, app.viewport.AXIS.BOTH, 0.1);
    • return the renderable absolute position in the game world. The returned vector is a Vector3d so the z component is summed across the ancestor chain too — important for Camera3d's frustum culling, which previously read obj.depth (local pos.z) and mis-culled children nested under a container with its own non-zero depth.

      Returns Vector3d

    • Get the first camera effect matching the given class.

      Type Parameters

      Parameters

      • effectClass: new (...args: any[]) => T

        the effect class to search for

      Returns T | undefined

      the first matching effect, or undefined

      const shake = camera.getCameraEffect(ShakeEffect);
      
    • Get post-processing shader effects. When called with a class, returns the first effect matching the given class. When called without arguments, returns the full effects array.

      Parameters

      • OptionaleffectClass: Function

        the effect class to search for

      Returns any

      the matching effect, the effects array, or undefined

      const desat = sprite.getPostEffect(DesaturateEffect);
      const allEffects = sprite.getPostEffect();
    • Returns true if the vertices composing this polygon form a convex shape (vertices must be in clockwise order).

      Returns boolean | null

      true if the vertices are convex, false if not, null if not computable

    • Visibility check used by Container.update (in turn driving Container.draw) to skip rendering off-screen children.

      Camera2d's implementation tests a 2D bounds-rectangle overlap against this.worldView — that test is invalid under perspective: the visible region is a frustum that widens with distance and rotates with the camera's pitch / yaw, not a fixed axis-aligned rect at the camera's x / y. Camera3d substitutes plane-based frustum culling — each non-floating renderable's bounding sphere is tested against the six frustum planes that were extracted in the most recent update() call. Floating elements (HUD / UI) still use Camera2d's 2D rect test because their bounds are screen-space and the perspective transform doesn't apply to them.

      Parameters

      • obj: Renderable

        the renderable to test

      • Optionalfloating: boolean = obj.floating

        test against screen coordinates instead of frustum

      Returns boolean

      true if the renderable's bounds overlap the frustum

    • convert the given "local" (screen) coordinates into world coordinates

      Parameters

      • x: number

        the x coordinate of the local point to be converted

      • y: number

        the y coordinate of the local point to be converted

      • Optionalv: Vector2d

        an optional vector object where to set the converted value

      Returns Vector2d

      the converted world coordinates as a Vector2d

    • Point the camera at a world-space target by deriving pitch and yaw from the direction (target − camera.pos). Roll is unaffected.

      Three call shapes:

      • lookAt(x, y, z) — raw world coordinates
      • lookAt(vector3d) — a 3D point
      • lookAt(renderable) — uses renderable.pos (matches the Renderable.lookAt(target) signature so Camera3d is a structural drop-in replacement for Camera2d / Renderable in user code).

      Last-write-wins with manual pitch / yaw assignment: if you call lookAt(...) then set camera.pitch = 0.1 directly, the next frame renders with the manual pitch.

      Parameters

      • xOrTarget: number | { pos?: ObservableVector3d; x: number; y: number; z?: number }

        target world x, or a target with pos / x,y,z

      • Optionaly: number

        target world y (only when first arg is a number)

      • Optionalz: number

        target world z (only when first arg is a number)

      Returns this

      this camera

    • move the camera upper-left position by the specified offset.

      Parameters

      • x: number

        horizontal offset

      • y: number

        vertical offset

      Returns void

      // Move the camera up by four pixels
      app.viewport.move(0, -4);
    • Legacy collision callback — fires every frame this renderable body is overlapping another body. Kept for backward compatibility with code written against pre-19.5 melonJS; semantics are unchanged from the 19.4 contract.

      NOTE — onCollision is NOT equivalent to Renderable.onCollisionActive. The two handlers exist side by side and have intentionally different contracts:

      onCollision (legacy) onCollisionActive (modern)
      Cadence for dynamic-dynamic pairs 2× per frame per side 1× per frame per side
      response.a semantics Fixed per pair (first body in detector call) Always the receiver (response.a === this)
      response.b semantics Fixed per pair Always the partner (response.b === other)
      response.normal / response.depth ✓ — normal.y < -0.7 = "push me up"
      return false to skip push-out ✓ (honored by SAT) ✗ — use bodyDef.isSensor or setSensor instead

      If you're writing new code, prefer onCollisionActive. Keep onCollision only when its every-frame, return-false, fixed-a/b semantics are what you want.

      Parameters

      • _response: any
      • _other: any

      Returns boolean

      true if the object should respond to the collision (its position and velocity will be corrected); the return value is only honored by the builtin SAT adapter.

      // legacy collision handler — note the receiver-side check on response.a
      onCollision(response) {
      if (response.b.body.collisionType === me.collision.types.ENEMY_OBJECT) {
      this.pos.sub(response.overlapV);
      this.hurt();
      return false; // skip the SAT push-out
      }
      return true;
      }
    • OnDestroy Notification function
      Called by engine before deleting the object. Stage.destroy(app) forwards the active Application, so subclasses that wire teardown against the app object can override as onDestroyEvent(app).

      Parameters

      • ..._args: any[]

        forwarded by destroy(...args); Stage passes the Application instance

      Returns void

    • Bulk frustum cull via the world's Octree. Returns every renderable whose octant the current frustum overlaps — conservative (some renderables may still narrow-cull out via Camera3d#isVisible's per-sphere test) but O(visible + walk) instead of O(scene).

      Only applicable under cameraClass: Camera3d (or any setup where world.sortOn === "depth" and the broadphase is an Octree). Returns an empty array under a 2D broadphase — call sites can guard on the array length or branch on world.sortOn.

      For a 1000-renderable scene with ~50 visible, expect a 5-20× speedup over walking every renderable and per-item Camera3d#isVisible.

      Parameters

      • world: { broadphase: unknown; sortOn: string }

        the world to cull (its broadphase must be an Octree); typed structurally to sidestep the Camera3d → World import cycle

        • broadphase: unknown

          the world's spatial broadphase

        • sortOn: string

          guard: returns empty unless this equals "depth"

      • Optionalout: Renderable[]

        caller-supplied result array (re-entrancy-safe)

      Returns Renderable[]

      visible-renderable candidates

      const visible = camera.queryVisible(app.world);
      for (const r of visible) {
      // narrow-phase per-renderable visibility (sphere / OBB) if needed
      if (camera.isVisible(r)) r.draw(renderer);
      }
    • reset the camera position to specified coordinates

      Parameters

      • Optionalx: number = 0

        initial position of the camera on the x axis

      • Optionaly: number = 0

        initial position of the camera on the y axis

      Returns void

    • Rotate this renderable by the specified angle (in radians). When called with just an angle, rotates around the Z axis (2D rotation). When called with an angle and a Vector3d axis, rotates around that axis in 3D.

      Parameters

      • angle: number

        The angle to rotate (in radians)

      • Optionalv: any

        the axis to rotate around (defaults to Z axis for 2D)

      Returns Renderable

      Reference to this object for method chaining

    • scale the renderable around his anchor point. Scaling actually applies changes to the currentTransform member which is used by the renderer to scale the object when rendering. It does not scale the object itself. For example if the renderable is an image, the image.width and image.height properties are unaltered but the currentTransform member will be changed.

      Parameters

      • x: number

        a number representing the abscissa of the scaling vector.

      • Optionaly: number = x

        a number representing the ordinate of the scaling vector.

      • Optionalz: number = 1

        a number representing the depth of the scaling vector.

      Returns Renderable

      Reference to this object for method chaining

    • set the camera boundaries (set to the world limit by default). the camera is bound to the given coordinates and cannot move/be scrolled outside of it.

      Parameters

      • x: number

        world left limit

      • y: number

        world top limit

      • w: number

        world width limit

      • h: number

        world height limit

      Returns void

    • Update the perspective near/far clip distances and rebuild the projection matrix in one shot. Anything closer than near or farther than far is clipped by the GPU; projection math also degrades sharply just before far, so size the far plane to the deepest object in your scene with a little headroom. Defaults are near = 0.1, far = 1000 — typical AfterBurner-class scenes with enemies spawning at z = 3000+ need to push far out.

      This is the supported way to change near/far at runtime. The inherited Camera2d.near / .far are plain instance fields — direct assignment (camera.near = 5) updates the cached value but leaves the projection matrix stale until the next resize(). TypeScript's property-vs-accessor rule prevents shadowing the inherited fields with accessor pairs, so the convenience method is the public contract instead.

      Parameters

      • near: number

        near clip distance

      • far: number

        far clip distance

      Returns this

      this camera (chainable)

    • change the deadzone settings. the "deadzone" defines an area within the current camera in which the followed renderable can move without scrolling the camera.

      Parameters

      • w: number

        deadzone width

      • h: number

        deadzone height

      Returns void

      follow

    • Set the target-local follow offset. Called once when configuring a follow-cam (e.g. behind-and-above third person: setFollowOffset(0, -2, -8)).

      Parameters

      • x: number

        target-local x offset

      • y: number

        target-local y offset

      • z: number

        target-local z offset

      Returns this

      this camera

    • set new value to the Polygon

      Parameters

      • x: number

        position of the Polygon

      • y: number

        position of the Polygon

      • points: PolygonVertices | LineVertices

        array of vector or vertices defining the Polygon

      Returns Camera3d

      this instance for object chaining

    • Set the camera screen position and size in a single call.

      Parameters

      • x: number

        x position on screen

      • y: number

        y position on screen

      • Optionalw: number

        width (defaults to current width)

      • Optionalh: number

        height (defaults to current height)

      Returns this

      this camera for chaining

    • shake the camera

      Parameters

      • intensity: number

        maximum offset that the screen can be moved while shaking

      • duration: number

        expressed in milliseconds

      • Optionalaxis: number

        specify on which axis to apply the shake effect (see Camera2d.AXIS)

      • OptionalonComplete: () => void

        callback once shaking effect is over

      • Optionalforce: boolean

        if true this will override the current effect

      Returns void

      // shake it baby !
      app.viewport.shake(10, 500, app.viewport.AXIS.BOTH);
    • Shifts the Polygon to the given position vector.

      Parameters

      • x: number

        The x coordinate or a vector point to shift to.

      • Optionaly: number

        The y coordinate. This parameter is required if the first parameter is a number.

      Returns void

      polygon.shift(10, 10);
      // or
      polygon.shift(myVector2d);
    • Shifts the Polygon to the given position vector.

      Parameters

      Returns void

      polygon.shift(10, 10);
      // or
      polygon.shift(myVector2d);