recharge
This commit is contained in:
parent
9f6cd43bb9
commit
c6b39fef8f
@ -19,6 +19,7 @@ const Heal = require('./anims/heal');
|
|||||||
const Hex = require('./anims/hex');
|
const Hex = require('./anims/hex');
|
||||||
const Strike = require('./anims/strike');
|
const Strike = require('./anims/strike');
|
||||||
const Parry = require('./anims/parry');
|
const Parry = require('./anims/parry');
|
||||||
|
const Recharge = require('./anims/recharge');
|
||||||
const Chaos = require('./anims/chaos');
|
const Chaos = require('./anims/chaos');
|
||||||
const invert = require('./anims/invert');
|
const invert = require('./anims/invert');
|
||||||
const Slay = require('./anims/slay');
|
const Slay = require('./anims/slay');
|
||||||
@ -114,6 +115,7 @@ function animations(props) {
|
|||||||
case 'Hex': return <Hex />;
|
case 'Hex': return <Hex />;
|
||||||
case 'Haste': return <Haste />;
|
case 'Haste': return <Haste />;
|
||||||
case 'Parry': return <Parry team={player} />;
|
case 'Parry': return <Parry team={player} />;
|
||||||
|
case 'Recharge': return <Recharge team={player} />;
|
||||||
case 'Invert': return invert(construct.id);
|
case 'Invert': return invert(construct.id);
|
||||||
case 'Siphon': return <Siphon id={construct.id} team={player} />;
|
case 'Siphon': return <Siphon id={construct.id} team={player} />;
|
||||||
case 'SiphonTick': return <SiphonTick id={construct.id} team={player} />;
|
case 'SiphonTick': return <SiphonTick id={construct.id} team={player} />;
|
||||||
|
|||||||
@ -1,9 +1,6 @@
|
|||||||
const anime = require('animejs').default;
|
const anime = require('animejs').default;
|
||||||
const { TIMES } = require('../../constants');
|
const { TIMES } = require('../../constants');
|
||||||
|
|
||||||
// shamelessly lifted from teh anime docs
|
|
||||||
// https://animejs.com/documentation/#svgAttr
|
|
||||||
|
|
||||||
function banish(id) {
|
function banish(id) {
|
||||||
anime({
|
anime({
|
||||||
targets: [document.getElementById(id)],
|
targets: [document.getElementById(id)],
|
||||||
|
|||||||
@ -6,9 +6,6 @@ const anime = require('animejs').default;
|
|||||||
|
|
||||||
const { TIMES } = require('../../constants');
|
const { TIMES } = require('../../constants');
|
||||||
|
|
||||||
// shamelessly lifted from teh anime docs
|
|
||||||
// https://animejs.com/documentation/#svgAttr
|
|
||||||
|
|
||||||
class Electrify extends Component {
|
class Electrify extends Component {
|
||||||
constructor() {
|
constructor() {
|
||||||
super();
|
super();
|
||||||
|
|||||||
@ -6,9 +6,6 @@ const anime = require('animejs').default;
|
|||||||
|
|
||||||
const { TIMES } = require('../../constants');
|
const { TIMES } = require('../../constants');
|
||||||
|
|
||||||
// shamelessly lifted from teh anime docs
|
|
||||||
// https://animejs.com/documentation/#svgAttr
|
|
||||||
|
|
||||||
class Electrify extends Component {
|
class Electrify extends Component {
|
||||||
constructor() {
|
constructor() {
|
||||||
super();
|
super();
|
||||||
|
|||||||
@ -1,9 +1,6 @@
|
|||||||
const anime = require('animejs').default;
|
const anime = require('animejs').default;
|
||||||
const { TIMES } = require('../../constants');
|
const { TIMES } = require('../../constants');
|
||||||
|
|
||||||
// shamelessly lifted from teh anime docs
|
|
||||||
// https://animejs.com/documentation/#svgAttr
|
|
||||||
|
|
||||||
function invert(id) {
|
function invert(id) {
|
||||||
anime({
|
anime({
|
||||||
targets: [document.getElementById(id)],
|
targets: [document.getElementById(id)],
|
||||||
|
|||||||
93
client/src/components/anims/recharge.jsx
Normal file
93
client/src/components/anims/recharge.jsx
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
const preact = require('preact');
|
||||||
|
const { Component } = require('preact');
|
||||||
|
const anime = require('animejs').default;
|
||||||
|
|
||||||
|
const { TIMES } = require('../../constants');
|
||||||
|
|
||||||
|
class Recharge extends Component {
|
||||||
|
constructor() {
|
||||||
|
super();
|
||||||
|
this.animations = [];
|
||||||
|
}
|
||||||
|
|
||||||
|
render({ team }) {
|
||||||
|
return (
|
||||||
|
<svg
|
||||||
|
class='skill-animation red'
|
||||||
|
version="1.1"
|
||||||
|
id="recharge"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
viewBox="0 0 256 256">
|
||||||
|
<filter id='rechargeFilter'>
|
||||||
|
<feTurbulence type="turbulence" baseFrequency="0" numOctaves="1" result="turbulence"></feTurbulence>
|
||||||
|
<feDisplacementMap in2="turbulence" in="SourceGraphic" scale="1" xChannelSelector="R" yChannelSelector="G"></feDisplacementMap>
|
||||||
|
</filter>
|
||||||
|
<filter id="rechargeBlueFilter">
|
||||||
|
<feGaussianBlur in="SourceGraphic" stdDeviation="5" />
|
||||||
|
<feMerge>
|
||||||
|
<feMergeNode />
|
||||||
|
<feMergeNode in="SourceGraphic" />
|
||||||
|
</feMerge>
|
||||||
|
</filter>
|
||||||
|
<path
|
||||||
|
class='red'
|
||||||
|
filter='url("#rechargeFilter")'
|
||||||
|
d='M64,128 h-50 M64,128 h50 M64,128 v50 M64,128 v-50'
|
||||||
|
/>
|
||||||
|
<path
|
||||||
|
class='blue'
|
||||||
|
filter='url("#rechargeBlueFilter")'
|
||||||
|
d='M192,128 h-50 M192,128 h50 M192,128 v50 M192,128 v-50'
|
||||||
|
/>
|
||||||
|
<path
|
||||||
|
class='white'
|
||||||
|
d='M192,128 h-50 M192,128 h50 M192,128 v50 M192,128 v-50'
|
||||||
|
/>
|
||||||
|
</svg>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
componentDidMount() {
|
||||||
|
this.animations.push(anime({
|
||||||
|
targets: ['#recharge'],
|
||||||
|
opacity: [
|
||||||
|
{ value: 1, delay: TIMES.TARGET_FADE_IN_DELAY, duration: TIMES.TARGET_FADE_IN_DURATION },
|
||||||
|
{ value: 0, delay: TIMES.TARGET_FADE_OUT_DELAY, duration: TIMES.FADE_OUT_DURATION },
|
||||||
|
],
|
||||||
|
easing: 'easeInOutSine',
|
||||||
|
}));
|
||||||
|
|
||||||
|
this.animations.push(anime({
|
||||||
|
targets: ['#recharge path.white'],
|
||||||
|
strokeWidth: [2, 1],
|
||||||
|
easing: 'easeInOutSine',
|
||||||
|
direction: 'alternate',
|
||||||
|
|
||||||
|
delay: TIMES.TARGET_MAIN_DELAY,
|
||||||
|
duration: TIMES.TARGET_MAIN_DURATION,
|
||||||
|
}));
|
||||||
|
|
||||||
|
this.animations.push(anime({
|
||||||
|
targets: ['#rechargeFilter feTurbulence', ' #rechargeFilter feDisplacementMap'],
|
||||||
|
baseFrequency: 2,
|
||||||
|
scale: 10,
|
||||||
|
numOctaves: 5,
|
||||||
|
easing: 'easeOutSine',
|
||||||
|
|
||||||
|
delay: TIMES.TARGET_FADE_IN_DELAY,
|
||||||
|
duration: TIMES.RESOLUTION_TOTAL_MS,
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
|
||||||
|
// this is necessary because
|
||||||
|
// skipping / timing / unmounting race conditions
|
||||||
|
// can cause the animations to cut short, this will ensure the values are reset
|
||||||
|
// because preact will recycle all these components
|
||||||
|
componentWillUnmount() {
|
||||||
|
for (let i = this.animations.length - 1; i >= 0; i--) {
|
||||||
|
this.animations[i].reset();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = Recharge;
|
||||||
Loading…
x
Reference in New Issue
Block a user