تأثير التحويم: الرسوم المتحركة لـ CSS أو الرسوم المتحركة على الويب
تم إهمال علامة الرسوم المتحركة لـ SMIL، ويجب أن تكون انتقالات التمرير في CSS تم تنفيذه لاستبداله.
إزالة علامات المجموعة وإضافة CSS إلى element_tpl:hover pseudo-class:
.element_tpl:hover {
stroke-opacity: 0.5;
}
قم بتحريك العنصر للقياس عدة مرات عند إجراء تغيير ملتزم.
خذ بعين الاعتبار الخيارات التالية:
@keyframes scale-animation {
0% { transform: scale(1); }
50% { transform: scale(1.12); }
100% { transform: scale(1); }
}
.element_tpl {
الرسوم المتحركة: مقياس الرسوم المتحركة 0.5 ثانية بديل لا نهائي؛
.element_tpl {
animation: scale-animation 0.5s infinite alternate;
}
// Create a new animation
const animation = document.timeline.addAnimation();
// Define keyframes
const keyframes = [
{ transform: 'scale(1)', offset: 0 },
{ transform: 'scale(1.12)', offset: 0.5 },
{ transform: 'scale(1)', offset: 1 }
];
// Apply keyframes to the animation
animation.effect = keyframes;
// Target the element
animation.target = document.querySelector('.element_tpl');
المشكلة:تحريك العنصر لتوسيع نطاقه و للأسفل عند النقر.
انتقالات CSS:
استخدم انتقالات CSS لتشغيل تغييرات المقياس في حدثي أسفل الماوس ورفع الماوس:.element_tpl {
transition: transform 0.2s;
}
.element_tpl:active {
transform: scale(1.1);
}
استخدم واجهة برمجة تطبيقات الرسوم المتحركة على الويب للتعامل مع حدث النقر وقياس العنصر وفقًا لذلك: // Add event listener
document.querySelector('.element_tpl').addEventListener('click', (event) => {
// Create a new animation
const animation = document.timeline.addAnimation();
// Define keyframes
const keyframes = [
{ transform: 'scale(1)', offset: 0 },
{ transform: 'scale(1.1)', offset: 0.2 },
{ transform: 'scale(1)', offset: 0.4 },
];
// Apply keyframes to the animation
animation.effect = keyframes;
// Target the element
animation.target = event.target;
});
الحل:
استخدم ملف SMIL polyfill الذي أنشأه إريك ويليجرز: https://github.com/ericwilligers/svg-animation. يقوم هذا polyfill بتحويل الرسوم المتحركة SMIL إلى رسوم متحركة على الويب، مما يوفر طريقة بديلة لتنفيذها.
تنصل: جميع الموارد المقدمة هي جزئيًا من الإنترنت. إذا كان هناك أي انتهاك لحقوق الطبع والنشر الخاصة بك أو الحقوق والمصالح الأخرى، فيرجى توضيح الأسباب التفصيلية وتقديم دليل على حقوق الطبع والنشر أو الحقوق والمصالح ثم إرسالها إلى البريد الإلكتروني: [email protected]. سوف نتعامل مع الأمر لك في أقرب وقت ممكن.
Copyright© 2022 湘ICP备2022001581号-3