Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

wpe-uiframework

Package Overview
Dependencies
Maintainers
1
Versions
7
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

wpe-uiframework

[![npm version](https://badge.fury.io/js/wpe-uiframework.svg)](https://badge.fury.io/js/wpe-uiframework) [![npm](https://img.shields.io/npm/dt/wpe-uiframework.svg)]() [![Donate](https://img.shields.io/badge/Donate-PayPal-green.svg)](https://www.paypal.com

  • 0.0.9
  • latest
  • npm
  • Socket score

Version published
Maintainers
1
Created
Source

WPE UI Framework

npm version npm Donate

WPE UI Framework is a javascript 2d graphics rendering and animation library using (Web)GL. It's geared towards developing animated User Interfaces that run nicely on low-performance (embedded) devices. The framework has been optimized for high performance and low CPU/memory usage, and has been carefully tested for memory leaks.

The framework provides a rendering tree that can be modified using a very simple API. The rendering tree consists of components that have properties that define where and how it is rendered (x, y, rotation, alpha, etc). An image or rendered text can be attached to a component, which is then rendered immediately on the screen.

UI Framework runs in a any modern web browser using WebGL and in Node.js (version 4 or higher) on several targets including (desktop) Linux, OSX, Windows and the Raspberry PI.

Installation instructions

Browser

Include the script dist/wpe.js or dist/wpe.min.js. These files can be re-generated from source using the command:

grunt wpe-browser

Node.js:

For Node.js, this module depends on node-canvas for image loading and text creation, and node-wpe-webgl for providing a WebGL interface to the native hardware. Install the dependencies and follow the installation instructions of node-canvas (https://github.com/Automattic/node-canvas) and node-wpe-webgl (https://github.com/WebPlatformForEmbedded/node-wpe-webgl).

Tutorial

This section describes how to initialize and use the framework step-by-step.

Initialization

For a web browser:

var options = {w: 600, h: 600, glClearColor: 0xFF000000};
var stage = new Stage(options);

document.body.appendChild(stage.getCanvas());

This initializes a new stage. The stage creates a canvas of the specified width and height for drawing, and uses the specified background color (in ARGB hexadecimal format). You should then get it using stage.getCanvas() add it to the DOM tree. You can also supply your own canvas object by using the reuseCanvas option.

For Node.js:

var Stage = require('wpe-uiframework');

var options = {w: 600, h: 600, glClearColor: 0xFF000000, window: {title: "Example", fullscreen: false}};
var stage = new Stage(options);

This is similar as for the web browser, but node-wpe-webgl is used as OpenGL rendering target. This module allows some options for initialization that can be set in the window property. See https://github.com/WebPlatformForEmbedded/node-wpe-webgl#options.

Check the API for a list of all initialisation options.

Tree Definition

The stage.root property is the root of the rendering tree. You can add other new components to this tree to define what should be rendered within the stage. All of the nodes in the rendering tree are of the Component type, and based on their property settings they can be images, rectangles, texts or containers.

Example:

stage.root.add([
    {tag: 'bg', rect: true, x: 20, y: 20, w: 560, h: 560, colorTop: 0xFFFF0000, colorBottom: 0xFFFF6666, children: [
        {tag: 'hello', text: {text: "hello world", fontSize: 100}, x: 280, y: 170, mountX: 0.5, mountY: 0.5, alpha: 0.5},
        {tag: 'bunnies', x: 30, y: 30, w: 500, h: 500, clipping: true, borderWidth: 10, borderColor: 0xFF000000, children: [
            {src: basePath + 'bunny.png', x: 20, y: 400, scale: 8, rotation: 0.3},
            {src: basePath + 'bunny.png', x: 480, y: 400, scale: 8, rotation: -0.3}
        ]}
    ]}
]);

https://jsfiddle.net/basvanmeurs/4qy5j7am/

Check the API for a list of all component properties.

Dynamic Changes

You can dynamically change the rendering tree by accessing components using their tags:

// Get a single component by tag, and modify properties.
var bunniesCtr = stage.root.tag('bunnies');
bunniesCtr.borderWidth -= 5;

// You can access the component's children directly.
var bunnies = bunniesCtr.children;
bunnies.forEach(function(b) {
  // Set properties using a JSON object.
  b.set({alpha: 0.5, scale:8});

  // Add tag for later use.
  b.addTag('bunny');
});

// Use the just added tags, and clear the tags using a setting.
bunniesCtr.stag('bunny', {borderWidth: 1, tags: []});

// Because tags were just removed, this does nothing.
bunniesCtr.stag('bunny', {borderWidth: 0});

// Set by complex tag (set components tagged 'hello' that have an ancestor tagged 'bg').
stage.root.stag('bg.hello', {text: {text: "Hello World"}, alpha: 1});

https://jsfiddle.net/basvanmeurs/m2z8ctu7/

You can also create, add and remove components dynamically:

// Add new branch.
stage.root.tag('bunnies').add({tag: 'stuff', w: 400, h: 60, x: 50, y: 10, rect: true, color: 0xAAFFFFFF, borderWidth: 2, borderColor: 0xFF000000, children: [
	{src: basePath + 'bunny.png', x: 10, y: 30, mountY: 0.5},
  {text: {text: "this is a demo showing you how to define a branch of components via json and how to add that to the render branch.", fontSize: 12, lineHeight: 14, fontFace: ["Verdana", "Sans-Serif"], wordWrapWidth: 330}, x: 50, y:10, color: 0xFF000000}
]});

var c;
setTimeout(function() {
  // Remove the bunny.
  c = stage.root.tag('stuff').children[0];
	stage.root.tag('stuff').removeChild(c);

  setTimeout(function() {
    // Re-add the bunny, this time to the stage root.
    stage.root.addChild(c);
  }, 1000);
}, 1000);

https://jsfiddle.net/basvanmeurs/r0hkamd7/

You can also hook into the frame loop event, which runs at 60fps:

stage.on('frameStart', function(dt) {
	stage.root.tag('left').scaleX += stage.dt * 10;
	stage.root.tag('right').rotation += stage.dt * 1;
	stage.root.tag('hello').x += 30 * stage.dt;
});

https://jsfiddle.net/basvanmeurs/c4f7kh70/

Transitions

In a UI, in most situations a gradual transition looks nicer than setting a property directly. That's why this framework provides transitions in a very simple API:

var t = stage.root.tag('bunnies').transition('rotation', {delay: 2, duration: 8, timingFunction: 'ease'});
t.on('finish', function() {
	stage.root.tag('bunnies').x = 400;
});
stage.root.tag('bunnies').transition('x', {delay: 2, duration: 5, timingFunction: 'linear'});
stage.root.tag('bunnies').rotation = 2 * Math.PI * 8;

Check the API for a list of all transition properties and events.

https://jsfiddle.net/basvanmeurs/3eakcyrh/

You can remove a previously set transition like this:

setTimeout(function() {
  stage.root.tag('bunnies').transition('rotation', null);
}, 3000);

https://jsfiddle.net/basvanmeurs/4sukLurc/

Every property of the Component type that can be used in a transition has a 'normal' value and a final value, which is represented by the upper case property name. So, for example, the property component.rotation has a final equivalent component.ROTATION. If no transition is active, setting component.rotation automatically also sets component.ROTATION. If a transition is active, it will change the component.ROTATION property every frame. The component.ROTATION property is the one that's actually being used when rendering the tree. It is good to know about this distinction, because sometimes you may wish to adjust something in the rendering tree based on the final value rather than the normal value, as in the following example, in which the text is kept aligned with the container box:

var t = stage.root.tag('box').transition('x', {delay: 0.5, duration: 2, timingFunction: 'ease'});
stage.root.tag('box').x = -300;
t.on('progress', function(p) {
  var x = stage.root.tag('box').X;
  if (x < 0) {
     stage.root.tag('hello').x = Math.min(150, 10 - x);
  } else {
     stage.root.tag('hello').x = 10;
  }
});

t.on('finish', function() {
  stage.root.tag('box').x = Math.random() * 1000 - 500;
});

https://jsfiddle.net/basvanmeurs/4sukLurc/

Sometimes you may want to fast-forward a transition. You can do this using the Component.fastForward method:

setTimeout(function() {
  // If you set the final property value and then the property value to the same value,
  // the transition will automatically skip to the end.
  stage.root.tag('bunnies').fastForward('rotation');
}, 3000);

Notice that, when fast-forwarding, the finish event is emitted, whereas when removing the transition it is not.

https://jsfiddle.net/basvanmeurs/2cttjrhw/

Check the API for a list of all transition methods, properties and events.

Animations

WPE UI Framework provides a standardized way of specifying and using animations. Animations are a collection of actions (property settings) that take place at the particular point in time. An animation has a subject Component, on which (or one of its descendants) the actions are applied.

The following example shows how to define and start a complex animation:

var a = stage.root.tag('notification-ctr').animation({duration: 1, actions: [
  {t: '', p: 'visible', v: true, rv: false},
  {t: 'notification', p: 'x', v: {0: 600, 0.6: 200}},
  {t: 'notification', p: 'h', v: {0.6: 50, 1: 190}},
  {t: 'bg-overlay', p: 'alpha', v: {0: 0, 0.5: 1}}
]});

a.start();

https://jsfiddle.net/basvanmeurs/56dpqoks/

In the actions property, you can define the things that should happen during the animation. All component properties can be used, as well as all text properties (defined as "text.fontSize", etc) and texture clipping properties ("texture.x").

The values that are numeric are by default 'smoothened' using cubic bezier splines. If you'd prefer to have linear actions, you can do that as follows:

var a = stage.root.tag('notification-ctr').animation({duration: 1, actions: [
  {t: '', p: 'visible', v: true, rv: false},
  {t: 'notification', p: 'x', v: {0: {v:600,sm:0}, 0.6: {v:200,sm:0}}},
  {t: 'notification', p: 'h', v: {0.6: {v:50,sm:0}, 1: {v:190,sm:0}}},
  {t: 'bg-overlay', p: 'alpha', v: {0: {v:0,sm:0}, 0.5: {v:1,sm:0}}}
]});

https://jsfiddle.net/basvanmeurs/bhdstyem/

Notice that the values are now encapsulated in objects with the v property. The sm value defines the smoothness around that point. By setting it to 0 the value transition becomes linear, while 1 it gets smoothened a lot. Check the API for other options on how to tune the auto smoothness.

You can also provide your own value function, which takes the (spline) progress from 0 to 1 and returns the value to be set to the property.

Stopping animations

After an animation has finished, the finally set property values will remain until you manually change them. Alternatively, you can stop an animation, which resets the values to some specified state. Usually, it just sets them to the values specified as defined in the action value property at the animation start. Example:

setTimeout(function() {
  a.stop();
}, 5000)

https://jsfiddle.net/basvanmeurs/mh50egcx/

As you can see, the default is to 'fade' the animation settings back to the original values gradually within one second. You affect this transition by setting the stopMethodOptions. Some other stop methods:

NameExample
reversehttps://jsfiddle.net/basvanmeurs/q4om4fje/
immediatehttps://jsfiddle.net/basvanmeurs/2oco85qk/
onetotwohttps://jsfiddle.net/basvanmeurs/e0yp6a18/
forwardThis continues the animation until it is finished.

Check the API for a list of all animation methods, properties and events.

Development Tools

There is a handy tool available for inspection of rendered compontents. It keeps a 'real' HTML DOM rendering tree syncronized with the WPE UI Framework rendering tree, so that you are able to use the browser's web inspector to check on the layout of your rendering tree. You can even change the properties on the fly and see the result reflected in your stage!

To use it, include the script browser/inspect.js script after the wpe.js source file.

As an example, open the following jsfiddle and try the inspector on the graphics output:

https://jsfiddle.net/basvanmeurs/pybm5r9b/

Other helpful commands are the component.getLocationString() and component.toString() methods. They provide information about the tree location and the component branch.

Cleaning Up

When you want to gracefully stop your Node.js application (or want to completely remove the stage from your webpage), you must call stage.destroy(). This will make sure that all resources are freed, and will stop the render loop, allowing Node.js to quit.

API

Stage

Initialisation options

Usage: new Stage({w: 600, h: 600, ...}).

NameDefault valueDescription
w1280Stage width in px.
h720Stage height in px
reuseCanvasnullCanvas object to use instead of creating a new one (browser only).
rw1280The px which corresponds the right edge of the stage.
rh720The px which corresponds the bottom edge of the stage.
textureMemory12e6The amount of squared pixels that may be stored in GPU memory for texture storage / caching.
glClearColor0xFF000000The background color (ARGB).
defaultFontFaceArialThe font face to use for rendering if none is explicitly specified.
fixedDt0If specified, the ms to progress in each is fixed instead of dynamic.
windowSpecific node-wpe-webgl options, see https://github.com/WebPlatformForEmbedded/node-wpe-webgl#options.
useTextureAtlastrueThis allocates a 2048x2048px texture to which small textures that are currently visible are being cached. This makes rendering a lot faster but takes memory.

Methods

MethodDescription
destroy()Destroys this stage and release all resources. It is no longer usable after calling this method.
setGlClearColor(color:Integer)Sets the background color (example: 0xFF000000).
getCanvas() : HTMLCanvasElementReturns the canvas.
stop()Temporarily stops the stage rendering loop.
resume()Resumes the stage rendering loop.
`texture(source:StringTextureSource
component(settings:Object):ComponentCreates an returns a new component object.
c(settings:Object):ComponentSee component().
animation(settings:Object):AnimationCreates and returns a new animation (without a subject).
a(settings:Object):AnimationSee animation().

Events

NameArgumentsDescription
frameStartEmitted on every frame.
updateEmitted on every frame, after applying transitions and animations.
frameEndEmitted on every frame, after rendering.

Component

Properties

NameDefault valueDescription
x, y0Relative offset to the parent component in px.
w, h0Width/height of the component in px (if applicable).
scale(X,Y)1Scales this component (and all descendants), relative to the pivot position.
rotation0Rotation around the pivot point in radian.s
pivot(X,Y)0.5Specifies the pivot point for scale and rotation (0 = left/top, 1 = bottom/right).
mount(X,Y)0Specifies the alignment for the x, y offset (0 = left/top, 1 = bottom/right).
alpha1Opacity of this component (and all descendants).
borderWidth(Top,Left,Right,Bottom)1Border width.
borderColor(Top,Left,Right,Bottom)0xFFFFFFFFBorder color (ARGB integer).
color(Top,Bottom)(Left,Right)0xFFFFFFFFColor/tinting/gradients of the drawn texture. Note: gradients do not work on textures that are being clipped due to technical limitations.
visibletrueToggles visibility for this component (and all descendants).
zIndex0Specifies drawing order (just as in HTML).
forceZIndexContextfalseCreates a z-index stacking context without changing the drawing order of this component itself.
clippingfalseDo not draw descendant component parts that are outside of this component (overflow:hidden).
rectfalseWhen set to true, this component becomes a colored rectangle.
srcnullThe image source URL (string). When set, this component will render the image; URL (Node.js / web) or file (Node.js).
textnullThe text settings. When set, this component will render the text as specified (an object with the options specified below).
texturenullThe texture that's being shown, or null if this component is only a container. When set (Texture object or null), this component will render the custom texture (see Stage.getTexture(..)). By setting it with a plain object with x,y,w,h properties, the current texture is kept but a specific area of the texture is selected for display.
tags[]The tags of this component. When get, you should never modify this array manually! When set, replaces the tags of this component. Can be both a string or an array of strings.
children[]The children of this component. When get, you should never modify this array manually! When set, replaces the children of this component.

All of these properties can be set directly (using component.pivotX = 0.5) or via the set or stag method: component.set({pivotX: 0.5}).

Text sub object properties:

NameDefault valueDescription
text""The text to be shown.
fontSize40Text font size, in px.
fontFace"Arial"the font face (as used in CSS); may be an array to use (multiple) fallbacks. If nothing is specified, the defaultFontFace is used.
fontStyle"normal"Font-style property (https://developer.mozilla.org/en-US/docs/Web/CSS/font-style).
wordWraptrueShould words wrap be enabled?
wordWrapWidth0The word wrap max line width in px. If not set, w property is used.
lineHeightnullThe line height; if not set the font size is used.
textBaselinealphabetichttps://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/textBaseline
textAlignleftText alignment: left, center or right.
textAlignleftText alignment: left, center or right.
offsetY0Additional offset to start drawing text from the top.
maxLines0Limits the number of lines to be drawn.
maxLinesSuffix".."If there were more text lines that have been drawn, append this to the final line.
textColor0xFFFFFFFFNormally, you will use the color property of the component to specify the color. But when using highlighting or text shadows, this will also affect those. You will then have to set this text drawing color.
padding(Left,Right)0Additional padding on the sides of the text.
shadowfalseEnable text shadows.
shadowColor0xFF000000https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/shadowColor
shadowOffset(X,Y)0https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/shadowOffsetX
shadowBlur5https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/shadowBlur

Methods

MethodDescription
`add(children:mixed):Componentnull`
addChild(child:Component)Appends a single component to the children.
addChildAt(child:Component,index:Integer)Appends a single component at the specified position in the children array.
removeChild(child:Component)Removes the specified child component.
removeChildAt(index:Integer):ComponentRemoves the child at the specified index.
removeChildren()Removes the specified child components.
addChildren(children:Component[])appends multiple components to the children.
setChildren(children:Component[])Replaces the current children with the array of components.
getChildIndex(child:Component):IntegerReturns the child index of the specified component (-1 if not a child of this component).
getDepth():IntegerReturns the tree depth (root = 0).
getAncestor(level:Integer):ComponentReturns the ancestor, l levels above this one (if l too high, root is returned).
getAncestorAtDepth(depth:Integer):ComponentReturns the ancestor at the specified depth of the tree.
isAncestorOf(child:Component):Boolean Returns true iff this component is an ancestor of the specified component.
getSharedAncestor(other:Component):ComponentReturns the shared ancestor between this and the specified component (null if not in the same tree).
isAttached():BooleanReturns true iff this component is attached to the stage rendering tree.
isActive():BooleanReturns true iff this component is attached to the stage rendering tree and is visible.
textureIsLoaded():BooleanReturns true iff this.texture has already been loaded.
animation(settings:Object):TimedAnimationCreates and returns an animation that has this component as subject.
a(settings:Object):TimedAnimationSee animation().
transition(property:String,settings:Object):TransitionIf settings is a plain object,it enables the transition on the specified property. If settings is null, it removes the animation on the specified property. The following properties can be transitioned: x y w h scale(X,Y) pivot(X,Y) mount(X,Y) alpha rotation borderWidth(Top,Bottom,Left,Right) borderColor(Top,Bottom,Left,Right) color(Top,Bottom)(Left,Right)
t(property:String,settings:Object):TransitionSee transition().
fastForward(property:String)Fast-forwards a currently running transition.
getRenderWidth():NumberReturns the render width of this component (either the set w property, or the width of the texture actually being shown).
getRenderHeight():NumberReturns the render height of this component.
getCornerPoints():Number[]Returns the [x1,y1,x2,y2,x3,y3,x4,y4] coordinates of the component's corner points in canvas coordinates.
getLocationString():StringReturns a nicely formatted string describing the tree location of this component.
getTags():String[]Returns an array with the component tags.
setTags(tags:String[])Replace the current tags by the specified tags.
addTag(tag:String)Adds the specified tag.
removeTag(tag:String)Removes the specified tag.
hasTag(tag:String):BooleanReturns true iff this component has the specified tag.
tag(tag:String):ComponentReturns the (single) component with the specified tag within this branch, or null if none found.
mtag(tag:String):ComponentReturns all of the components with the specified tag within this branch.
stag(tag:String,settings:Object)Combination of mtag and set in one method call.
set(settings:Object)Sets the specified properties.
toString():StringReturns a JSON-formatted string describing this branch.
getSettingsObject():ObjectReturns a JSON object describing this component's branch. It can be imported using the add method.

Events

NameArgumentsDescription
txLoadtextureSourcethis.texture has been loaded.
txErrorerror, textureSourceError while trying to load this.texture.

Transition

Properties

NameDefault valueDescription
delay0Delay in s before starting the transition after updating the value.
duration1Defines how long the transition takes from start to finish.
timingFunction"ease"The timing function. Options: linear ease ease-in ease-out ease-in-out step-start step-end cubic-bezier(n,n,n,n)

Events

NameArgumentsDescription
startEmitted when a transition starts.
delayEndEmitted when the delay ends.
progressp (value between 0 and 1)Emitted on every transition step.
finishEmitted when the transition finishes.

Animation

Methods

MethodDescription
start()Restarts the animation.
play()If not already running (or finished), starts the animation. If stopping in 'reverse' mode, go into playing mode
replay()Like play(), but restart if finished.
fastForward()If playing, goes to the finish state. If stopping, goes to the stopped state.
isPlaying():BooleanReturns true iff this animation is currently playing.
skipDelay()Skip delay if currently waiting for it.
stop()Stop the current animation.
stopNow()Stop the current animation immediately.

Properties

NameDefault valueDescription
subjectnullThe component that is the subject of this animation.
delay0Delay in s before actually starting the animation after starting it.
duration1Defines how long the animation takes from start to finish.
repeat0How many times the animation should be repeated before finishing (-1 = repeat forever).
autostopfalseStop automatically after the animation finishes.
stopMethodfadeThe way to stop the animation. Options: fade immediate reverse forward onetotwo. Forward means: continue until repeat finishes and then stop. Onetotwo means: keep progressing until progress reaches 2 (value definition goes up to 2).
stopMethodOptions{}Additional options for the stop method. Properties: duration, delay, timingFunction
actions[]The actions to be applied. See below.

Action sub object properties

NameDefault valueDescription
t[""]Tags to apply (see Component.mtag()). Either a string or an array of strings. Additionally, the empty string defines the subject component itself.
p[]Properties to set. Either a string or an array of strings.
v{}Result value. Can be set as a value function (p:Number -> mixed), or an object with value items, indexed by progress values (see below).
rvnullResult value. If not set, the value at p=0 is used.

Action value item sub object properties

NameDefault valueDescription
vEither a value function (p:Number -> mixed) or an actual value to be set to the property.
p0Start at animation progress (0 = 0%, 1 = 100%).
peEnd at animation progress (0 = 0%, 1 = 100%) (by default, the next point's p value is used).
sm0.5Auto-smoothness smoothness around the point. 0 = linear, 1 = smooth. Note: when using sm=1 artifacts may appear, so use up to 0.9 to stay safe or try it.
sAuto-smoothness slope around the point (0 = horizontal, 1 = diagonal up, -1 = diagonal down).
smeEnd of spline auto-smoothness smoothness around the point (by default, the next point's smoothness is used).
seEnd of spline auto-smoothness slope around the point (by default, the next point's slope is used).
veThe end of spline auto-smoothness value (by default, the next point's start value is used).

Events

NameArgumentsDescription
startEmitted when the animation starts.
delayEndEmitted when the delay ends.
progressp (value between 0 and 1)Emitted on every animation step.
repeatrepeatsLeftEmitted when a repeat is started.
finishEmitted when the animation finishes.
stopEmitted when the animation is starting to stop.
stopFinishEmitted when the animation finishes stopping.
stopDelayEndEmitted when the stop delay ends.
stopContinueEmitted when an animation is started while it was stopping.
finishEmitted when the animation finishes.

FAQs

Package last updated on 12 Apr 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc