Skip to content

Instantly share code, notes, and snippets.

Embed
What would you like to do?
to ivan.popelyshev
<div id="myContainer"></div>
function test() {
return false;
}
const ball=""
Object.defineProperty(PIXI.Application.prototype, 'rw', {
get: function() { return Math.random() * this.renderer.width; }
});
Object.defineProperty(PIXI.Application.prototype, 'rh', {
get: function() { return Math.random() * this.renderer.height; }
});
Object.defineProperty(PIXI.Application.prototype, 'cw', {
get: function() { return .5 * this.renderer.width; }
});
Object.defineProperty(PIXI.Application.prototype, 'ch', {
get: function() { return .5 * this.renderer.height; }
});
Object.assign(PIXI.Sprite.prototype, {
acc: new PIXI.ObservablePoint(test, window, 0, 0),
vel: new PIXI.ObservablePoint(test, window, 0, 0),
k: .1,
interactive: false,
buttonMode: false
});
let opts = {
transparent: false,
backgroundColor: 0x49DCB1,
resolution: 1,
antialias: 0,
autoResize: true,
forceCanvas: false,
clearBeforeRender: true
};
var app = new PIXI.Application(innerWidth, innerHeight, opts);
let _width = app.renderer.width;
let _height = app.renderer.height;
const mouse = { x: null, y: null };
let container = new PIXI.Container();
container.interactive = true;
app.stage.addChild(container);
$("#myContainer").append(app.view);
window.onresize = resize;
let pressed = 0;
function resize() {
app.renderer.resize(innerWidth, innerHeight);
_width = app.renderer.width;
_height = app.renderer.height;
}
let cvs = document.getElementsByTagName("canvas")[0];
cvs.addEventListener("mousemove", (e) => {
mouse.x = e.clientX;
mouse.y = e.clientY;
});
cvs.addEventListener("mousedown", (e) => {
pressed = true;
});
cvs.addEventListener("mouseup", (e) => {
pressed = false;
});
Object.assign(Number.prototype, {
map: function(inmin = 0, inmax = 1517, outmin = 0, outmax = 360) {
return (this.valueOf() - inmin) * (outmax - outmin) / (inmax - inmin) + outmin;
},
toDegree: function() {
return this.valueOf() * (180 / Math.PI);
},
toRadians: function() {
return this.valueOf() * (Math.PI / 180);
}
});
Object.assign(PIXI.ObservablePoint.prototype, {
add: function(o) {
this.set(this.x += o.x, this.y += o.y);
},
radd: function(o) {
return new PIXI.ObservablePoint(test, window, this.x + o.x, this.y + o.y);
},
sub: function(o) {
this.set(this.x -= o.x, this.y -= o.y);
},
rsub: function(o) {
return new PIXI.ObservablePoint(test, window, this.x - o.x, this.y - o.y);
},
mult: function(o) {
this.x *= o;
this.y *= o;
},
rmult: function(o) {
return new PIXI.ObservablePoint(test, window, this.x * o, this.y * o);
},
getAngle() {
//in radians
return Math.atan2(this.y, this.x);
},
getLenght() {
return Math.hypot(this.x, this.y);
},
setLength(l) {
let angle = this.getAngle();
this.set(Math.cos(angle) * l, Math.sin(angle) * l);
},
setAngle(a) {
//in radians;
this.set(Math.cos(a) * this.getLenght(), Math.sin(a) * this.getLenght());
}
});
class spring extends PIXI.Sprite {
constructor(x, y) {
super(PIXI.Texture.fromImage(ball));
this.x = app.rw;
this.y = app.rh;
this.friction=.9
this.t = new PIXI.ObservablePoint(test, window, x, y);
this.scale.set(.5 + Math.random() * .5);
this.anchor.set(.5);
}
update() {
this.d = this.t.rsub(this.position);
this.d.mult(this.k);
this.vel.add(this.d);
this.position.add(this.vel);
this.vel.mult(this.friction);
}
}
let arr = [];
for (var a = 0; a < 100; a++) {
let bu = new spring(app.rw, app.rh);
container.addChild(bu);
arr.push(bu);
}
app.ticker.add(() => {
for (var i = 0; i < arr.length; i++) {
let bu = arr[i];
bu.update();
}
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/pixi.js/4.5.4/pixi.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
* {
margin: 0;
padding: 0;
}
body,
html {
width: 100%;
height: 100%;
margin: 0px;
overflow: hidden;
}
#myContainer {
position: absolute;
width: 100%;
height: 100%;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
You can’t perform that action at this time.