अपाचे POI पीपीटी - त्वरित गाइड

कई बार, Microsoft Office फ़ाइल प्रारूप में रिपोर्ट बनाने के लिए एक सॉफ़्टवेयर एप्लिकेशन की आवश्यकता होती है। कभी-कभी, एक एप्लिकेशन को इनपुट डेटा के रूप में एमएस-ऑफिस फ़ाइलों को प्राप्त करने की अपेक्षा की जाती है।

कोई भी जावा प्रोग्रामर जो उत्पादन के रूप में एमएस ऑफिस फ़ाइलों का उत्पादन करना चाहता है, उसे ऐसा करने के लिए पूर्वनिर्धारित और केवल पढ़ने के लिए एपीआई का उपयोग करना चाहिए।

Apache POI क्या है?

Apache POI एक लोकप्रिय एपीआई है जो प्रोग्रामर को जावा प्रोग्राम का उपयोग करके MS-Office फ़ाइलों को बनाने, संशोधित करने और प्रदर्शित करने की अनुमति देता है। यह अपाचे सॉफ्टवेयर फाउंडेशन द्वारा विकसित और वितरित एक खुला स्रोत पुस्तकालय है। इसमें उपयोगकर्ता इनपुट डेटा, या MS Office दस्तावेज़ों में फ़ाइल को डीकोड करने के लिए कक्षाएं और विधियाँ शामिल हैं।

अपाचे POI के घटक

Apache POI में MS-Office के सभी OLE2 यौगिक दस्तावेज़ों पर काम करने के लिए कक्षाएं और विधियाँ शामिल हैं। इस एपीआई के घटकों की सूची नीचे दी गई है -

  • POIFS (Poor Obfuscation Implementation File System)- यह घटक अन्य सभी POI तत्वों का मूल कारक है। इसका उपयोग विभिन्न फ़ाइलों को स्पष्ट रूप से पढ़ने के लिए किया जाता है।

  • HSSF (Horrible SpreadSheet Format) - इसका उपयोग MS-Excel फ़ाइलों के .xls प्रारूप को पढ़ने और लिखने के लिए किया जाता है।

  • XSSF (XML SpreadSheet Format) - यह MS-Excel के .xlsx फ़ाइल स्वरूप के लिए उपयोग किया जाता है।

  • HPSF (Horrible Property Set Format) - इसका उपयोग MS-Office फ़ाइलों के गुण सेट निकालने के लिए किया जाता है।

  • HWPF (Horrible Word Processor Format) - इसका उपयोग पढ़ने और लिखने के लिए किया जाता है .doc MS-Word की एक्सटेंशन फ़ाइलें।

  • XWPF (XML Word Processor Format) - इसका उपयोग MS-Word की .docx एक्सटेंशन फ़ाइलों को पढ़ने और लिखने के लिए किया जाता है।

  • HSLF (Horrible Slide Layout Format) - इसका उपयोग PowerPoint प्रस्तुतियों को पढ़ने, बनाने और संपादित करने के लिए किया जाता है।

  • HDGF (Horrible DiaGram Format) - इसमें MS-Visio बाइनरी फ़ाइलों के लिए कक्षाएं और विधियाँ शामिल हैं।

  • HPBF (Horrible PuBlisher Format) - इसका उपयोग MS-Publisher फ़ाइलों को पढ़ने और लिखने के लिए किया जाता है।

यह ट्यूटोरियल जावा का उपयोग करके Microsoft PowerPoint प्रस्तुति पर काम करने की प्रक्रिया के माध्यम से आपका मार्गदर्शन करता है। इसलिए चर्चा तक ही सीमित हैXSLF component.

Note - POI के पुराने संस्करण द्विआधारी फ़ाइल स्वरूपों जैसे doc, xls, ppt, आदि का समर्थन करते हैं। संस्करण 3.5 इसके बाद के संस्करण, POI MS-Office के OOXML फ़ाइल स्वरूपों का समर्थन करता है जैसे docx, xlsx, pptx, आदि।

यह अध्याय आपको जावा पावरपॉइंट एपीआई के कुछ जायके और उनकी विशेषताओं के माध्यम से ले जाता है। कई विक्रेता हैं जो जावा पीपीटी से संबंधित एपीआई प्रदान करते हैं; उनमें से कुछ को इस अध्याय में माना जाता है।

जावा के लिए एसोसाइड स्लाइड्स

जावा के लिए एसॉन्ड स्लाइड्स विशुद्ध रूप से लाइसेंस प्राप्त जावा पीपीटी एपीआई है, जिसे वेंडर द्वारा विकसित और वितरित किया जाता है Aspose। इस एपीआई का नवीनतम संस्करण 8.1.2 है, जो जुलाई 2014 में जारी किया गया था। यह पीपीटी घटक को पढ़ने, लिखने और प्रबंधित करने के लिए एक समृद्ध और भारी एपीआई (सादे जावा कक्षाओं और AWT कक्षाओं का संयोजन) है, जो स्लाइड्स को पढ़, लिख और प्रबंधित कर सकता है।

इस एपीआई के सामान्य उपयोग इस प्रकार हैं -

  • गतिशील प्रस्तुतियों का निर्माण
  • उच्च-निष्ठा प्रस्तुतियों को प्रस्तुत करना और प्रिंट करना
  • प्रस्तुतियाँ बनाएं, संपादित करें, रूपांतरित करें और प्रिंट करें

अपाचे POI

Apache POI, Apache Software Foundation द्वारा प्रदान की जाने वाली एक 100% ओपन सोर्स लाइब्रेरी है। अधिकांश छोटे और मध्यम स्तर के एप्लिकेशन डेवलपर्स Apache POI (HSLF + XSLF) पर बहुत अधिक निर्भर करते हैं। यह पीपीटी पुस्तकालयों की सभी बुनियादी सुविधाओं का समर्थन करता है; हालाँकि, प्रतिपादन और पाठ निष्कर्षण इसकी मुख्य विशेषताएं हैं। नीचे दिए गए पीपीटी के लिए अपाचे POI की वास्तुकला है।

यह अध्याय आपको विंडोज और लिनक्स आधारित सिस्टम पर अपाचे POI स्थापित करने की प्रक्रिया के माध्यम से ले जाता है। अपाचे POI आसानी से स्थापित किया जा सकता है और अपने वर्तमान जावा वातावरण के साथ एकीकृत किया जा सकता है, बिना किसी जटिल सेटअप प्रक्रियाओं के कुछ सरल चरणों का पालन कर। स्थापना के लिए उपयोगकर्ता प्रशासन आवश्यक है।

सिस्टम आवश्यकताएं

JDK जावा एसई 2 जेडडीके 1.5 या इसके बाद के संस्करण
याद 1 जीबी रैम (अनुशंसित)
डिस्क में जगह कोई न्यूनतम आवश्यकता नहीं
ऑपरेटिंग सिस्टम संस्करण विंडोज एक्सपी या उससे ऊपर, लिनक्स

चलिए अब Apache POI को स्थापित करने के चरणों के साथ आगे बढ़ते हैं।

चरण 1: अपने जावा इंस्टॉलेशन को सत्यापित करें

सबसे पहले, आपको अपने सिस्टम पर जावा सॉफ्टवेयर डेवलपमेंट किट (एसडीके) इंस्टॉल करना होगा। इसे सत्यापित करने के लिए, आप जिस प्लेटफ़ॉर्म पर काम कर रहे हैं, उसके आधार पर निम्नलिखित दो कमांड्स में से किसी को निष्पादित करें।

यदि जावा इंस्टॉलेशन ठीक से किया गया है, तो यह आपके जावा इंस्टॉलेशन के वर्तमान संस्करण और विनिर्देश को प्रदर्शित करेगा। निम्न तालिका में एक नमूना आउटपुट दिया गया है।

मंच आदेश नमूना आउटपुट
खिड़कियाँ

कमांड कंसोल खोलें और टाइप करें -

\>java –version

जावा संस्करण "1.7.0_60"

जावा (टीएम) एसई रन टाइम

पर्यावरण (बिल्ड 1.7.0_60-b19)

जावा हॉटस्पॉट (टीएम) 64-बिट सर्वर

VM (बिल्ड 24.60-b09, मिश्रित मोड)

लिनक्स

ओपन कमांड टर्मिनल और प्रकार -

$java –version

जावा संस्करण "1.7.0_25"

ओपन JDK रनटाइम एनवायरनमेंट (rhel-2.3.10.4.el6_4-x86_64)

ओपन JDK 64-बिट सर्वर VM (बिल्ड 23.7-b01, मिश्रित मोड)

  • हम मानते हैं कि इस ट्यूटोरियल के पाठकों के पास अपने सिस्टम पर जावा एसडीके संस्करण 1.7.0_60 स्थापित है।

  • यदि आपके पास जावा एसडीके नहीं है, तो इसका वर्तमान संस्करण डाउनलोड करें https://www.oracle.com/technetwork/java/javase/downloads/index.html और इसे स्थापित करें।

चरण 2: अपने जावा पर्यावरण सेट करें

वातावरण चर JAVA_HOME को आधार निर्देशिका स्थान पर इंगित करने के लिए सेट करें जहाँ जावा आपकी मशीन पर स्थापित है। उदाहरण के लिए,

मंच विवरण
खिड़कियाँ JAVA_HOME को C: \ ProgramFiles \ java \ jdk1.7.0_60 पर सेट करें
लिनक्स निर्यात JAVA_HOME = / usr / स्थानीय / जावा-वर्तमान

जावा कंपाइलर स्थान का पूरा पथ सिस्टम पथ में जोड़ें।

मंच विवरण
खिड़कियाँ स्ट्रिंग "C: \ Program Files \ Java \ jdk1.7.0_60 \ bin" सिस्टम चर पथ के अंत में जोड़ें।
लिनक्स निर्यात पाथ = $ पाथ: $ जाव_होम / बिन /

आदेश निष्पादित करें java -version ऊपर बताए अनुसार कमांड प्रॉम्प्ट से।

चरण 3: Apache POI लाइब्रेरी स्थापित करें

Apache POI का नवीनतम संस्करण डाउनलोड करें https://poi.apache.org/download.htmlऔर इसकी सामग्री को एक फ़ोल्डर में अनज़िप करें जहां से आवश्यक पुस्तकालयों को आपके जावा प्रोग्राम से जोड़ा जा सकता है। आइए मान लेते हैं कि फाइलें सी ड्राइव पर एक फ़ोल्डर में एकत्र की गई हैं।

निम्नलिखित छवियां निर्देशिका और डाउनलोड किए गए फ़ोल्डर के अंदर फ़ाइल संरचनाएं दिखाती हैं -

पाँच का पूरा रास्ता जोड़ें jars जैसा कि ऊपर चित्र में CLASSPATH पर प्रकाश डाला गया है।

मंच विवरण
खिड़कियाँ

उपयोगकर्ता चर CLASSPATH के अंत में निम्नलिखित तार जोड़ें -

"C: \ poi-3.9 \ poi-3.9-20121203.jar,"

"C: \ poi-3.9 \ poi-OOXML- 3.9-20121203.jar,"

"C: \ poi-3.9 \ poi-OOXML- स्कीमा-3.9-20121203.jar,"

"C: \ poi-3.9 \ OOXML-lib \ dom4j-1.6.1.jar,"

"C: \ poi-3.9 \ OOXML-lib \ xmlbeans-2.3.0.jar;।"

लिनक्स

निर्यात CLASSPATH = $ CLASSPATH:

/usr/share/poi-3.9/poi-3.9-20121203.tar:

/usr/share/poi-3.9/poi-ooxml-schemas-3.9-20121203.tar:

/usr/share/poi-3.9/poi-ooxml-3.9-20121203.tar:

/usr/share/poi-3.9/ooxml-lib/dom4j-1.6.1.tar:

/usr/share/poi-3.9/ooxml-lib/xmlbeans-2.3.0.tar

pom.xml

इस ट्यूटोरियल में प्रोग्राम चलाने के लिए pom.xml फाइल है।

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
   <modelVersion>4.0.0</modelVersion>
   <groupId>ApachePoiPPT</groupId>
   <artifactId>ApachePoiPPT</artifactId>
   <version>0.0.1-SNAPSHOT</version>
   <build>
      <sourceDirectory>src</sourceDirectory>
      <plugins>
         <plugin>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.5.1</version>
            <configuration>
               <source>1.8</source>
               <target>1.8</target>
            </configuration>
         </plugin>
      </plugins>
   </build>
   <dependencies>  
      <dependency>
         <groupId>org.apache.poi</groupId>
         <artifactId>poi</artifactId>
         <version>3.9</version>
      </dependency>
      <dependency>
         <groupId>org.apache.poi</groupId>
         <artifactId>poi-ooxml</artifactId>
         <version>3.9</version>
      </dependency>    
   </dependencies>
</project>

इस अध्याय में, हम Apache POI API के तहत कुछ वर्गों और विधियों के बारे में जानेंगे जो जावा कार्यक्रमों का उपयोग करके PPT फ़ाइलों पर काम करने के लिए महत्वपूर्ण हैं।

प्रस्तुतीकरण

बना सकते हैं और एक प्रस्तुति का प्रबंधन करने के लिए, आप एक वर्ग पैकेज में XMLSlideShow कहा जाता है org.apache.poi.xslf.usermodel । नीचे दिए गए कुछ महत्वपूर्ण तरीके और इस वर्ग के एक निर्माता हैं।

Class - XMLSlideShow

Package - org.apache.poi.xslf.usermodel

S.No कंस्ट्रक्टर और विवरण
1

XMLSlideShow(java.io.InputStream inputStream)

आप एक इनपुटस्ट्रीम क्लास ऑब्जेक्ट को पास करके इस क्लास को इंस्टेंट कर सकते हैं।

S.No तरीके और विवरण
1

int addPicture (byte[] pictureData, int format)

इस पद्धति का उपयोग करके, आप एक प्रस्तुति में एक चित्र जोड़ सकते हैं।

2

XSLFSlide createSlide()

एक प्रस्तुति में एक खाली स्लाइड बनाता है।

3

XSLFSlide createSlide(XSLFSlideLayout layout)

किसी दिए गए स्लाइड लेआउट के साथ एक स्लाइड बनाता है।

4

java.util.List <XSLFPictureData> getAllPictures()

एक प्रस्तुति में सभी चित्रों की एक सरणी देता है।

5

java.awt.Dimension getPageSize()

इस विधि का उपयोग करके, आप वर्तमान पृष्ठ का आकार जान सकते हैं।

6

XSLFSlideMaster[] getSlideMasters()

किसी प्रस्तुति में सभी स्लाइड्स की सरणी देता है।

7

XSLFSlide[] getSlides()

एक प्रस्तुति में सभी स्लाइड देता है।

8

XSLFSlide removeSlide(int index)

इस पद्धति का उपयोग करके, आप एक प्रस्तुति से एक स्लाइड को हटा सकते हैं।

9

void setPageSize(java.awt.Dimension pgSize)

इस पद्धति का उपयोग करके, आप पृष्ठ आकार को रीसेट कर सकते हैं।

10

void setSlideOrder(XSLFSlide slide, int newIndex)

इस पद्धति का उपयोग करके, आप स्लाइड्स को फिर से व्यवस्थित कर सकते हैं।

फिसल पट्टी

एक प्रस्तुति में एक स्लाइड बनाने और प्रबंधित करने के लिए, के तरीके XSLFSlideवर्ग का उपयोग किया जाता है। इस वर्ग के कुछ महत्वपूर्ण तरीकों का उल्लेख नीचे किया गया है।

Class - XSLFSlide

Package - org.apache.poi.xslf.usermodel

S.No विधि और विवरण
1

XSLFBackground getBackground()

लौटता है XSLFBackgroundऑब्जेक्ट जिसका उपयोग स्लाइड की पृष्ठभूमि के रंग और लंगर जैसे विवरण प्राप्त करने के लिए किया जा सकता है। आप इस ऑब्जेक्ट का उपयोग करके स्लाइड में आकृतियाँ भी बना सकते हैं।

2

XSLFSlideLayout getSlideLayout()

तक पहुँच प्रदान करता है XSLFSlideLayout वर्तमान स्लाइड का उद्देश्य।

3

XSLFSlideMaster getSlideMaster()

वर्तमान स्लाइड के स्लाइड मास्टर तक पहुंच प्रदान करता है।

4

XSLFTheme getTheme()

लौटता है XSLFTheme वर्तमान स्लाइड का उद्देश्य।

5

java.lang.String getTitle()

वर्तमान स्लाइड का शीर्षक लौटाता है।

6

XSLFSlide importContent(XSLFSheet src)

इस स्लाइड में एक और स्लाइड की सामग्री की प्रतिलिपि बनाता है।

फिसलने का गुरु

यह विभिन्न स्लाइड लेआउट वाली प्रस्तुति का घटक है। XSLFSlideMasterवर्ग आपको इसकी पहुँच प्रदान करता है। नीचे उल्लेखित इस वर्ग के कुछ महत्वपूर्ण तरीके हैं।

Class - XSLFSlideMaster

Package - org.apache.poi.xslf.usermodel

S.No विधि और विवरण
1

XSLFBackground getBackground()

स्लाइड मास्टर की सामान्य पृष्ठभूमि देता है।

2

XSLFSlideLayout getLayout(SlideLayout type)

XSLFSlideLayout ऑब्जेक्ट लौटाता है।

3

XSLFSlideLayout[] getSlideLayouts()

इस स्लाइड मास्टर में सभी स्लाइड लेआउट देता है।

स्लाइड लेआउट

POI पुस्तकालय में एक वर्ग होता है जिसे कहा जाता है XSLFSlideLayout, जिसके उपयोग से आप स्लाइड के लेआउट का प्रबंधन कर सकते हैं।

Class - XSLFSlideLayout

Package - org.apache.poi.xslf.usermodel

S.No विधि और विवरण
1

void copyLayout(XSLFSlide slide)

यह पद्धति इस लेआउट से प्लेसहोल्डर्स को दिए गए स्लाइड में कॉपी कर देगी।

पाठ पैराग्राफ

आप स्लाइड का उपयोग करके सामग्री लिख सकते हैं XSLFTextParagraphकक्षा। नीचे इस वर्ग के कुछ महत्वपूर्ण तरीके दिए गए हैं।

Class - XSLFTextParagraph

Package - org.apache.poi.xslf.usermodel

S.No विधि और विवरण
1

XSLFTextRun addLineBreak()

एक पैराग्राफ में एक लाइन ब्रेक सम्मिलित करता है।

2

XSLFTextRun addNewTextRun()

एक पैराग्राफ में पाठ का एक नया रन जोड़ता है।

3

void setBulletAutoNumber(ListAutoNumber scheme, int startAt)

अनुच्छेद पर स्वचालित क्रमांकित बुलेट बिंदु लागू करता है।

4

void setIndent(double value)

अनुच्छेद में पाठ के लिए इंडेंट सेट करता है।

5

void setLeftMargin(double value)

इस पद्धति का उपयोग पैराग्राफ के बाएं मार्जिन को जोड़ने के लिए किया जाता है।

6

void setLineSpacing(double linespacing)

इस विधि का उपयोग पैराग्राफ में लाइन रिक्ति सेट करने के लिए किया जाता है।

7

void setTextAlign(TextAlign align)

इस पद्धति का उपयोग संरेखण सेट करने के लिए किया जाता है जिसे पैराग्राफ पर सेट किया जाना है।

टेक्स्ट रन

यह एक पाठ निकाय के भीतर पाठ पृथक्करण का निम्नतम स्तर है। आपके पासXSLFTextRunएक पैराग्राफ के पाठ चलाने का प्रबंधन करने के लिए कक्षा। नीचे इस वर्ग के कुछ महत्वपूर्ण तरीके दिए गए हैं।

Class - XSLFTextParagraph

Package - org.apache.poi.xslf.usermodel

S.No विधि और विवरण
1

XSLFHyperlink createHyperlink()

प्रस्तुति में हाइपरलिंक बनाता है।

2

XSLFHyperlink getHyperlink()

हाइपरलिंक प्राप्त करने के लिए इस विधि का उपयोग किया जाता है।

3

java.lang.String getText()

जावा स्ट्रिंग के रूप में इस टेक्स्ट नोड का मान लौटाता है।

4

void setBold(boolean bold)

इस विधि का उपयोग टेक्स्ट को बोल्ड में सेट करने के लिए किया जाता है।

5

void setCharacterSpacing(double spc)

एक पाठ चलाने के भीतर वर्णों के बीच अंतर निर्धारित करता है।

6

void setFontColor(java.awt.Color color)

पाठ का फ़ॉन्ट रंग सेट करता है।

7

void setFontSize(double fontSize)

पाठ का फ़ॉन्ट आकार सेट करता है।

8

void setItalic(boolean italic)

इस पद्धति का उपयोग पैराग्राफ को इटैलिक करने के लिए किया जाता है।

9

void setStrikethrough(boolean strike)

इस विधि का उपयोग स्ट्राइकथ्रू पाठ के रूप में पाठ के रन को प्रारूपित करने के लिए किया जाता है।

10

void setSubscript(boolean flag)

इस विधि का उपयोग टेक्स्ट को सबस्क्रिप्ट के रूप में प्रारूपित करने के लिए किया जाता है।

1 1

void setSuperscript(boolean flag)

इस विधि का उपयोग इस पाठ में सुपरस्क्रिप्ट के रूप में प्रारूपित करने के लिए किया जाता है।

12

void setText(java.lang.String text)

इस विधि का उपयोग पाठ को रन में सेट करने के लिए किया जाता है।

13

void setUnderline(boolean underline)

इस विधि का उपयोग टेक्स्ट रन में टेक्स्ट को रेखांकित करने के लिए किया जाता है।

पाठ का आकार

पीपीटी में, हमारे पास ऐसे आकार होते हैं जो उनके भीतर पाठ को पकड़ सकते हैं। हम इनका उपयोग करके प्रबंधन कर सकते हैंXSLFTextShapeकक्षा। नीचे उल्लेखित इस वर्ग के कुछ महत्वपूर्ण तरीके हैं।

Class - XSLFTextShape

Package - org.apache.poi.xslf.usermodel

S.No विधि और विवरण
1

void setPlaceholder(Placeholder placeholder)

इस पद्धति का उपयोग करके, आप एक स्थान धारक चुन सकते हैं।

2

Placeholder getTextType()

वर्तमान प्लेसहोल्डर का प्रकार लौटाता है।

3

void clearText()

वर्तमान पाठ आकार के पाठ क्षेत्र को साफ़ करता है।

4

XSLFTextParagraph addNewTextParagraph()

एक आकार में एक नया पैराग्राफ जोड़ता है।

5

void drawContent(java.awt.Graphics2D graphics)

यह विधि आपको स्लाइड पर किसी भी सामग्री को खींचने की अनुमति देती है।

हाइपरलिंक

POI पुस्तकालय में एक वर्ग होता है जिसे कहा जाता है XSLFHyperlinkजिसका उपयोग करके आप प्रेजेंटेशन में हाइपरलिंक बना सकते हैं। नीचे उल्लेखित इस वर्ग के कुछ महत्वपूर्ण तरीके हैं।

Class - XSLFHyperlink

Package - org.apache.poi.xslf.usermodel

S.No विधि और विवरण
1

java.net.URI getTargetURL()

प्रस्तुति की स्लाइड में मौजूद URL लौटाता है।

2

void setAddress(java.lang.String address)

इस विधि का उपयोग URL को पता सेट करने के लिए किया जाता है।

3

void setAddress(XSLFSlide slide)

प्रस्तुति के स्लाइड में मौजूद URL पर पता सेट करता है।

आमतौर पर, हम प्रस्तुतियाँ बनाने के लिए MS-PowerPoint का उपयोग करते हैं। अब देखते हैं कि जावा का उपयोग करके प्रस्तुतियाँ कैसे बनाते हैं। इस अध्याय के पूरा होने के बाद, आप अपने जावा प्रोग्राम के साथ नई MS-PowerPoint प्रस्तुतियाँ बना सकते हैं और मौजूदा PPTs खोल सकते हैं।

खाली प्रस्तुति बनाना

एक खाली प्रस्तुति बनाने के लिए, आपको तत्काल करना होगा XMLSlideShoworg.poi.xslf.usermodel पैकेज का वर्ग -

XMLSlideShow ppt = new XMLSlideShow();

PPT डॉक्यूमेंट में बदलावों को सेव करें FileOutputStream वर्ग -

File file = new File("C://POIPPT//Examples//example1.pptx");
FileOutputStream out = new FileOutputStream(file);
ppt.write(out);

खाली MS-PowerPoint प्रस्तुति बनाने का पूरा कार्यक्रम नीचे दिया गया है।

import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;

public class CreatePresentation {
   
   public static void main(String args[]) throws IOException {
   
      //creating a new empty slide show
      XMLSlideShow ppt = new XMLSlideShow();	     
      
      //creating an FileOutputStream object
      File file = new File("example1.pptx");
      FileOutputStream out = new FileOutputStream(file);
      
      //saving the changes to a file
      ppt.write(out);
      System.out.println("Presentation created successfully");
      out.close()
   }
}

ऊपर दिए गए Java कोड को इस तरह सेव करें CreatePresentation.java, और उसके बाद कमांड प्रॉम्प्ट से इसे संकलित और निष्पादित करें -

$javac CreatePresentation.java $java CreatePresentation

यदि आपका सिस्टम वातावरण POI लाइब्रेरी के साथ कॉन्फ़िगर किया गया है, तो यह नामांकित रिक्त PPT फ़ाइल जनरेट करने के लिए संकलित और निष्पादित करेगा example1.pptx अपनी वर्तमान निर्देशिका में और कमांड प्रॉम्प्ट पर निम्न आउटपुट प्रदर्शित करें -

Presentation created successfully

रिक्त PowerPoint दस्तावेज़ निम्नानुसार दिखाई देता है -

एक मौजूदा प्रस्तुति का संपादन

मौजूदा प्रस्तुति खोलने के लिए, तुरंत XMLSlideShow कक्षा और पास FileInputStream फ़ाइल के ऑब्जेक्ट को एक तर्क के रूप में संपादित किया जाना है XMLSlideShow निर्माता।

File file = new File(“C://POIPPT//Examples//example1.pptx”);
FileInputstream inputstream = new FileInputStream(file);
XMLSlideShow ppt = new XMLSlideShow(inputstream);

आप किसी प्रस्तुति का उपयोग करके स्लाइड्स को जोड़ सकते हैं createSlide()XMLSlideShow वर्ग की विधि जोकि org.poi.xslf.usermodel पैकेज में है।

XSLFSlide slide1 = ppt.createSlide();

नीचे दिए गए और मौजूदा पीपीटी में स्लाइड्स को जोड़ने का पूरा कार्यक्रम है -

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;

public class EditPresentation {

   public static void main(String ar[]) throws IOException {
	   
      //opening an existing slide show
      File file = new File("example1.pptx");
      FileInputStream inputstream = new FileInputStream(file);
      XMLSlideShow ppt = new XMLSlideShow(inputstream);
      
      //adding slides to the slodeshow
      XSLFSlide slide1 = ppt.createSlide();
      XSLFSlide slide2 = ppt.createSlide();
      
      //saving the changes 
      FileOutputStream out = new FileOutputStream(file);
      ppt.write(out);
      
      System.out.println("Presentation edited successfully");
      out.close();	
   }
}

ऊपर दिए गए Java कोड को इस तरह सेव करें EditPresentation.java, और उसके बाद कमांड प्रॉम्प्ट से इसे संकलित और निष्पादित करें -

$javac EditPresentation.java $java EditPresentation

यह निम्नलिखित आउटपुट उत्पन्न करने के लिए संकलित और निष्पादित करेगा -

slides successfully added

नए जोड़े गए स्लाइड के साथ आउटपुट पीपीटी दस्तावेज़ निम्नानुसार है -

स्लाइड्स को PPT में जोड़ने के बाद, आप स्लाइड्स पर ऑपरेशन जोड़ सकते हैं, प्रदर्शन कर सकते हैं, पढ़ सकते हैं और लिख सकते हैं।

पिछले अध्याय में, आपने देखा है कि खाली स्लाइड कैसे बनाते हैं और इसमें स्लाइड कैसे जोड़ते हैं। इस अध्याय में, आप सीखेंगे कि उपलब्ध स्लाइड्स की सूची कैसे प्राप्त करें, और विभिन्न लेआउट के साथ स्लाइड कैसे बनाएं।

उपलब्ध स्लाइड लेआउट

PowerPoint प्रस्तुतियों में स्लाइड लेआउट होते हैं, और आप स्लाइड को संपादित करने के लिए एक वांछित लेआउट चुन सकते हैं। सबसे पहले, हमें उपलब्ध सभी स्लाइड लेआउट की सूची का पता लगाएं।

  • विभिन्न स्लाइड स्वामी हैं और प्रत्येक स्लाइड मास्टर में, कई स्लाइड लेआउट हैं।

  • आप स्लाइड मास्टर्स की सूची का उपयोग करके प्राप्त कर सकते हैं getSlideMasters() की विधि XMLSlideShow कक्षा।

  • आप प्रत्येक स्लाइड मास्टर से स्लाइड लेआउट की सूची प्राप्त कर सकते हैं getSlideLayouts() की विधि XSLFSlideMaster कक्षा।

  • आप का उपयोग करके लेआउट ऑब्जेक्ट से स्लाइड लेआउट का नाम प्राप्त कर सकते हैं getType() की विधि XSLFSlideLayout कक्षा।

Note- ये सभी कक्षाएं org.poi.xslf.usermodel पैकेज की हैं।

पीपीटी में उपलब्ध स्लाइड लेआउट की सूची प्राप्त करने के लिए नीचे दिया गया पूरा कार्यक्रम है -

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlideLayout;
import org.apache.poi.xslf.usermodel.XSLFSlideMaster;

public class SlideLayouts {

   public static void main(String args[]) throws IOException {
   
      //create an empty presentation
      XMLSlideShow ppt = new XMLSlideShow();
      System.out.println("Available slide layouts:")
   
      //getting the list of all slide masters
      for(XSLFSlideMaster master : ppt.getSlideMasters()) {
   
         //getting the list of the layouts in each slide master
         for(XSLFSlideLayout layout : master.getSlideLayouts()) {
   
            //getting the list of available slides
            System.out.println(layout.getType());
         } 
      }
   }
}

ऊपर दिए गए Java कोड को इस तरह सेव करें SlideLayouts.java , और उसके बाद कमांड प्रॉम्प्ट से इसे संकलित और निष्पादित करें -

$javac SlideLayouts.java $java SlideLayouts

यह निम्नलिखित आउटपुट उत्पन्न करने के लिए संकलित और निष्पादित करेगा -

Available slide layouts:
TITLE
PIC_TX
VERT_TX
TWO_TX_TWO_OBJ
BLANK
VERT_TITLE_AND_TX
TITLE_AND_CONTENT
TITLE_ONLY
SECTION_HEADER
TWO_OBJ
OBJ_TX

नीचे दिखाए गए कुछ नमूना स्लाइड लेआउट MS-Office 360, 2013 संस्करण के साथ उपलब्ध हैं।

शीर्षक लेआउट

शीर्षक लेआउट का उपयोग कर पीपीटी में स्लाइड बनाएं। नीचे दिए गए चरणों का पालन करें -

Step 1 - Instantiating द्वारा एक खाली प्रस्तुति बनाएँ XMLSlideShow नीचे दिखाया गया है।

XMLSlideShow ppt = new XMLSlideShow();

Step 2 - स्लाइड मास्टर्स की सूची का उपयोग कर प्राप्त करें getSlideMasters()तरीका। इसके बाद, नीचे दिखाए गए अनुसार इंडेक्स का उपयोग करके वांछित स्लाइड मास्टर का चयन करें।

XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];

यहां हम डिफ़ॉल्ट स्लाइड मास्टर प्राप्त कर रहे हैं जो स्लाइड मास्टर्स सरणी के 0 वें स्थान पर है।

Step 3 - का उपयोग कर वांछित लेआउट प्राप्त करें getLayout() की विधि XSLFSlideMasterकक्षा। यह विधि एक पैरामीटर को स्वीकार करती है जहां आपको एक स्थिर चर के पास से गुजरना पड़ता हैSlideLayoutclass, जो हमारे वांछित लेआउट का प्रतिनिधित्व करता है। इस वर्ग में कई चर हैं जहां प्रत्येक चर स्लाइड लेआउट का प्रतिनिधित्व करता है।

नीचे दिया गया कोड स्निपेट दिखाता है कि शीर्षक लेआउट कैसे बनाया जाए -

XSLFSlideLayout titleLayout = slideMaster.getLayout(SlideLayout.TITLE);

Step 4 - पैरामीटर के रूप में एक स्लाइड लेआउट ऑब्जेक्ट पास करके एक नई स्लाइड बनाएं।

XSLFSlide slide = ppt.createSlide(titleLayout);

Step 5 - का उपयोग कर एक प्लेसहोल्डर का चयन करें getPlaceholder() की विधि XSLFSlideकक्षा। यह विधि पूर्णांक पैरामीटर को स्वीकार करती है। पास करके0 यह करने के लिए, आप मिल जाएगा XSLFTextShapeऑब्जेक्ट, जिसके उपयोग से आप स्लाइड के शीर्षक पाठ क्षेत्र तक पहुँच सकते हैं। सेटटेक्स्ट () विधि का उपयोग करके शीर्षक सेट करें जैसा कि नीचे दिखाया गया है।

XSLFTextShape title1 = slide.getPlaceholder(0);
//setting the title init
title1.setText("Tutorials point");

नीचे दिए गए एक प्रस्तुति में शीर्षक लेआउट के साथ एक स्लाइड बनाने के लिए पूरा कार्यक्रम है -

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.SlideLayout;
import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;
import org.apache.poi.xslf.usermodel.XSLFSlideLayout;
import org.apache.poi.xslf.usermodel.XSLFSlideMaster;
import org.apache.poi.xslf.usermodel.XSLFTextShape;

public class TitleLayout {

   public static void main(String args[]) throws IOException {
   
      //creating presentation
      XMLSlideShow ppt = new XMLSlideShow();	    	
      
      //getting the slide master object
      XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];
      
      //get the desired slide layout 
      XSLFSlideLayout titleLayout = slideMaster.getLayout(SlideLayout.TITLE);
                                                     
      //creating a slide with title layout
      XSLFSlide slide1 = ppt.createSlide(titleLayout);
      
      //selecting the place holder in it 
      XSLFTextShape title1 = slide1.getPlaceholder(0); 
      
      //setting the title init 
      title1.setText("Tutorials point");
      
      //create a file object
      File file = new File("C://POIPPT//Examples//Titlelayout.pptx");
      FileOutputStream out = new FileOutputStream(file);
      
      //save the changes in a PPt document
      ppt.write(out);
      System.out.println("slide cretated successfully");
      out.close();  
   }
}

ऊपर दिए गए Java कोड को TitleLayout.java के रूप में सहेजें, और फिर इसे कमांड प्रॉम्प्ट से संकलित और निष्पादित करें: -

$javac TitleLayout.java $java TitleLayout

यह निम्नलिखित आउटपुट उत्पन्न करने के लिए संकलित और निष्पादित करेगा।

slide created successfully

नव जोड़ा शीर्षक लेआउट स्लाइड के साथ पीपीटी दस्तावेज़ निम्नानुसार दिखाई देता है -

शीर्षक और सामग्री लेआउट

एक शीर्षक और सामग्री लेआउट का उपयोग कर पीपीटी में स्लाइड बनाएं। नीचे दिए गए चरणों का पालन करें।

Step 1 - Instantiating द्वारा एक खाली प्रस्तुति बनाएँ XMLSlideShow नीचे दिखाया गया है।

XMLSlideShow ppt = new XMLSlideShow();

Step 2 - स्लाइड मास्टर्स की सूची का उपयोग कर प्राप्त करें getSlideMasters()तरीका। नीचे दिए गए सूचकांक के अनुसार वांछित स्लाइड मास्टर का चयन करें।

XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];

यहां हमें डिफ़ॉल्ट स्लाइड मास्टर मिल रहा है जो स्लाइड मास्टर्स सरणी के 0 वें स्थान पर है।

Step 3 - का उपयोग कर वांछित लेआउट प्राप्त करें getLayout() की विधि XSLFSlideMasterकक्षा। यह विधि एक पैरामीटर को स्वीकार करती है जहां आपको एक स्थिर चर के पास से गुजरना पड़ता हैSlideLayoutवर्ग जो हमारे वांछित लेआउट का प्रतिनिधित्व करता है। इस वर्ग में कई चर हैं जो स्लाइड लेआउट का प्रतिनिधित्व करते हैं।

निम्न कोड स्निपेट दिखाता है कि शीर्षक और सामग्री लेआउट कैसे बनाया जाए -

XSLFSlideLayout contentlayout = slideMaster.getLayout(SlideLayout.TITLE_AND_CONTENT);

Step 4 - पैरामीटर के रूप में स्लाइड लेआउट ऑब्जेक्ट को पास करके एक नई स्लाइड बनाएं।

XSLFSlide slide = ppt.createSlide(SlideLayout.TITLE_AND_CONTENT);

Step 5 - का उपयोग कर एक प्लेसहोल्डर का चयन करें getPlaceholder() की विधि XSLFSlideकक्षा। यह विधि पूर्णांक पैरामीटर को स्वीकार करती है। पास करके1 यह करने के लिए, आप मिल जाएगा XSLFTextShapeऑब्जेक्ट, जिसके उपयोग से आप स्लाइड के सामग्री क्षेत्र तक पहुँच सकते हैं। सेटटेक्स्ट () विधि का उपयोग करके शीर्षक सेट करें जैसा कि नीचे दिखाया गया है।

XSLFTextShape title1 = slide1.getPlaceholder(1);
//setting the title init 
title1.setText("Introduction");

Step 6 - का उपयोग कर स्लाइड में मौजूदा पाठ को साफ़ करें clearText() की विधि XSLFTextShape कक्षा।

body.clearText();

Step 7 - का उपयोग कर नया पैराग्राफ जोड़ें addNewTextParagraph()तरीका। अब पैराग्राफ का उपयोग करके एक नया पाठ रन जोड़ेंaddNewTextRun()तरीका। अब पाठ चलाने के लिए, पाठ का उपयोग करके जोड़ेंsetText() तरीका नीचे दिखाया गया है।

body.addNewTextParagraph().addNewTextRun().setText("this is  my first slide body");

नीचे दिए गए एक प्रस्तुति में शीर्षक लेआउट के साथ एक स्लाइड बनाने के लिए पूरा कार्यक्रम है -

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.SlideLayout;
import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;
import org.apache.poi.xslf.usermodel.XSLFSlideLayout;
import org.apache.poi.xslf.usermodel.XSLFSlideMaster;
import org.apache.poi.xslf.usermodel.XSLFTextShape;

public class TitleAndBodyLayout {
   
   public static void main(String args[]) throws IOException {
   
      //creating presentation
      XMLSlideShow ppt = new XMLSlideShow();
      
      //getting the slide master object
      XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];
      
      //select a layout from specified list
      XSLFSlideLayout slidelayout = slideMaster.getLayout(SlideLayout.TITLE_AND_CONTENT);
      
      //creating a slide with title and content layout
      XSLFSlide slide = ppt.createSlide(slidelayout);
      //selection of title place holder
      XSLFTextShape title = slide.getPlaceholder(0);
      
      //setting the title in it
      title.setText("introduction");
      
      //selection of body placeholder
      XSLFTextShape body = slide.getPlaceholder(1);
      
      //clear the existing text in the slide
      body.clearText();
      
      //adding new paragraph
      body.addNewTextParagraph().addNewTextRun().setText("this is  my first slide body");
      
      //create a file object
      File file = new File("contentlayout.pptx");
      FileOutputStream out = new FileOutputStream(file);
      
      //save the changes in a file
      ppt.write(out);
      System.out.println("slide cretated successfully");
      out.close();                
   }
}

ऊपर दिए गए Java कोड को इस तरह सेव करें TitleLayout.java, और उसके बाद कमांड प्रॉम्प्ट से इसे संकलित और निष्पादित करें -

$javac TitleLayout.java $java TitleLayout

यह निम्नलिखित आउटपुट उत्पन्न करने के लिए संकलित और निष्पादित करेगा -

slide created successfully

नव जोड़ा शीर्षक लेआउट स्लाइड के साथ पीपीटी दस्तावेज़ निम्नानुसार दिखाई देता है -

उसी तरह, आप अलग-अलग लेआउट के साथ स्लाइड भी बना सकते हैं।

इस अध्याय को पूरा करने के बाद, आप एक स्लाइड पर डिलीट, रीऑर्डर और पढ़ने और लिखने का संचालन कर पाएंगे।

स्लाइड बदलना

हम किसी स्लाइड का पेज आकार बदल सकते हैं setPageSize() की विधि XMLSlideShow कक्षा।

प्रारंभ में नीचे दिखाए गए अनुसार एक प्रस्तुति बनाएं -

File file = new File("C://POIPPT//Examples// TitleAndContentLayout.pptx");

//create presentation
XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));

का उपयोग करके वर्तमान स्लाइड का आकार प्राप्त करें getPageSize() की विधि XMLSlideShow कक्षा।

java.awt.Dimension pgsize = ppt.getPageSize();

का उपयोग करके पृष्ठ का आकार निर्धारित करें setPageSize() तरीका।

ppt.setPageSize(new java.awt.Dimension(1024, 768));

स्लाइड का आकार बदलने का पूरा कार्यक्रम नीचे दिया गया है -

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import org.apache.poi.xslf.usermodel.XMLSlideShow;

public class ChangingSlide {
   
   public static void main(String args[]) throws IOException {

      //create file object
      File file = new File("TitleAndContentLayout.pptx");
	 
      //create presentation
      XMLSlideShow ppt = new XMLSlideShow();
      
      //getting the current page size
      java.awt.Dimension pgsize = ppt.getPageSize();
      int pgw = pgsize.width; //slide width in points
      int pgh = pgsize.height; //slide height in points
      
      System.out.println("current page size of the PPT is:");
      System.out.println("width :" + pgw);
      System.out.println("height :" + pgh);
      
      //set new page size
      ppt.setPageSize(new java.awt.Dimension(2048,1536));
      
      //creating file object
      FileOutputStream out = new FileOutputStream(file);
      
      //saving the changes to a file
      ppt.write(out);
      System.out.println("slide size changed to given dimentions ");
      out.close();	
   }
}

ऊपर दिए गए Java कोड को इस तरह सेव करें ChangingSlide.java, और उसके बाद कमांड प्रॉम्प्ट से इसे संकलित और निष्पादित करें -

$javac ChangingSlide.java $java ChangingSlide

यह निम्नलिखित आउटपुट उत्पन्न करने के लिए संकलित और निष्पादित करेगा।

current page size of the presentation is : 
width :720
height :540
slide size changed to given dimensions

नीचे दिए गए स्लाइड आकार बदलने से पहले प्रस्तुति का स्नैपशॉट दिया गया है -

इसका आकार बदलने के बाद स्लाइड निम्नानुसार दिखाई देती है -

सरकने वाली स्लाइड

आप स्लाइड आदेश का उपयोग करके सेट कर सकते हैं setSlideOrder()तरीका। नीचे दिए गए स्लाइड्स के क्रम को निर्धारित करने की प्रक्रिया है।

नीचे दिखाए गए अनुसार एक मौजूदा पीपीटी दस्तावेज़ खोलें -

File file = new File("C://POIPPT//Examples//example1.pptx");
XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));

स्लाइड का उपयोग कर प्राप्त करें getSlides() नीचे दिखाए अनुसार विधि -

XSLFSlide[] slides = ppt.getSlides();

स्लाइड के सरणी से एक स्लाइड का चयन करें, और आदेश का उपयोग करके बदलें setSlideOrder() नीचे दिखाए अनुसार विधि -

//selecting the fourth slide
XSLFSlide selectesdslide = slides[4];

//bringing it to the top
ppt.setSlideOrder(selectesdslide, 1);

नीचे दिए गए एक प्रस्तुति में स्लाइड को फिर से व्यवस्थित करने के लिए पूरा कार्यक्रम है -

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;

public class ReorderSlide {	
   
   public static void main(String args[]) throws IOException {
   
      //opening an existing presentation
      File file = new File("example1.pptx");
      XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));
      
      //get the slides 
      XSLFSlide[] slides = ppt.getSlides();    
      
      //selecting the fourth slide
      XSLFSlide selectesdslide = slides[13];
      
      //bringing it to the top
      ppt.setSlideOrder(selectesdslide, 0);
      
      //creating an file object 
      FileOutputStream out = new FileOutputStream(file);
	  
      //saving the changes to a file
      ppt.write(out);
      out.close();	
   }
}

ऊपर दिए गए Java कोड को इस तरह सेव करें ReorderSlide.java, और उसके बाद कमांड प्रॉम्प्ट से इसे संकलित और निष्पादित करें -

$javac ReorderSlide.java $java ReorderSlide

यह निम्नलिखित आउटपुट उत्पन्न करने के लिए संकलित और निष्पादित करेगा।

Reordering of the slides is done

नीचे स्लाइड्स को पुनः प्रदर्शित करने से पहले प्रस्तुति का स्नैपशॉट दिया गया है -

स्लाइड्स को पुन: व्यवस्थित करने के बाद, प्रस्तुति निम्नानुसार दिखाई देती है। यहां हमने स्लाइड को छवि के साथ चुना है और इसे शीर्ष पर ले जाया है।

स्लाइड्स को हटाना

आप स्लाइड का उपयोग करके हटा सकते हैं removeSlide()तरीका। स्लाइड्स को हटाने के लिए नीचे दिए गए चरणों का पालन करें।

का उपयोग कर एक मौजूदा प्रस्तुति खोलें XMLSlideShow नीचे दिखाए अनुसार कक्षा -

File file = new File("C://POIPPT//Examples//image.pptx");
XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));

का उपयोग कर आवश्यक स्लाइड हटाएं removeSlide()तरीका। यह विधि पूर्णांक पैरामीटर को स्वीकार करती है। इस विधि को हटाने के लिए स्लाइड का इंडेक्स पास करें।

ppt.removeSlide(1);

नीचे एक प्रस्तुति से स्लाइड हटाने का कार्यक्रम दिया गया है -

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;

public class Deleteslide { 
   
   public static void main(String args[]) throws IOException {
   
      //Opening an existing slide
      File file = new File("image.pptx");
      XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));
      
      //deleting a slide
      ppt.removeSlide(1);
      
      //creating a file object
      FileOutputStream out = new FileOutputStream(file);
      
      //Saving the changes to the presentation
      ppt.write(out);
      out.close();	
   }
}

ऊपर दिए गए Java कोड को इस तरह सेव करें Deleteslide.java, और उसके बाद कमांड प्रॉम्प्ट से इसे संकलित और निष्पादित करें -

$javac Deleteslide.java $java Deleteslide

यह निम्नलिखित आउटपुट उत्पन्न करने के लिए संकलित और निष्पादित करेगा -

reordering of the slides is done

नीचे का स्नैपशॉट स्लाइड को हटाने से पहले प्रस्तुति का है -

स्लाइड को हटाने के बाद, प्रस्तुति निम्नानुसार दिखाई देती है -

इस अध्याय में, आप सीखेंगे कि एक PPT में एक छवि कैसे जोड़ें और उससे एक छवि कैसे पढ़ें।

छवि जोड़ना

आप प्रस्तुति का उपयोग करके छवियों को जोड़ सकते हैं createPicture() उसकि विधि XSLFSlide। यह विधि बाइट सरणी प्रारूप के रूप में छवि को स्वीकार करती है। इसलिए, आपको उस छवि का बाइट सरणी बनाना होगा जिसे प्रस्तुति में जोड़ा जाना है।

किसी प्रस्तुति में छवि जोड़ने के लिए दी गई प्रक्रिया का पालन करें। एक खाली स्लाइड शो का उपयोग कर बनाएँXMLSlideShow जैसा कि नीचे दिखाया गया है -

XMLSlideShow ppt = new XMLSlideShow();

इसमें एक खाली प्रस्तुति बनाएं createSlide()

XSLFSlide slide = ppt.createSlide();

उस छवि फ़ाइल को पढ़ें जिसे जोड़ा जाना है और इसे बाइट सरणी में परिवर्तित करना है IOUtils.toByteArray() का IOUtils नीचे दिखाए अनुसार कक्षा -

//reading an image
File image = new File("C://POIPPT//boy.jpg");

//converting it into a byte array
byte[] picture = IOUtils.toByteArray(new FileInputStream(image));

छवि का उपयोग प्रस्तुति में जोड़ें addPicture()। यह विधि दो चर स्वीकार करती है: छवि का बाइट सरणी प्रारूप जिसे जोड़ा जाना है और छवि के फ़ाइल प्रारूप का प्रतिनिधित्व करने वाला स्थिर चर। का उपयोगaddPicture() विधि नीचे दी गई है -

int idx = ppt.addPicture(picture, XSLFPictureData.PICTURE_TYPE_PNG);

छवि का उपयोग करके स्लाइड पर एम्बेड करें createPicture() जैसा कि नीचे दिखाया गया है -

XSLFPictureShape pic = slide.createPicture(idx);

एक प्रस्तुति में स्लाइड में एक छवि जोड़ने का पूरा कार्यक्रम नीचे दिया गया है -

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.util.IOUtils;
import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFPictureData;
import org.apache.poi.xslf.usermodel.XSLFPictureShape;
import org.apache.poi.xslf.usermodel.XSLFSlide;

public class AddingImage {
   
   public static void main(String args[]) throws IOException {
   
      //creating a presentation 
      XMLSlideShow ppt = new XMLSlideShow();
      
      //creating a slide in it 
      XSLFSlide slide = ppt.createSlide();
      
      //reading an image
      File image = new File("C://POIPPT//boy.jpg");
      
      //converting it into a byte array
      byte[] picture = IOUtils.toByteArray(new FileInputStream(image));
      
      //adding the image to the presentation
      int idx = ppt.addPicture(picture, XSLFPictureData.PICTURE_TYPE_PNG);
      
      //creating a slide with given picture on it
      XSLFPictureShape pic = slide.createPicture(idx);
      
      //creating a file object 
      File file = new File("addingimage.pptx");
      FileOutputStream out = new FileOutputStream(file);
      
      //saving the changes to a file
      ppt.write(out)
      System.out.println("image added successfully");
      out.close();	
   }
}

ऊपर दिए गए Java कोड को इस तरह सेव करें AddingImage.java, और उसके बाद कमांड प्रॉम्प्ट से इसे संकलित और निष्पादित करें -

$javac AddingImage.java $java AddingImage

यह निम्नलिखित आउटपुट उत्पन्न करने के लिए संकलित और निष्पादित करेगा -

reordering of the slides is done

छवि के साथ नई जोड़ी गई स्लाइड के साथ प्रस्तुति इस प्रकार है -

पढ़ने की छवि

आप का उपयोग करके सभी चित्रों का डेटा प्राप्त कर सकते हैं getAllPictures() की विधि XMLSlideShowकक्षा। निम्नलिखित कार्यक्रम एक प्रस्तुति से छवियों को पढ़ता है -

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFPictureData;

public class Readingimage {
  
  public static void main(String args[]) throws IOException {
   
      //open an existing presentation 
      File file = new File("addingimage.pptx");
      XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));
      
      //reading all the pictures in the presentation
      for(XSLFPictureData data : ppt.getAllPictures()){
         
         byte[] bytes = data.getData();
         String fileName = data.getFileName();
         int pictureFormat = data.getPictureType();
         System.out.println("picture name: " + fileName);
         System.out.println("picture format: " + pictureFormat);   
      }	    
      
      //saving the changes to a file
      FileOutputStream out = new FileOutputStream(file);
      ppt.write(out);
      out.close();	
   }
}

ऊपर दिए गए Java कोड को इस तरह सेव करें Readingimage.java, और उसके बाद कमांड प्रॉम्प्ट से इसे संकलित और निष्पादित करें -

$javac Readingimage.java $java Readingimage

यह निम्नलिखित आउटपुट उत्पन्न करने के लिए संकलित और निष्पादित करेगा -

picture name: image1.png
picture format: 6

इस अध्याय में आप जानेंगे कि प्रस्तुति में हाइपरलिंक कैसे बनाते हैं।

हाइपरलिंक बनाना

आप किसी प्रस्तुति का उपयोग करके हाइपरलिंक पढ़ सकते हैं createHyperlink() की विधि XSLFTextRunकक्षा। एक प्रस्तुति में हाइपरलिंक बनाने के लिए नीचे दी गई प्रक्रिया का पालन करें।

का उपयोग कर एक खाली प्रस्तुति बनाएँ XMLSlideShow नीचे दिखाए अनुसार कक्षा -

XMLSlideShow ppt = new XMLSlideShow();

खाली स्लाइड बनाएं और बॉडी और कंटेंट लेआउट का उपयोग करके स्लाइड का टेक्स्टबॉक्स और बॉडी बनाएं।

//create an empty presentation
XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];

//creating a slide with title and content layout
XSLFSlideLayout slidelayout = slideMaster.getLayout(SlideLayout.TITLE_AND_CONTENT);
XSLFSlide slide = ppt.createSlide(slidelayout);

//selection of body place holder
XSLFTextShape body = slide.getPlaceholder(1);

//clear the existing text in the slide
body.clearText();

टेक्स्ट रन ऑब्जेक्ट बनाएं और टेक्स्ट को नीचे दिखाए अनुसार सेट करें -

XSLFTextRun textRun = body.addNewTextParagraph().addNewTextRun();
textRun.setText("Tutorials point");

का उपयोग कर एक हाइपरलिंक बनाएँ createHyperlink() की विधि XSLFTextRun नीचे दिखाए अनुसार कक्षा -

XSLFHyperlink link = textRun.createHyperlink();

हाइपरलिंक का लिंक पता सेट करें setAddress() उसकि विधि XSLFHyperlink नीचे दिखाए अनुसार कक्षा -

link.setAddress("http://www.tutorialspoint.com/");

एक प्रस्तुति में हाइपरलिंक बनाने का पूरा कार्यक्रम नीचे दिया गया है -

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.SlideLayout;
import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFHyperlink;
import org.apache.poi.xslf.usermodel.XSLFSlide;
import org.apache.poi.xslf.usermodel.XSLFSlideLayout;
import org.apache.poi.xslf.usermodel.XSLFSlideMaster;
import org.apache.poi.xslf.usermodel.XSLFTextRun;
import org.apache.poi.xslf.usermodel.XSLFTextShape;

public class CreatingHyperlinks {

   public static void main(String args[]) throws IOException {
      
      //create an empty presentation
      XMLSlideShow ppt = new XMLSlideShow();
      
      //getting the slide master object
      XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];
      
      //select a layout from specified list
      XSLFSlideLayout slidelayout = slideMaster.getLayout(SlideLayout.TITLE_AND_CONTENT);
     
      //creating a slide with title and content layout
      XSLFSlide slide = ppt.createSlide(slidelayout);
      
      //selection of title place holder
      XSLFTextShape body = slide.getPlaceholder(1);
      
      //clear the existing text in the slid
      body.clearText();
      
      //adding new paragraph
      XSLFTextRun textRun = body.addNewTextParagraph().addNewTextRun();
      
      //setting the text
      textRun.setText("Tutorials point");	
      
      //creating the hyperlink
      XSLFHyperlink link = textRun.createHyperlink();
      
      //setting the link address
      link.setAddress("http://www.tutorialspoint.com/");
      
      //create the file object            
      File file = new File("hyperlink.pptx");
      FileOutputStream out = new FileOutputStream(file);
      
      //save the changes in a file
      ppt.write(out);
      System.out.println("slide cretated successfully");
      out.close();              
   }
}

ऊपर दिए गए Java कोड को इस तरह सेव करें CreatingHyperlinks.java, और उसके बाद कमांड प्रॉम्प्ट से इसे संकलित और निष्पादित करें -

$javac CreatingHyperlinks.java $java CreatingHyperlinks

यह निम्नलिखित आउटपुट उत्पन्न करने के लिए संकलित और निष्पादित करेगा -

slide cretated successfully

हाइपरलिंक के साथ उसके शरीर में नई गयी स्लाइड इस प्रकार है -

आप विधि का उपयोग करके किसी प्रस्तुति में उपयोग किए गए आकृतियों की संख्या की एक संख्या प्राप्त कर सकते हैं getShapeName() का XSLFShapeकक्षा। नीचे एक प्रस्तुति से आकृतियों को पढ़ने का कार्यक्रम दिया गया है -

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFShape;
import org.apache.poi.xslf.usermodel.XSLFSlide;

public class ReadingShapes {
   
   public static void main(String args[]) throws IOException {
      
      //creating a slideshow 
      File file = new File("shapes.pptx");
      XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));
      
      //get slides 
      XSLFSlide[] slide = ppt.getSlides();
      
      //getting the shapes in the presentation
      System.out.println("Shapes in the presentation:");
      for (int i = 0; i < slide.length; i++){
         
         XSLFShape[] sh = slide[i].getShapes();
         for (int j = 0; j < sh.length; j++){
            
            //name of the shape
            System.out.println(sh[j].getShapeName());
         }
      }
      
      FileOutputStream out = new FileOutputStream(file);
      ppt.write(out);
      out.close();	
   }
}

ऊपर दिए गए Java कोड को इस तरह सेव करें ReadingShapes.java, और उसके बाद कमांड प्रॉम्प्ट से इसे संकलित और निष्पादित करें -

$javac ReadingShapes.java $java ReadingShapes

यह निम्नलिखित आउटपुट उत्पन्न करने के लिए संकलित और निष्पादित करेगा।

Shapes in the presentation: 
Rectangle 1
Oval 1
Isosceles Triangle 1

विभिन्न आकृतियों के साथ नई गयी स्लाइड निम्नानुसार दिखाई देती है -

एक प्रस्तुति में पाठ के तरीकों का उपयोग करके स्वरूपित किया जा सकता है XSLFTextRunकक्षा। उसके लिए, आपको एक बनाना होगाXSLFTextRun नीचे दिखाए गए अनुसार स्लाइड लेआउट में से एक का चयन करके वर्ग वस्तु -

//create the empty presentation 
XMLSlideShow ppt = new XMLSlideShow();

//getting the slide master object
XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];

//select a layout from specified list
XSLFSlideLayout slidelayout = slideMaster.getLayout(SlideLayout.TITLE_AND_CONTENT);

//creating a slide with title and content layout
XSLFSlide slide = ppt.createSlide(slidelayout);

//selection of title place holder
XSLFTextShape body = slide.getPlaceholder(1);

//clear the existing text in the slide
body.clearText();

//adding new paragraph
XSLFTextParagraph paragraph = body.addNewTextParagraph();

//creating text run object
XSLFTextRun run = paragraph.addNewTextRun();

आप प्रस्तुति का उपयोग करके पाठ का फ़ॉन्ट आकार सेट कर सकते हैं setFontSize()

run.setFontColor(java.awt.Color.red);
run.setFontSize(24);

निम्न कोड स्निपेट दिखाता है कि एक प्रस्तुति में पाठ को विभिन्न स्वरूपण शैलियों (बोल्ड, इटैलिक, अंडरलाइन, स्ट्राइक) को कैसे लागू किया जाए।

//change the text into bold format
run.setBold(true);

//change the text it to italic format
run.setItalic(true)

// strike through the text
run.setStrikethrough(true);

//underline the text
run.setUnderline(true);

पैराग्राफ के बीच लाइन ब्रेक करने के लिए, उपयोग करें addLineBreak() का XSLFTextParagraph नीचे दिखाए अनुसार कक्षा -

paragraph.addLineBreak();

उपरोक्त सभी विधियों का उपयोग करके पाठ को प्रारूपित करने का पूरा कार्यक्रम नीचे दिया गया है -

import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.SlideLayout;
import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;
import org.apache.poi.xslf.usermodel.XSLFSlideLayout;
import org.apache.poi.xslf.usermodel.XSLFSlideMaster;
import org.apache.poi.xslf.usermodel.XSLFTextParagraph;
import org.apache.poi.xslf.usermodel.XSLFTextRun;
import org.apache.poi.xslf.usermodel.XSLFTextShape;

public class TextFormating {
   
   public static void main(String args[]) throws IOException {
      
      //creating an empty presentation
      XMLSlideShow ppt = new XMLSlideShow();
      
      //getting the slide master object
      XSLFSlideMaster slideMaster = ppt.getSlideMasters()[0];
      
      //select a layout from specified list
      XSLFSlideLayout slidelayout = slideMaster.getLayout(SlideLayout.TITLE_AND_CONTENT);
      
      //creating a slide with title and content layout
      XSLFSlide slide = ppt.createSlide(slidelayout);
      
      //selection of title place holder
      XSLFTextShape body = slide.getPlaceholder(1);
      
      //clear the existing text in the slide
      body.clearText();
      
      //adding new paragraph
      XSLFTextParagraph paragraph = body.addNewTextParagraph();
      
      //formatting line 1
      
      XSLFTextRun run1 = paragraph.addNewTextRun();
      run1.setText("This is a colored line");      
      
      //setting color to the text
      run1.setFontColor(java.awt.Color.red);      
      
      //setting font size to the text
      run1.setFontSize(24);      
      
      //moving to the next line
      paragraph.addLineBreak();
     
      //formatting line 2
      
      XSLFTextRun run2 = paragraph.addNewTextRun();
      run2.setText("This is a bold line");
      run2.setFontColor(java.awt.Color.CYAN);
      
      //making the text bold
      run2.setBold(true);
      paragraph.addLineBreak();
      
      //formatting line 3
      
      XSLFTextRun run3 = paragraph.addNewTextRun();
      run3.setText(" This is a striked line");
      run3.setFontSize(12);
      
      //making the text italic
      run3.setItalic(true);
      
      //strike through the text
      run3.setStrikethrough(true);
      paragraph.addLineBreak();
       
      //formatting line 4
      
      XSLFTextRun run4 = paragraph.addNewTextRun();
      run4.setText(" This an underlined line");
      run4.setUnderline(true);
      
      //underlining the text
      paragraph.addLineBreak();
      
      //creating a file object
      File file = new File(“TextFormat.pptx”);
      FileOutputStream out = new FileOutputStream(file);
       
      //saving the changes to a file
      ppt.write(out);
      out.close();	 
   }
}

उपरोक्त कोड को इस प्रकार सेव करें TextFormating.java, और उसके बाद कमांड प्रॉम्प्ट से इसे संकलित और निष्पादित करें -

$javac TextFormating.java $java TextFormating

यह निम्नलिखित आउटपुट उत्पन्न करने के लिए संकलित और निष्पादित करेगा -

Formatting completed successfully

स्वरूपित पाठ के साथ स्लाइड निम्नानुसार दिखाई देती है -

आप का उपयोग करके कई प्रस्तुतियों को मर्ज कर सकते हैं importContent() की विधि XMLSlideShowकक्षा। नीचे दो प्रस्तुतियों को मर्ज करने का पूरा कार्यक्रम दिया गया है -

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;

public class MergingMultiplePresentations {
   
      public static void main(String args[]) throws IOException {
      
      //creating empty presentation
      XMLSlideShow ppt = new XMLSlideShow();
      
      //taking the two presentations that are to be merged 
      String file1 = "presentation1.pptx";
      String file2 = "presentation2.pptx";
      String[] inputs = {file1, file2};
      
      for(String arg : inputs){
      
         FileInputStream inputstream = new FileInputStream(arg);
         XMLSlideShow src = new XMLSlideShow(inputstream);
         
         for(XSLFSlide srcSlide : src.getSlides()) {
         
            //merging the contents
            ppt.createSlide().importContent(srcSlide);
         }
      }
     
      String file3 = "combinedpresentation.pptx";
      
      //creating the file object
      FileOutputStream out = new FileOutputStream(file3);
      
      // saving the changes to a file
      ppt.write(out);
      System.out.println("Merging done successfully");
      out.close();
   }
}

उपरोक्त कोड को इस प्रकार सेव करें MergingMultiplePresentations.java, और उसके बाद कमांड प्रॉम्प्ट से इसे संकलित और निष्पादित करें -

$javac MergingMultiplePresentations.java $java MergingMultiplePresentations

यह निम्नलिखित आउटपुट उत्पन्न करने के लिए संकलित और निष्पादित करेगा -

Merging done successfully

निम्नलिखित स्नैपशॉट पहली प्रस्तुति दिखाता है -

निम्नलिखित स्नैपशॉट दूसरी प्रस्तुति दिखाता है -

नीचे दिए गए दो स्लाइड्स को मर्ज करने के बाद प्रोग्राम का आउटपुट है। यहां आप पहले स्लाइड्स की सामग्री को एक साथ मिला कर देख सकते हैं।

आप एक प्रस्तुति को एक छवि फ़ाइल में बदल सकते हैं। निम्नलिखित कार्यक्रम दिखाता है कि इसके बारे में कैसे जाना है।

import java.awt.Color;
import java.awt.Dimension;
import java.awt.Graphics2D;
import java.awt.geom.Rectangle2D;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;

import org.apache.poi.xslf.usermodel.XMLSlideShow;
import org.apache.poi.xslf.usermodel.XSLFSlide;

public class PptToImage {
   
   public static void main(String args[]) throws IOException {
      
      //creating an empty presentation
      File file=new File("pptToImage.pptx");
      XMLSlideShow ppt = new XMLSlideShow(new FileInputStream(file));
      
      //getting the dimensions and size of the slide 
      Dimension pgsize = ppt.getPageSize();
      XSLFSlide[] slide = ppt.getSlides();
      
      BufferedImage img = null;
      
      for (int i = 0; i < slide.length; i++) {
         img = new BufferedImage(pgsize.width, pgsize.height,BufferedImage.TYPE_INT_RGB);
         Graphics2D graphics = img.createGraphics();

         //clear the drawing area
         graphics.setPaint(Color.white);
         graphics.fill(new Rectangle2D.Float(0, 0, pgsize.width, pgsize.height));

         //render
         slide[i].draw(graphics);
         
      }
      
      //creating an image file as output
      FileOutputStream out = new FileOutputStream("ppt_image.png");
      javax.imageio.ImageIO.write(img, "png", out);
      ppt.write(out);
      
      System.out.println("Image successfully created");
      out.close();	
   }
}

ऊपर दिए गए Java कोड को इस तरह सेव करें PpttoPNG.java, और उसके बाद कमांड प्रॉम्प्ट से इसे संकलित और निष्पादित करें -

$javac PpttoPNG.java $java PpttoPNG

यह निम्नलिखित आउटपुट उत्पन्न करने के लिए संकलित और निष्पादित करेगा -

Image created successfully

निम्न स्नैपशॉट उस प्रस्तुति को दिखाता है जिसे इनपुट के रूप में दिया गया है -

नीचे दिए गए चित्र में निर्दिष्ट स्थान पर बनाई गई छवि का स्नैपशॉट है।