Animation chute de neige

De grands gamins que nous sommes, mais c’est rafraichissant dans ce monde de fou :wave:

Allez, pour aller toujours plus loin dans l’esprit de Noël, un petit ajout de suivi de souris avec des étoiles aux couleurs multiples :mouse:

Possibilité de choisir la direction des animations des étoiles depuis custom.js :

// valeurs possibles : 1=anim vers le bas, 0=anim horizontale, -1=anim vers le haut
let fallDirection = 1;

starsMouseOver

Bon, avec les étoiles qui tombent, elles passent un peu inaperçues sur la vidéo :sweat_smile:

custom.css
.starMouse {
  transform-style: preserve-3d;
  width: 1px;
  height: 1px;
  position: absolute;
  color: red;
  pointer-events: none;
  z-index: 50;
}

.starMouse:before {
  position: absolute;
  content: "✦";
  color: inherit;
  inset: 0;
  text-shadow: 0 0 1em #fff5;
}

.star {
  position: absolute;
  top: -20px;
  animation: animate 5s linear forwards;
  z-index: 50;
}

.star::before {
  content: '\f005';
  text-shadow: 0 0 5px #fff,
    0 0 20px #fff,
    0 0 50px #fff, ;
}

@keyframes animate {
  0% {
    transform: translateY(0) rotate(0deg);
    opacity: 1;
  }
  80% {
    opacity: 1;
  }
  100% {
    transform: translateY(calc(100vh - 24px)) rotate(360deg);
    opacity: 0;
  }
}

#div_displayObject .eqLogic::before {
    content: '';
    position: absolute;
    top: -5px;
    left: -4px;
    right: -5px;
    height: 18px;
    background: url() no-repeat 0 0, url() no-repeat 70% 0, url() no-repeat 30% 0, url() no-repeat 100% 0;
  opacity: 0.6;
}
custom.js
$(document).ready (function(){
	$('.eqLogic-widget[data-eqLogic_id="1523"]').css('transform', 'rotate(45deg)');
        function stars() {

            let e = document.createElement("div");
            e.setAttribute("class", "fas fa-star star");
            document.body.appendChild(e);
            e.style.left = Math.random() * + innerWidth + "px";

            let size = Math.random() * 12;
            let duration = Math.random() * 3;

            e.style.fontSize = 12 + size + "px";
            e.style.animationDuration = 2 + duration + "s";

            setTimeout(function () {
                document.body.removeChild(e);
            }

                , 5000);
        }

        setInterval(function () {
            stars();
        }

            , 100);
  
})

// valeurs possibles : 1=anim vers le bas, 0=anim horizontale, -1=anim vers le haut
let fallDirection = 1;
let x1=0, y1=0;

const 
  vh = Math.max(document.documentElement.clientHeight || 0, window.innerHeight || 0),
  dist_to_draw = 50,
  delay = 1000,
  fsize = ['1.1rem', '1.4rem', '.8rem', '1.7rem'],
  colors = ['#E23636', '#F9F3EE', '#E1F8DC', '#B8AFE6', '#AEE1CD', '#5EB0E5'],
  rand = (min, max) => 
    Math.floor(Math.random() * (max - min + 1)) + min,
  selRand = (o) => o[rand(0, o.length -1)],
  distanceTo =  (x1, y1, x2, y2) => 
    Math.sqrt((Math.pow(x2-x1,2))+(Math.pow(y2-y1,2))),
  shouldDraw = (x, y) => 
    (distanceTo(x1, y1, x, y) >= dist_to_draw),
  addStr = (x, y) => {
    const str = document.createElement("div");
    str.innerHTML = '✦';
    str.className = 'starMouse';
    str.style.top = `${y + rand(-20,20)}px`;
    str.style.left = `${x}px`;
    str.style.color = selRand(colors);
    str.style.fontSize = selRand(fsize);
    document.body.appendChild(str);
    const fs = 10 + 5 * parseFloat(getComputedStyle(str).fontSize);
    str.animate(
      {
        translate: [
          `${rand(-5, 5)}px ${((y+fs)>vh?vh-y:fs) * fallDirection * .3}px`,
          `${rand(-20, 20)}px ${((y+fs)>vh?vh-y:fs) * fallDirection}px`],
        opacity: [1,0],
        transform: ['rotateX(0) rotateY(0)',`rotateX(${rand(1, 500)}deg) rotateY(${rand(1, 500)}deg)`]
      }, {
        duration: delay,
        fill: 'forwards',
        rangeStart: ["cover 0% ", "cover 40%"],
        rangeEnd: ["cover 40% ", "cover 100%"]
    });

    setTimeout(() => {
        str.remove();
      }, delay);
  }

addEventListener("mousemove", (e) => {
  const {clientX, clientY} = e;
  if (shouldDraw(clientX, clientY)){
    addStr(clientX, clientY);
    x1 = clientX;
    y1 = clientY;
  }
});
1 « J'aime »

Il y a une cacahuète dans le texte préformatté du custom.js, idem en custom.css :wink:

ça doit être ok, merci :slight_smile: j’avais zappé les balises de code.

Bonjour @Phpvarious, je prépare l’hiver!
j’ai réussi à installer l’effet neige qui tombe en galerant un peu car j’avais pas compris qui fallait coché la case « avancée » dans le menu « Réglage » « Configuration » onglet « interface », mais c’est bon. Avec le scénario de Spine, ca marche nickel.
Par contre, je n’arrive pas a avoir l’effet neige sur les tuiles,
peut tu m’expliquer comment faire s’il te plait pour l’intégrer?

et sinon si on veux remplacer les flocons par des feuilles ou des citrouilles c’est faisable?
merci d’avance

Hello,

Il faut récupérer les images souhaitées, les adapter à la bonne taille et générer le code correspondant à l’image.

image

  • récupération d’une image

  • adaptation de l’image : positionner son contenu, mettre un fond transparent, redimensionner avec une hauteur de 23px

citrouille2

  • recopier le code dans la personnalisation avancée en remplacement du code de la neige

Bon courage ! :slight_smile:

1 « J'aime »

Je vais essayer
merci Noodom

Voilà le résultat et ma contribution;

scenario de desactivation

$fileCss = '/var/www/html/desktop/custom/custom.css'; $resultCss = file_get_contents($fileCss); if ($resultCss === false) { $scenario->setLog('Echec de la lecture du fichier custom.css'); } else { // $scenario->setLog($resultCss); $resultCss = preg_replace('/\/\* Snow \*\/.*?\/\* SnowEnd \*\//s', '', $resultCss); $resultCss = preg_replace('/\/\* Snowcadre \*\/.*?\/\* SnowcadreEnd \*\//s', '', $resultCss); $resultCss = preg_replace('/\/\* Feuilles d\'érable \*\/.*?\/\* Feuilles d\'érable End \*\//s', '', $resultCss); $resultCss = preg_replace('/\/\* Citrouille \*\/.*?\/\* Citrouille End \*\//s', '', $resultCss); $resultCss = preg_replace('/\/\* Fleurs qui poussent \*\/.*?\/\* Fleurs End \*\//s', '', $resultCss); $resultCss = preg_replace('/\/\* Fleurs qui tombent \*\/.*?\/\* Fleurs End \*\//s', '', $resultCss); // $scenario->setLog($resultCss); $resultCss = file_put_contents($fileCss, trim($resultCss)); if ($resultCss === false) { $scenario->setLog('Echec de l\'écriture du fichier custom.css'); } else { $scenario->setLog($resultCss . ' octets ont été écrits dans le fichier custom.css'); $fileJs = '/var/www/html/desktop/custom/custom.js'; $resultJs = file_get_contents($fileJs); if ($resultJs === false) { $scenario->setLog('Echec de la lecture du fichier custom.js'); } else { // $scenario->setLog($resultJs); $resultJs = preg_replace('/\/\* Animation \*\/.*?\/\* Animation End \*\//s', '', $resultJs); // $scenario->setLog($resultJs); $resultJs = file_put_contents($fileJs, trim($resultJs)); if ($resultCss === false) { $scenario->setLog('Echec de l\'écriture du fichier custom.js'); } else { $scenario->setLog($resultCss . ' octets ont été écrits dans le fichier custom.js'); message::add('Animation', 'L\'animation chute de neige a été désactivé'); } } } }

scenario citrouille

`$fileCss = ‹ /var/www/html/desktop/custom/custom.css ›;
$dataCss = ’
/* Citrouille /
.citrouille {
position: absolute;
top: -20px;
animation: animate 5s linear forwards;
z-index: 50;
}
.citrouille::before {
content: «  »;
background-image: url(« …/…/data/img/citrouille1.png »);
width: 28px; /
Largeur de votre image /
height: 28px; /
Hauteur de votre image /
display: inline-block; /
Pour que les dimensions fonctionnent /
color: green; /
Changer la couleur de la feuille d'érable si nécessaire /
font-size: 28px; /
Changer la taille de la feuille d'érable si nécessaire */
}

@keyframes animate {
0% {
transform: translateY(0) rotate(0deg);
opacity: 1;
}

80% {
	opacity: 1;
}

100% {
	transform: translateY(calc(100vh - 24px)) rotate(360deg);
	opacity: 0;
}

}

.div_object legend .objectDashLegend {
background-color: transparent !important;
}
/* Citrouille End /‹ ;
$dataCss = $dataCss . PHP_EOL;
$resultCss = file_put_contents($fileCss, $dataCss, FILE_APPEND);
if ($resultCss === false) {
$scenario->setLog(« Echec de l’écriture du fichier custom.css »);
} else {
$scenario->setLog($resultCss . ’ octets ont été écrits dans le fichier custom.css ›);
$fileJs = ‹ /var/www/html/desktop/custom/custom.js ›;
$dataJs = ’
/
Animation /
document.addEventListener(« DOMContentLoaded », function () {
function leaves() {
let e = document.createElement(« div »);
e.setAttribute(« class », « citrouille »);
document.body.appendChild(e);
e.style.left = Math.random() * (innerWidth - 17 - 24) + « px »;
let size = Math.random() * 12;
let duration = Math.random() * 3;
e.style.fontSize = 12 + size + « px »;
e.style.animationDuration = 2 + duration + « s »;
setTimeout(function () {
document.body.removeChild(e);
}, 5000);
};
setInterval(function () {
leaves();
}, 100);
});
/
Animation End */‹ ;
$dataJs = $dataJs . PHP_EOL;
$resultJs = file_put_contents($fileJs, $dataJs, FILE_APPEND);
if ($resultJs === false) {
$scenario->setLog(« Echec de l’écriture du fichier custom.js »);
} else {
$scenario->setLog($resultJs . ’ octets ont été écrits dans le fichier custom.js ›);
message::add(« Animation », « L’animation chute de feuilles d’érable a été activée »);
}
}
`

scenario neige

`$fileCss = ‹ /var/www/html/desktop/custom/custom.css ›;
$dataCss = ’
/* Snowcadre /
#div_displayObject .eqLogic::before {
content: '';
position: absolute;
top: -5px;
left: -4px;
right: -5px;
height: 18px;
background: url() no-repeat 0 0, url() no-repeat 70% 0, url() no-repeat 30% 0, url() no-repeat 100% 0;
opacity: 0.6;
}
/
SnowcadreEnd /
/
Snow */
.snowflake {
position: absolute;
top: -20px;
animation: animate 5s linear forwards;
z-index: 50;
}

.snowflake::before {
content: '\f2dc';
text-shadow: 0 0 5px #fff,
0 0 20px #fff,
0 0 50px #fff, ;
}

@keyframes animate {
0% {
transform: translateY(0) rotate(0deg);
opacity: 1;
}

80% {
	opacity: 1;
}

100% {
	transform: translateY(calc(100vh - 24px)) rotate(360deg);
	opacity: 0;
}

}

.div_object legend .objectDashLegend {
background-color: transparent !important;
}

/* SnowEnd /‹ ;
$dataCss = $dataCss . PHP_EOL;
$resultCss = file_put_contents($fileCss, $dataCss, FILE_APPEND);
if ($resultCss === false) {
$scenario->setLog(‹ Echec de l'écriture du fichier custom.css ›);
} else {
$scenario->setLog($resultCss . ’ octets ont été écrits dans le fichier custom.css ›);
$fileJs = ‹ /var/www/html/desktop/custom/custom.js ›;
$dataJs = ’
/
Animation /
document.addEventListener(« DOMContentLoaded », function () {
document.querySelector(« #backgroundforJeedom »).style.transform = « rotate(45deg) »;
function stars() {
let e = document.createElement(« div »);
e.setAttribute(« class », « fas fa-snowflake snowflake »);
document.body.appendChild(e);
e.style.left = Math.random() * (innerWidth - 17 - 24) + « px »;
//e.style.top = Math.random() * window.innerHeight + « px »;
let size = Math.random() * 12;
let duration = Math.random() * 3;
e.style.fontSize = 12 + size + « px »;
e.style.animationDuration = 2 + duration + « s »;
setTimeout(function () {
document.body.removeChild(e);
}, 5000);
};
setInterval(function () {
stars();
}, 100);
});
/
Animation End */‹ ;
$dataJs = $dataJs . PHP_EOL;
$resultJs = file_put_contents($fileJs, $dataJs, FILE_APPEND);
if ($resultJs === false) {
$scenario->setLog(‹ Echec de l'écriture du fichier custom.js ›);
} else {
$scenario->setLog($resultJs . ’ octets ont été écrits dans le fichier custom.js ›);
message::add(‹ Animation ›, ‹ L'animation chute de neige a été activé ›);
}
}`

scenario Feuille d érable

`$fileCss = ‹ /var/www/html/desktop/custom/custom.css ›;
$dataCss = ’
/* Feuilles d'érable /
.feuille {
position: absolute;
top: -20px;
animation: animate 5s linear forwards;
z-index: 50;
}
.feuille::before {
content: «  »;
background-image: url(« …/…/data/img/Feuille2.png »);
width: 24px; /
Largeur de votre image /
height: 24px; /
Hauteur de votre image /
display: inline-block; /
Pour que les dimensions fonctionnent /
color: green; /
Changer la couleur de la feuille d'érable si nécessaire /
font-size: 24px; /
Changer la taille de la feuille d'érable si nécessaire */
}

@keyframes animate {
0% {
transform: translateY(0) rotate(0deg);
opacity: 1;
}

80% {
	opacity: 1;
}

100% {
	transform: translateY(calc(100vh - 24px)) rotate(360deg);
	opacity: 0;
}

}

.div_object legend .objectDashLegend {
background-color: transparent !important;
}
/* Feuilles d'érable End /‹ ;
$dataCss = $dataCss . PHP_EOL;
$resultCss = file_put_contents($fileCss, $dataCss, FILE_APPEND);
if ($resultCss === false) {
$scenario->setLog(« Echec de l’écriture du fichier custom.css »);
} else {
$scenario->setLog($resultCss . ’ octets ont été écrits dans le fichier custom.css ›);
$fileJs = ‹ /var/www/html/desktop/custom/custom.js ›;
$dataJs = ’
/
Animation /
document.addEventListener(« DOMContentLoaded », function () {
function leaves() {
let e = document.createElement(« div »);
e.setAttribute(« class », « feuille »);
document.body.appendChild(e);
e.style.left = Math.random() * (innerWidth - 17 - 24) + « px »;
let size = Math.random() * 12;
let duration = Math.random() * 3;
e.style.fontSize = 12 + size + « px »;
e.style.animationDuration = 2 + duration + « s »;
setTimeout(function () {
document.body.removeChild(e);
}, 5000);
};
setInterval(function () {
leaves();
}, 100);
});
/
Animation End */‹ ;
$dataJs = $dataJs . PHP_EOL;
$resultJs = file_put_contents($fileJs, $dataJs, FILE_APPEND);
if ($resultJs === false) {
$scenario->setLog(« Echec de l’écriture du fichier custom.js »);
} else {
$scenario->setLog($resultJs . ’ octets ont été écrits dans le fichier custom.js ›);
message::add(« Animation », « L’animation chute de feuilles d’érable a été activée »);
}
}
`

scenario Fleurs qui poussent et tombent

`$fileCss = ‹ /var/www/html/desktop/custom/custom.css ›;
$dataCss = ’
/* Fleurs qui poussent */
.fleur-grow {
position: absolute;
bottom: 0px;
animation: grow 5s linear forwards;
z-index: 50;
transform-origin: bottom center;
}

.fleur-grow::before {
content: «  »;
background-image: url(« …/…/data/img/fleur.png »);
width: 24px; /* Largeur de votre image /
height: 24px; /
Hauteur de votre image /
display: inline-block; /
Pour que les dimensions fonctionnent */
}

@keyframes grow {
0% {
transform: scale(0);
opacity: 0;
}

100% {
    transform: scale(1);
    opacity: 1;
}

}
.fleur2-grow {
position: absolute;
bottom: 0px;
animation: grow 5s linear forwards;
z-index: 50;
transform-origin: bottom center;
}

.fleur2-grow::before {
content: «  »;
background-image: url(« …/…/data/img/orchidee.png »);
width: 24px; /* Largeur de votre image /
height: 24px; /
Hauteur de votre image /
display: inline-block; /
Pour que les dimensions fonctionnent */
}
.fleur3-grow {
position: absolute;
bottom: 0px;
animation: grow 5s linear forwards;
z-index: 50;
transform-origin: bottom center;
}

.fleur3-grow::before {
content: «  »;
background-image: url(« …/…/data/img/rose jaune.png »);
width: 24px; /* Largeur de votre image /
height: 24px; /
Hauteur de votre image /
display: inline-block; /
Pour que les dimensions fonctionnent */
}

/* Ajoutez d'autres fleurs ici */

/* Fleurs qui tombent */
.fleur-fall {
position: fixed;
top: 0;
animation: fall linear infinite;
z-index: 50;
}

.fleur-fall::before {
content: «  »;
background-image: url(« …/…/data/img/fleur blanche.png »);
width: 24px; /* Largeur de votre image /
height: 24px; /
Hauteur de votre image /
display: inline-block; /
Pour que les dimensions fonctionnent */
}

@keyframes fall {
0% {
transform: translateY(-100%);
}

100% {
    transform: translateY(100vh);
}

}

.div_object legend .objectDashLegend {
background-color: transparent !important;
}
/* Fleurs End /‹ ;
$dataCss = $dataCss . PHP_EOL;
$resultCss = file_put_contents($fileCss, $dataCss, FILE_APPEND);
if ($resultCss === false) {
$scenario->setLog(« Echec de l’écriture du fichier custom.css »);
} else {
$scenario->setLog($resultCss . ’ octets ont été écrits dans le fichier custom.css ›);
$fileJs = ‹ /var/www/html/desktop/custom/custom.js ›;
$dataJs = ’
/
Animation */
document.addEventListener(« DOMContentLoaded », function () {
function createFlower(className, imageUrl) {
let e = document.createElement(« div »);
e.setAttribute(« class », className);
document.body.appendChild(e);
e.style.backgroundImage = « url( » + imageUrl + « ) »;
e.style.left = Math.random() * (innerWidth - 17 - 32) + « px »;
let size = Math.random() * 12;
let duration = Math.random() * 3;
e.style.fontSize = 12 + size + « px »;
e.style.animationDuration = 2 + duration + « s »;
setTimeout(function () {
document.body.removeChild(e);
}, 5000);
};

function flowersGrow() {
    createFlower("fleur-grow", "../../data/img/fleur.png");
    createFlower("fleur2-grow", "../../data/img/orchidee.png");
    createFlower("fleur3-grow", "../../data/img/rose jaune.png");
    // Ajoutez d\'autres fleurs ici
};

function flowersFall() {
    createFlower("fleur-fall", "../../data/img/fleur blanche.png");
    // Ajoutez d\'autres fleurs ici
};

setInterval(flowersGrow, 300);
setInterval(flowersFall, 500);

});
/* Animation End */‹ ;
$dataJs = $dataJs . PHP_EOL;
$resultJs = file_put_contents($fileJs, $dataJs, FILE_APPEND);
if ($resultJs === false) {
$scenario->setLog(« Echec de l’écriture du fichier custom.js »);
} else {
$scenario->setLog($resultJs . ’ octets ont été écrits dans le fichier custom.js ›);
message::add(« Animation », « L’animation de fleurs a été activée »);
}
}
`

pour les images:

dans `html/data/img`

citrouille1
Feuille1
Feuille2
fleur blanche
fleur
orchidee
rose jaune