ईएस 6 - एनीमेशन
आप एक जटिल एनीमेशन बनाने के लिए जावास्क्रिप्ट का उपयोग कर सकते हैं, लेकिन निम्नलिखित तत्वों तक सीमित नहीं हैं -
- Fireworks
- फीका असर
- रोल-इन या रोल-आउट
- पेज-इन या पेज-आउट
- वस्तु की चाल
इस अध्याय में, हम देखेंगे कि एनीमेशन बनाने के लिए जावास्क्रिप्ट का उपयोग कैसे करें।
एक तार्किक समीकरण या फ़ंक्शन द्वारा निर्धारित पैटर्न के कुछ प्रकार के अनुसार जावास्क्रिप्ट का उपयोग कई डोम तत्वों (<img />, <div>, या किसी अन्य HTML तत्व) को स्थानांतरित करने के लिए किया जा सकता है।
जावास्क्रिप्ट एनीमेशन कार्यक्रमों में अक्सर उपयोग किए जाने वाले निम्नलिखित कार्य प्रदान करता है।
setTimeout(फ़ंक्शन, अवधि) - यह फ़ंक्शन अब से अवधि मिलीसेकंड के बाद फ़ंक्शन को कॉल करता है।
setInterval(फ़ंक्शन, अवधि) - यह फ़ंक्शन हर अवधि मिलीसेकंड के बाद फ़ंक्शन को कॉल करता है।
clearTimeout(setTimeout_variable) - यह फ़ंक्शन सेटटाइमआउट () फ़ंक्शन द्वारा सेट किए गए किसी भी टाइमर को साफ़ करता है।
जावास्क्रिप्ट एक DOM ऑब्जेक्ट की कई विशेषताओं को स्क्रीन पर उसकी स्थिति सहित भी सेट कर सकता है। आप इसे स्क्रीन पर कहीं भी रखने के लिए किसी ऑब्जेक्ट के ऊपर और बाईं विशेषता सेट कर सकते हैं। निम्नलिखित के लिए सिंटैक्स है।
// Set distance from left edge of the screen.
object.style.left = distance in pixels or points;
or
// Set distance from top edge of the screen.
object.style.top = distance in pixels or points;
मैनुअल एनीमेशन
तो चलिए DOM ऑब्जेक्ट प्रॉपर्टीज़ और जावास्क्रिप्ट फ़ंक्शंस का उपयोग करते हुए एक सरल एनीमेशन लागू करते हैं। निम्न सूची में भिन्न DOM विधियाँ हैं।
हम जावास्क्रिप्ट फ़ंक्शन का उपयोग कर रहे हैं getElementById() एक DOM ऑब्जेक्ट प्राप्त करना और फिर इसे एक ग्लोबल वैरिएबल को असाइन करना imgObj।
हमने एक इनिशियलाइज़ेशन फंक्शन को परिभाषित किया है init() imgObj को शुरू करने के लिए जहां हमने इसकी स्थिति और बाईं विशेषताओं को निर्धारित किया है।
हम विंडो लोड के समय आरंभीकरण फ़ंक्शन कह रहे हैं।
हम बुला रहे हैं moveRight()10 पिक्सेल से बाईं दूरी बढ़ाने के लिए कार्य करते हैं। आप इसे बाईं ओर स्थानांतरित करने के लिए एक नकारात्मक मान पर भी सेट कर सकते हैं।
उदाहरण
निम्न उदाहरण का प्रयास करें
<html>
<head>
<title>JavaScript Animation</title>
<script type = "text/javascript">
<!--
var imgObj = null; function init(){
imgObj = document.getElementById('myImage');
imgObj.style.position = 'relative';
imgObj.style.left = '0px';
}
function moveRight(){
imgObj.style.left = parseInt(
imgObj.style.left) + 10 + 'px';
}
window.onload = init;
//
-->
</script>
</head>
<body>
<form>
<img id = "myImage" src = "/images/html.gif" />
<p>Click button below to move the image to right</p>
<input type = "button" value = "Click Me" onclick = "moveRight();" />
</form>
</body>
</html>
स्वचालित एनीमेशन
उपरोक्त उदाहरण में, हमने देखा कि हर क्लिक के साथ दाईं ओर एक छवि कैसे चलती है। हम जावास्क्रिप्ट फ़ंक्शन का उपयोग करके इस प्रक्रिया को स्वचालित कर सकते हैंsetTimeout() निम्नलिखित नुसार।
यहाँ हमने और विधियाँ जोड़ी हैं। तो, आइए देखें कि यहां क्या नया है।
moveRight() फंक्शन imgObj की स्थिति सेट करने के लिए सेटटाइमआउट () फ़ंक्शन कह रहा है।
हमने एक नया फंक्शन जोड़ा है stop() सेटटाइमआउट () फ़ंक्शन द्वारा टाइमर सेट को साफ़ करने और ऑब्जेक्ट को अपने प्रारंभिक स्थान पर सेट करने के लिए।
उदाहरण
निम्न उदाहरण कोड का प्रयास करें।
<html>
<head>
<title>JavaScript Animation</title>
<script type = "text/javascript">
<!--
var imgObj = null; var animate ; function init(){
imgObj = document.getElementById('myImage');
imgObj.style.position = 'relative';
imgObj.style.left = '0px';
}
function moveRight(){
imgObj.style.left = parseInt(imgObj.style.left) + 10 + 'px';
animate = setTimeout(moveRight,20);
// call moveRight in 20msec
}
function stop() {
clearTimeout(animate);
imgObj.style.left = '0px';
}
window.onload = init;
//
-->
</script>
</head>
<body>
<form>
<img id = "myImage" src = "/images/html.gif" />
<p>Click the buttons below to handle animation</p>
<input type="button" value="Start" onclick = "moveRight();" />
<input type = "button" value="Stop" onclick = "stop();" />
</form>
</body>
</html>
एक माउस घटना के साथ रोलओवर
यहां एक सरल उदाहरण है जो माउस इवेंट के साथ छवि रोलओवर दिखा रहा है।
आइए देखें कि हम निम्नलिखित उदाहरण में क्या उपयोग कर रहे हैं -
इस पृष्ठ को लोड करने के समय, 'if' स्टेटमेंट इमेज ऑब्जेक्ट के अस्तित्व की जांच करता है। यदि छवि ऑब्जेक्ट अनुपलब्ध है, तो यह ब्लॉक निष्पादित नहीं किया जाएगा।
Image() कंस्ट्रक्टर एक नई छवि ऑब्जेक्ट बनाता है और उसे प्रीलोड करता है image1।
src प्रॉपर्टी को एक्सटर्नल इमेज फाइल का नाम सौंपा जाता है /images/html.gif।
इसी तरह, हमने बनाया है image2 ऑब्जेक्ट और असाइन किया गया /images/http.gif इस वस्तु में।
#(हैश मार्क) लिंक को निष्क्रिय कर देता है ताकि क्लिक करने पर ब्राउज़र URL पर जाने की कोशिश न करे। यह लिंक एक छवि है।
onMouseOver जब उपयोगकर्ता का माउस लिंक पर चला जाता है, और onMouseOut जब उपयोगकर्ता का माउस लिंक (छवि) से दूर चला जाता है तो ईवेंट हैंडलर चालू हो जाता है।
जब माउस छवि पर चला जाता है, तो HTTP छवि पहली छवि से दूसरे एक में बदल जाती है। जब माउस को छवि से दूर ले जाया जाता है, तो मूल छवि प्रदर्शित होती है।
जब माउस लिंक से दूर ले जाया जाता है, तो प्रारंभिक छवि html.gif स्क्रीन पर फिर से दिखाई देगा।
<html>
<head>
<title>Rollover with a Mouse Events</title>
<script type = "text/javascript">
<!--
if(document.images) {
var image1 = new Image();
// Preload an image image1.src = "/images/html.gif";
var image2 = new Image();
// Preload second image image2.src = "/images/http.gif";
}
//
-->
</script>
</head>
<body>
<p>Move your mouse over the image to see the result</p>
<a href = "#" onMouseOver = "document.myImage.src = image2.src;"
onMouseOut = "document.myImage.src = image1.src;">
<img name = "myImage" src = "/images/html.gif" />
</a>
</body>
</html>