Research
Security News
Malicious npm Package Targets Solana Developers and Hijacks Funds
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
three.interactive
Advanced tools
Fast and simple interaction manager for THREE.js for enabling pointer, mouse and touch events on 3D objects.
Note: When using ReactJS I can highly recommend react-three-fiber, which has built-in interaction support. For pure THREE.js projects, this little library can be very useful though.
ESM only. Currently no CJS version is built.
Interactive Objects (THREE.Object3D) are added to the InteractionManager, which fires instances of InteractiveEvent.
Differenciates between mouseover/mouseout (closest objects) and mouseenter/mouseleave (all objects) events.
Intersections are sorted by distance to the camera and the events are dispatched in that order (closest first). If InteractiveEvent.stopPropagation() is called, the event won't fire again on other objects.
Alternative to three.interaction.
Collaborations and improvements are welcome.
yarn add three.interactive
or
npm install three.interactive
import { InteractionManager } from 'three.interactive';
const interactionManager = new InteractionManager(
renderer,
camera,
renderer.domElement
);
interactionManager.add(cube);
cube.addEventListener('click', (event) => {});
interactionManager.update();
import * as THREE from 'three';
import { InteractionManager } from 'three.interactive';
const container = document.createElement('div');
container.setAttribute('id', 'container');
document.body.appendChild(container);
const renderer = new THREE.WebGLRenderer();
renderer.setPixelRatio(window.devicePixelRatio);
renderer.setSize(window.innerWidth, window.innerHeight);
container.appendChild(renderer.domElement);
const scene = new THREE.Scene();
const camera = new THREE.PerspectiveCamera(
45,
window.innerWidth / window.innerHeight,
0.1,
1000
);
camera.position.set(0.0, 0.0, 10.0);
const interactionManager = new InteractionManager(
renderer,
camera,
renderer.domElement
);
const geometry = new THREE.BoxGeometry(1, 1, 1);
const material = new THREE.MeshBasicMaterial();
const cube = new THREE.Mesh(geometry, material);
cube.addEventListener('mouseover', (event) => {
event.target.material.color.set(0xff0000);
document.body.style.cursor = 'pointer';
});
cube.addEventListener('mouseout', (event) => {
event.target.material.color.set(0xffffff);
document.body.style.cursor = 'default';
});
cube.addEventListener('mousedown', (event) => {
event.target.scale.set(1.1, 1.1, 1.1);
});
cube.addEventListener('click', (event) => {
event.target.scale.set(1.0, 1.0, 1.0);
});
scene.add(cube);
interactionManager.add(cube);
const animate = (time) => {
requestAnimationFrame(animate);
interactionManager.update();
renderer.render(scene, camera);
};
animate();
new InteractionManager(renderer, camera, renderer.domElement [, { autoAdd: false, scene, bindEventsOnBodyElement: true } ])
Constructor of InteractionManager instance; if the autoAdd option (still beta) is used, there is no need for adding objects to InteractionManager manually and calling interactionManager.update(); In this mode, the scene needs to be provided in the options.
Members:
Member | Type | Default | Description |
---|---|---|---|
treatTouchEventsAsMouseEvents | boolean | true | Whether touch events should fire as mouse events |
Methods:
Method | Description |
---|---|
add(object, childNames = []) | Add object(s), optionally select only children of object by their names |
remove(object, childNames = []) | Remove object(s), optionally select only children of object by their names |
update() | Update InteractionManager on each render |
dispose() | Dispose InteractionManager |
new InteractionManagerOptions({ autoAdd: false, scene, bindEventsOnBodyElement: true })
Constructor of InteractionManagerOptions instance
Members:
Member | Type | Default | Description |
---|---|---|---|
cancelBubble | boolean | false | Whether events should continue to bubble |
coords | THREE.Vector2 | Mouse/touch coords | |
distance | Number | Distance of intersected point from camera | |
intersected | boolean | Whether object is still intersected | |
wasIntersected | boolean | Whether object was intersected during the last event or last render | |
wasIntersectedOnMouseDown | boolean | Whether object was intersected during mousedown event | |
originalEvent | Event object | Original event, if available (MouseEvent, TouchEvent or PointerEvent) | |
target | THREE.Object3D | Target object | |
type | string | event type: 'click', 'mouseover', 'mouseout', 'mouseenter', 'mouseleave', 'mousedown', 'mousemove', 'mouseup', 'touchstart', 'touchmove', 'touchend', 'pointerdown', 'pointerup', 'pointermove' |
Methods:
Method | Description |
---|---|
stopPropagation | Stop bubbling of event (cancelBubble), e.g. when only the object closest to the camera is supposed to fire an event |
In order to edit the source code, run:
yarn start
And open http://127.0.0.1:8000/ in your browers.
The files in the build
folder will automatically be rebuilt when the files in the src
folder are modified.
MIT licensed
Created by Markus Lerner & contributors
FAQs
Fast and simple interaction manager for THREE.js
We found that three.interactive demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
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.
Research
Security News
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
Security News
Research
Socket researchers have discovered malicious npm packages targeting crypto developers, stealing credentials and wallet data using spyware delivered through typosquats of popular cryptographic libraries.
Security News
Socket's package search now displays weekly downloads for npm packages, helping developers quickly assess popularity and make more informed decisions.