के साथ आकार बदलने योग्य एसवीजी तत्व किसी भी जेएस कोड को जानते हैं जो उपयोगकर्ता द्वारा निर्धारित विंडो के आकार के आधार पर svg तत्व (पूरी सामग्री भी) को आकार देने की अनुमति देगा। मेरे उपयोगकर्ता अपने सक्रिय डेस्कटॉप पर एक छोटे से अनुकूलित दृश्य में डी 3 ग्राफिक्स देखना चाहते हैं। जबकि साथ ही अन्य लोग अपने सक्रिय डेस्कटॉप पर पूर्ण स्क्रीन चलाएंगे। इसका मतलब है कि ग्राफ को उपयोगकर्ताओं की वरीयता के आधार पर स्वयं का आकार बदलने की आवश्यकता होगी।जावास्क्रिप्ट और डी 3
उत्तर
आप पृष्ठ को या आकार बदलने पर एक svg.attr ("width")। Attr ("height") को समायोजित कर सकते हैं, लेकिन d3 तत्वों को बदलने के लिए आपको अपने कोड में अतिरिक्त व्यवहार की आवश्यकता होगी नया आकार
तुम भी एक svg वस्तु की .viewBox विशेषता है, जो गतिशील svg तत्वों स्केल करेगा गौर कर सकते हैं, लेकिन मैं मिल गया है विभिन्न ब्राउज़रों के बीच अपने व्यवहार को असमान होने के लिए:
मैं कुछ दिन पहले इस वांछित व्यवहार के एक डेमो को एक साथ रखो। इसे यहां देखें - http://bl.ocks.org/4444770
असल में, आप खिड़की के आकार को सुनते हैं, जी तत्व में आनुपातिक परिवर्तन लागू करते हैं जो सभी एसवीजी तत्वों को लपेटता है, और माता-पिता एसवीजी के आकार को समायोजित करता है। pageload पर और विंडो आकार परिवर्तन, जहां "कंटेनर" div एसवीजी पकड़े है पर इस कोड को कॉल करें:
d3.select("g").attr("transform", "scale(" + $("#container").width()/900 + ")");
$("svg").height($("#container").width()*0.618);
यह एक अच्छा तरीका है अगर आपके एसवीजी एक div भीतर रखा जाता है।
दूसरा तरीका एसवीजी व्यूबॉक्स का उपयोग करना है, जैसा कि माइक Bostock द्वारा दिखाया गया है - http://bl.ocks.org/harlantwood/raw/6900108/। यह विधि सर्वोत्तम है यदि आप शरीर को एसवीजी जोड़ रहे हैं, और मुझे यकीन है कि एसवीजी को एक div के अंदर रखकर इस विधि का उपयोग करने का कोई तरीका है, लेकिन मैं समाधान खोजने में असमर्थ था, और इस प्रकार उपरोक्त बनाया चारों ओर काम करो।
- 1. ज़ेंड_Mail और = 0 डी = 0 ए = 3 डी = 3 डी = 3 डी = 3 डी = 3 डी
- 2. डी 3 जावास्क्रिप्ट विज़ुअलाइजेशन
- 3. डी 3 जावास्क्रिप्ट लाइब्रेरी
- 4. इसे जावास्क्रिप्ट (डी 3 लाइब्रेरी)
- 5. डी 3 जावास्क्रिप्ट वैकल्पिक रंग
- 6. क्रॉसफिल्टर और डी 3
- 7. डी 3
- 8. डी 3
- 9. डी 3
- 10. जावास्क्रिप्ट लाइब्रेरी डी 3 कॉल फ़ंक्शन
- 11. डी 3 जावास्क्रिप्ट फोरैच के बीच अंतर और प्रत्येक
- 12. छवि मान्यता और 3 डी
- 13. डी 3: सॉर्ट और आरोही
- 14. डी 3 ट्रांसफॉर्म स्केल और
- 15. 3 डी
- 16. डी 3
- 17. डी 3
- 18. 3 डी
- 19. 3 डी
- 20. डी 3
- 21. 3 डी?
- 22. यूनिट 3 डी
- 23. डी 3 डी 9 हुक - डायरेक्ट 3 डी 9
- 24. 3 डी
- 25. डी 3
- 26. डी 3
- 27. डी 3
- 28. 3 डी
- 29. डी 3
- 30. 3 डी
यह सुनिश्चित नहीं है कि आप इसे डी 3 में कैसे करते हैं लेकिन राफेल आसानी से एसवीजी को स्केल कर सकता है, यहां एक नज़र डालें: http://stackoverflow.com/questions/4322660/scaling-svg-raphael-js-like-an-swf – Richard