टेक्स्ट रेंज का इस्तेमाल करके, टेक्स्ट में बदलाव किया जा सकता है और उसे स्टाइल किया जा सकता है. टेक्स्ट रेंज को TextRange
टाइप से दिखाया जाता है. TextRange
, किसी शेप या टेबल सेल में मौजूद टेक्स्ट के सेगमेंट को दिखाता है. किसी शेप या टेबल सेल पर getText()
को कॉल करने पर, टेक्स्ट की ऐसी रेंज मिलती है जिसमें पूरा टेक्स्ट शामिल होता है.
अगर टेक्स्ट को किसी शेप में फ़िट करने के लिए, ऐसे तरीकों का इस्तेमाल किया जाता है जिनसे टेक्स्ट में बदलाव होता है, तो शेप पर लागू की गई सभी ऑटोफ़िट सेटिंग बंद हो जाती हैं.
टेक्स्ट रेंज का इस्तेमाल करना
किसी टेक्स्ट रेंज में दो इंडेक्स होते हैं. ये इंडेक्स, टेक्स्ट के उस सेगमेंट को अलग करते हैं जिसे टेक्स्ट रेंज में शामिल किया गया है: स्टार्ट इंडेक्स और एंड इंडेक्स. getStartIndex()
और getEndIndex()
फ़ंक्शन का इस्तेमाल करके, इन इंडेक्स का पता लगाया जा सकता है.
किसी टेक्स्ट रेंज का कॉन्टेंट पढ़ने के लिए, asString()
या
asRenderedString()
फ़ंक्शन का इस्तेमाल करें.
किसी टेक्स्ट रेंज में से सबरेंज को वापस पाने के लिए, getRange()
फ़ंक्शन का इस्तेमाल करें.
नीचे दी गई स्क्रिप्ट, पहली स्लाइड पर एक टेक्स्ट बॉक्स बनाती है और उसके टेक्स्ट कॉन्टेंट को "Hello world!" पर सेट करती है. इसके बाद, यह सिर्फ़ "Hello" वाले सब-रेंज को वापस लाता है.
किसी शेप या टेबल सेल से मिली टेक्स्ट रेंज में हमेशा पूरा टेक्स्ट शामिल होगा. भले ही, टेक्स्ट डाला और मिटाया गया हो. इसलिए, ऊपर दिए गए उदाहरण से ये लॉग स्टेटमेंट जनरेट होते हैं:
Start: 0; End: 13; Content: Hello world! Start: 0; End: 5; Content: Hello
टेक्स्ट डालना और मिटाना
टेक्स्ट रेंज का इस्तेमाल करके, टेक्स्ट शेप और टेबल सेल भी डाली और मिटाई जा सकती हैं.
insertText()
औरappendText()
की मदद से, टेक्स्ट डाला जा सकता है.setText()
, टेक्स्ट रेंज के टेक्स्ट को दिए गए टेक्स्ट से बदलता है.clear()
, टेक्स्ट रेंज में मौजूद टेक्स्ट को मिटाता है.
यहां दी गई स्क्रिप्ट में, इन फ़ंक्शन के इस्तेमाल के बारे में बताया गया है:
यह स्क्रिप्ट, पहली स्लाइड पर एक टेक्स्ट बॉक्स बनाती है और उसके टेक्स्ट कॉन्टेंट को "Hello world!" पर सेट करती है. इसके बाद, यह छठे से 11वें वर्ण ("world") को मिटा देता है और इसकी जगह पर इंडेक्स 6 पर "galaxy" टेक्स्ट डाल देता है. ऊपर दिए गए उदाहरण से, यह लॉग स्टेटमेंट जनरेट होता है:
Start: 0; End: 14; Content: Hello galaxy!
ढूंढें और बदलें
पूरी प्रज़ेंटेशन या किसी पेज में 'ढूंढें और बदलें' सुविधा का इस्तेमाल करने के लिए, प्रज़ेंटेशन या पेज पर replaceAllText()
फ़ंक्शन का इस्तेमाल करें.
TextRange पर मौजूद find()
फ़ंक्शन, रेंज में मौजूद किसी स्ट्रिंग के इंस्टेंस दिखाता है. इसका इस्तेमाल setText()
के साथ किया जा सकता है. इससे किसी शेप या टेबल सेल में, ढूंढें और बदलें की सुविधा का इस्तेमाल किया जा सकता है.
पैराग्राफ़, सूची के आइटम, और रन
TextRange
, टेक्स्ट इकाइयों के काम के कलेक्शन दिखाने वाले फ़ंक्शन उपलब्ध कराता है.
इनमें से कुछ फ़ंक्शन ये हैं:
getParagraphs(),
, जो टेक्स्ट रेंज से ओवरलैप होने वाले सभी पैराग्राफ़ उपलब्ध कराता है. पैराग्राफ़, टेक्स्ट का एक क्रम होता है. यह नई लाइन वाले वर्ण "\n" पर खत्म होता है.getListParagraphs(),
, जो मौजूदा टेक्स्ट रेंज में सूची के आइटम दिखाता है.getRuns(),
जो मौजूदा टेक्स्ट रेंज से ओवरलैप होने वाले टेक्स्ट रन उपलब्ध कराता है. टेक्स्ट रन, टेक्स्ट का एक ऐसा सेगमेंट होता है जिसमें सभी वर्णों का टेक्स्ट स्टाइल एक जैसा होता है.
टेक्स्ट स्टाइलिंग
टेक्स्ट स्टाइल से, आपकी प्रज़ेंटेशन में टेक्स्ट के वर्णों को रेंडर करने का तरीका तय होता है. इसमें फ़ॉन्ट, रंग, और हाइपरलिंकिंग शामिल है.
टेक्स्ट रेंज का getTextStyle()
फ़ंक्शन, TextStyle
ऑब्जेक्ट उपलब्ध कराता है. इसका इस्तेमाल टेक्स्ट को स्टाइल करने के लिए किया जाता है. TextStyle
ऑब्जेक्ट में मौजूद टेक्स्ट, उसके पैरंट TextRange
ऑब्जेक्ट में मौजूद टेक्स्ट के जैसा ही है.
ऊपर दिए गए उदाहरण में, सबसे पहले पहली स्लाइड पर एक टेक्स्ट बॉक्स बनाया गया है. इसके बाद, उसके कॉन्टेंट को "Hello " पर सेट किया गया है. इसके बाद, "world!" टेक्स्ट जोड़ा गया है. नया जोड़ा गया टेक्स्ट बोल्ड किया गया है. इसे www.example.com
से लिंक किया गया है और इसका रंग लाल पर सेट किया गया है.
स्टाइल पढ़ते समय, अगर रेंज में स्टाइल के लिए एक से ज़्यादा वैल्यू मौजूद हैं, तो फ़ंक्शन शून्य दिखाता है. इसलिए, ऊपर दिया गया सैंपल, लॉग स्टेटमेंट जनरेट करता है:
Text: Hello; Bold: false Text: world!; Bold: true Text: Hello world!; Bold: null
टेक्स्ट पर कई अन्य स्टाइल भी लागू की जा सकती हैं. ज़्यादा जानकारी के लिए, TextStyle
रेफ़रंस दस्तावेज़ देखें.
पैराग्राफ़ की स्टाइलिंग
पैराग्राफ़ की स्टाइल पूरे पैराग्राफ़ पर लागू होती हैं. इनमें टेक्स्ट अलाइनमेंट और लाइन स्पेसिंग जैसी चीज़ें शामिल होती हैं. TextRange
में मौजूद getParagraphStyle() फ़ंक्शन, पैरंट टेक्स्ट रेंज में शामिल सभी पैराग्राफ़ को स्टाइल करने के लिए ParagraphStyle
ऑब्जेक्ट उपलब्ध कराता है.
नीचे दिए गए उदाहरण में, पहली स्लाइड पर चार पैराग्राफ़ वाला एक टेक्स्ट बॉक्स बनाया गया है. इसके बाद, पहले तीन पैराग्राफ़ को बीच में अलाइन किया गया है.
सूची की स्टाइलिंग
ParagraphStyle
की तरह ही, ListStyle
का इस्तेमाल उन सभी पैराग्राफ़ को स्टाइल करने के लिए किया जा सकता है जो पैरंट टेक्स्ट रेंज से ओवरलैप करते हैं.
ऊपर दिए गए उदाहरण में, पहली स्लाइड पर एक टेक्स्ट बॉक्स बनाया गया है. इसमें चार पैराग्राफ़ हैं: दूसरे पैराग्राफ़ में एक बार और तीसरे पैराग्राफ़ में दो बार इंडेंट किया गया है. इसके बाद, यह सभी पैराग्राफ़ पर सूची का प्रीसेट लागू करता है. आखिर में, हर पैराग्राफ़ के नेस्टिंग लेवल को लॉग किया जाता है. (पैराग्राफ़ का नेस्टिंग लेवल, पैराग्राफ़ के टेक्स्ट से पहले मौजूद टैब की संख्या से तय होता है.) इसलिए, ऊपर दी गई स्क्रिप्ट से ये लॉग स्टेटमेंट जनरेट होते हैं:
Paragraph 1's nesting level: 0 Paragraph 2's nesting level: 1 Paragraph 3's nesting level: 2 Paragraph 4's nesting level: 0