npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

aframe-proxy-controls

v0.6.0

Published

A-Frame component to proxy keyboard/gamepad controls between devices over WebRTC.

Downloads

2

Readme

A-Frame proxy-controls Component

A-Frame component to proxy keyboard/gamepad controls between devices over WebRTC.

Overview

With a mobile device / Google Cardboard for WebVR, designing the UI around a single button is an obstacle. This component provides an experimental way to proxy user input events (keyboard, perhaps Leap Motion later) from a keyboard-connected device to the mobile viewer.

For performance, WebRTC DataStreams are used to minimize latency between the devices. Browser support for this standard is limited - notably, Safari (including all iPhone browsers) does not support it. I will consider adding fallback support via WebSockets in the future, if the latency is bearable.

Usage

Add the proxy-controls component to the scene, and use one of the input controller components on the object(s) you want to control. For example:

<a-scene proxy-controls>
  <a-entity id="player" gamepad-controls="controller: 2"></a-entity>
</a-scene>

The gamepad-controls component is available separately, here.

Options

Options are assigned with A-Frame's entity/component/property pattern:

<a-scene camera proxy-controls="enabled: true;
                                debug: true;
                                pairCode: 'my-secret-code';
                                enableOverlay: false;">

  <!-- scene content -->                                 
                                 
</a-scene>

Property | Default | Description --------------------|----------|------------- enabled | true | Enables/disables event updates from the host. debug | false | Enables/disables logging in the console. proxyUrl | https://proxy-controls.donmccurdy.com | URL of the remote proxy server / signaling server. pairCode | <random> | Pair code that should be used to match with the remote host. If not provided, a random pair code is assigned. enableOverlay | true | Enables/disables the overlay UI showing the pair code. enableOverlayStyles | true | Enables/disables the CSS used to style the pair code overlay.

Events

When the pair code is available, a proxycontrols.paircode event is fired. If you want to hide the default overlay, use this to show the pair code to the user as needed:

scene.addEventListener('proxycontrols.paircode', function (e) {
  console.log(e.detail.pairCode);
});