के कैनवास के अंदर कैनवास क्या हम मौजूदा कैनवास के अंदर कैनवास लगा सकते हैं? अगर हम कर सकते हैं, तो कृपया इसे html5 में करने में मदद करें।एचटीएमएल 5
उत्तर
आपके प्रश्न की व्याख्या करने के दो संभावित तरीके हैं। एक यह है कि आप का मतलब है वास्तव में घोंसला canvas
तत्वों खुद को, इस तरह के:
<canvas id="outer">
<canvas id="inner"></canvas>
</canvas>
यह (validator.nu के अनुसार) कानूनी है, लेकिन व्यर्थ। canvas
तत्व के अंदर सामग्री फ़ॉलबैक के लिए है। canvas
तत्व के अंदर सामग्री का उपयोग करने का एकमात्र तरीका यह है कि यदि ब्राउज़र canvas
का समर्थन नहीं करता है, तो इस स्थिति में आंतरिक canvas
तत्व वैसे भी नहीं देखा जाएगा।
आपके प्रश्न की व्याख्या करने का दूसरा संभावित तरीका यह है कि आप एक कैनवास पर दिखाए गए चित्र को दूसरे के भीतर प्रदर्शित कर सकते हैं। यह काफी सरल है, canvas
तत्व को context.drawImage()
पर पहले पैरामीटर के रूप में उपयोग किया जा सकता है। आप दो canvas
तत्वों है:
<canvas id="c1" width="200" height="200"></canvas>
<canvas id="c2" width="200" height="200"></canvas>
फिर this script (using jQuery) पहले canvas
पर आकर्षित करेगा और फिर दूसरी canvas
के लिए एक छवि के रूप में है कि चार बार जोड़ें:
var c1 = $('#c1');
var ctx1 = c1[0].getContext('2d');
ctx1.fillRect(50,50,100,100);
var c2 = $('#c2');
var ctx2 = c2[0].getContext('2d');
ctx2.drawImage(c1[0],0,0,100,100);
ctx2.drawImage(c1[0],100,0,100,100);
ctx2.drawImage(c1[0],0,100,100,100);
ctx2.drawImage(c1[0],100,100,100,100);
लेकिन फिर, आप क्यों करेंगे? आप just using one ऊपर दूसरा canvas
की छवि को दोहराने कर सकते हैं:
var c1 = $('#c1');
var ctx1 = c1[0].getContext('2d');
ctx1.fillRect(25,25,50,50);
ctx1.fillRect(125,25,50,50);
ctx1.fillRect(25,125,50,50);
ctx1.fillRect(125,125,50,50);
तो सारांश में: हाँ, यह संभव है, लेकिन यह सरल प्रयोग में वास्तव में आवश्यक नहीं है।
दूसरे कैनवास का उपयोग करने के लिए बहुत सारे (स्वीकार्य रूप से गैर-तुच्छ) कारण हैं। उदाहरण के लिए, ग्राफ़ को अन्य ऑफस्क्रीन कैनवास में कॉपी करके, मुख्य कैनवास को साफ़ करके, और फिर ऑफस्क्रीन कैनवास को बाएं से एक पिक्सल तक ऑफ़सेट करना और गायब कॉलम में नया डेटा खींचकर सबसे आसान किया जाता है। (यह केवल तभी जरूरी है जब ग्राफ की पृष्ठभूमि पारदर्शी हो।) – Phrogz
@Phrogz हां, विभिन्न छवि प्रसंस्करण चीजें भी। लेकिन मैं अपने "यह सरल उपयोग में वास्तव में जरूरी नहीं है" से खड़ा है, मुझे नहीं लगता कि इनमें से कोई भी सामान इस प्रश्न या इस उत्तर से प्रासंगिक है। – robertc
शायद नहीं, लेकिन एक नवागंतुक आपका शब्द यह कहने के लिए ले सकता है कि यह अत्यधिक है, जब यह अक्सर कुछ करने के लिए neater और अधिक इष्टतम तरीका होता है। यदि आपके पास स्थैतिक तत्वों (कहें, एक गेम) के साथ एक बदलते कैनवास हैं, तो इस तकनीक के लिए बड़े पैमाने पर प्रदर्शन लाभ हैं - आपको केवल एक बार कैनवास में बिटमैप/वैक्टरों को आकर्षित करने की आवश्यकता है, फिर अपडेट करते समय इसे मुख्य रूप से खींचें। हालांकि अच्छे जवाब के लिए +1। – MickMalone1983
यह किसी अन्य कैनवास के अंदर एक कैनवास घोंसला करने के लिए बिल्कुल व्यर्थ होगा। पृष्ठ केवल canvas
टैग के अंदर क्या देखता है यदि ब्राउज़र canvas
का समर्थन नहीं करता है।
<canvas id="background">fallbacks/polyfills go in here...</canvas> <canvas id="foreground">.. or here, but not other canvases.</canvas>
- 1. एचटीएमएल 5 बॉयलरप्लेट बनाम एचटीएमएल 5 रीसेट
- 2. एचटीएमएल 5
- 3. एचटीएमएल 5
- 4. एचटीएमएल 5
- 5. एचटीएमएल 5
- 6. एचटीएमएल 5
- 7. एचटीएमएल 5
- 8. एचटीएमएल 5
- 9. एचटीएमएल 5
- 10. एचटीएमएल 5
- 11. एचटीएमएल 5
- 12. एचटीएमएल 5
- 13. एचटीएमएल 5
- 14. एचटीएमएल 5
- 15. एचटीएमएल 5
- 16. एचटीएमएल 5
- 17. एचटीएमएल 5
- 18. एचटीएमएल 5
- 19. एचटीएमएल 5
- 20. एचटीएमएल 5
- 21. एचटीएमएल 5
- 22. एचटीएमएल 5
- 23. एचटीएमएल 5
- 24. एचटीएमएल 5
- 25. एचटीएमएल 5
- 26. एचटीएमएल 5
- 27. एचटीएमएल 5
- 28. एचटीएमएल 5
- 29. एचटीएमएल 5
- 30. एचटीएमएल 5
क्या आप वास्तव में पूरा करने के लिए कोशिश कर रहे हैं के रूप में और विवरण प्रदान करें: तो, बस क्या robertc कहा है। – Phrogz