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

@ekolabs/aframe-spritesheet-component

v1.2.0

Published

Animated spritesheet support for A-Frame

Downloads

120

Readme

A-Frame Spritesheet Component

Animated spritesheet support for A-Frame.

Demo / Using spritesheets

Spritesheets are a common way to play pre-rendered animation. This component allows you to load up a spritesheet image to an a-image element and easily control its animation. It allows usage of two types of spritesheet formats:

Rows and Cols

A grid representing all frames of the animation. All of the frames must be of the same dimensions, and the animation index is assumed to be scanned left to right, top to bottom. If your last frame is not the one on the bottom right, you'll have to specify the index of the last frame using the lastFrame property.

JSON data format

The spritesheet image file can be made more compact by using a dictionary automatically generated with TexturePacker. This will help reduce file size.

Browser

Install and use by directly including the browser files:

<head>
  <title>My A-Frame Scene</title>
  <script src="https://aframe.io/releases/0.5.0/aframe.min.js"></script>
  <script src="https://unpkg.com/aframe-spritesheet-component/dist/aframe-spritesheet-component.min.js"></script>
</head>

<body>
  <a-scene>
    <!-- rows/cols format-->
    <a-image src="spritesheet.png" sprite-sheet="cols:8; rows: 3; progress: 0;"></a-image>
    <!-- json format -->
    <a-image src="spritesheet.png" sprite-sheet="dataUrl: spritesheet.json; progress: 0;" ></a-image>
  </a-scene>
</body>

npm

Install via npm:

npm install aframe-spritesheet-component

Then require and use.

require('aframe');
require('aframe-spritesheet-component');

API

| Property | Description | Default Value | | -------- | ----------- | ------------- | | progress | A value between 0 and 1 that represents animation progression. the index of the animation frame is calculated from this attribute. Used if no frameIndex or frameName specified | 0 | | frameIndex | Explicit index of the animation frame to use. Used if no frameName specified | null | | frameName | Explicit name of the animation frame to use, if using dataUrl | null | | cols | number of cols in the spritesheet image (not needed if using dataUrl)| 1 | | rows | number of rows spritesheet image (not needed if using dataUrl) | 1 | | firstFrame| index of the first frame of the animation, ordered left to right starting at the first row | 0 | | lastFrame| index of the last frame of the animation, ordered left to right starting at the first row . If not specified and not using the JSON format, value is rows * cols - 1| null | | cloneTexture | if using separate instances of the same image, set this to true | false | | dataUrl | If using a JSON format, url pointing to the json file| null |

Acknowledgment

Walking pig sprite taken from glitchthegame.com, under a Public Domain Dedication license.

Interesting bit of Trivia: Tiny Speck, the company behind the now-defunct Glitch game is now actually Slack!

Author

Developed by Opher Vishnia of Eko

License

Apache 2