Затухание в анимации прокруткиCSS

Разбираемся в CSS
Ответить Пред. темаСлед. тема
Anonymous
 Затухание в анимации прокрутки

Сообщение Anonymous »

Итак, я нашел этот код и хочу добавить к этой анимации небольшое затухание. Итак, при одной прокрутке он проходит через несколько кадров, и я хочу добавить две вещи, с которыми мне нужна помощь. Итак, во-первых, как заставить его проходить больше кадров за одну прокрутку, и, во-вторых, как добавить эффект затухания к одной прокрутке? Да, я пока довольно туп в JS.


< pre class="snippet-code-js lang-js Prettyprint-override">

Код: Выделить всё

const html = document.documentElement;
const canvas = document.getElementById("hero-lightpass");
const context = canvas.getContext("2d");

const frameCount = 148;
const currentFrame = index => (
`https://www.apple.com/105/media/us/airpods-pro/2019/1299e2f5_9206_4470_b28e_08307a42f19b/anim/sequence/large/01-hero-lightpass/${index.toString().padStart(4, '0')}.jpg`
)

const preloadImages = () => {
for (let i = 1; i < frameCount; i++) {
const img = new Image();
img.src = currentFrame(i);
}
};

const img = new Image()
img.src = currentFrame(1);
canvas.width = 1158;
canvas.height = 770;
img.onload = function() {
context.drawImage(img, 0, 0);
}

const updateImage = index => {
img.src = currentFrame(index);
context.drawImage(img, 0, 0);
}

window.addEventListener('scroll', () => {
const scrollTop = html.scrollTop;
const maxScrollTop = html.scrollHeight - window.innerHeight;
const scrollFraction = scrollTop / maxScrollTop;
const frameIndex = Math.min(
frameCount - 1,
Math.ceil(scrollFraction * frameCount)
);

requestAnimationFrame(() => updateImage(frameIndex + 1))
});

preloadImages()

Код: Выделить всё

html {
height: 100vh;
}

body {
height: 500vh;
background: #000;
}

canvas {
position: fixed;
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
max-width: 100vw;
max-height: 100vh;
}


Я несколько раз пытался сделать это сам, но думаю, что просто не понял код.

Подробнее здесь: https://stackoverflow.com/questions/792 ... -animation
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Как включить затухание альфа-анимации для рисуемого объекта?
    Anonymous » » в форуме JAVA
    0 Ответы
    8 Просмотры
    Последнее сообщение Anonymous
  • Как включить затухание альфа-анимации для рисуемого объекта?
    Anonymous » » в форуме Android
    0 Ответы
    14 Просмотры
    Последнее сообщение Anonymous
  • Затухание при пользовательском просмотре прокрутки
    Anonymous » » в форуме JAVA
    0 Ответы
    8 Просмотры
    Последнее сообщение Anonymous
  • Затухание при пользовательском просмотре прокрутки
    Anonymous » » в форуме Android
    0 Ответы
    7 Просмотры
    Последнее сообщение Anonymous
  • Затухание изображения до прозрачности, как градиент
    Гость » » в форуме CSS
    0 Ответы
    13 Просмотры
    Последнее сообщение Гость

Вернуться в «CSS»