PowerPoint Online を組み合わせる

PowerPoint を組み合わせる | Java Cloud SDK を使用して PPT PPTX をマージする

この記事では、複数の PowerPoint を 1 つのプレゼンテーション ファイルに結合する方法について詳しく説明します。 PowerPoint は、企業文化における情報の表現や説明に使用されるほか、ビジネスマンや学生がスライド ショーの準備に使用します。人気のもう 1 つの側面は、チュートリアル、デジタル ポートフォリオ、基本的なアニメーション、または写真のスライド ショーの作成です。ただし、チームが分散環境で作業している場合、PowerPoint プレゼンテーションをマージする必要がある場合があります。そのため、この記事では、Java Cloud SDK を使用して複数の PowerPoint を 1 つのプレゼンテーションに結合するための詳細に光を当てます。

PowerPoint API の結合

プログラムで PPT または PPTXPDFJPEGPNG または GIF に作成、編集、およびエクスポートするためなどの形式で、Aspose.Slides Cloud という名前のローコード API を開発しました。その REST ベースのアーキテクチャにより、あらゆるプラットフォームで API ルーチンを呼び出すことができます。 Java アプリケーションで PowerPoint プレゼンテーションを結合する機能を実装するために、Aspose.Slides Cloud SDK for Java を特別に作成しました。したがって、SDK を使用するには、Maven ビルド プロジェクトの pom.xml にその参照を追加するだけです。

<repositories> 
    <repository>
        <id>aspose-cloud</id>
        <name>artifact.aspose-cloud-releases</name>
        <url>http://artifact.aspose.cloud/repo</url>
    </repository>   
</repositories>

<dependencies>
    <dependency>
        <groupId>com.aspose</groupId>
        <artifactId>aspose-slides-cloud</artifactId>
        <version>22.9.0</version>
    </dependency>
</dependencies>

SDK リファレンスが追加されたら、次の重要なステップは Aspose Cloud で認証することです。既存のアカウントをお持ちでない場合は、有効なメール アドレスを使用して無料のアカウントを作成してください。次に、新しく作成したアカウントを使用してログインし、クラウド ダッシュボード でクライアント ID とクライアント シークレットを検索/作成します。これらの詳細は、以降のセクションで認証のために必要になります。

Java で PowerPoint を結合する

このセクションでは、Java Cloud SDK を使用して PowerPoint プレゼンテーションをマージする方法について詳しく説明します。 PowerPoint をマージするには、入力 PowerPoint をローカル ドライブからロードするか、クラウド ストレージからロードするか、Web URL から直接ロードすることもできます。以下の指示に従ってください。

  • まずは ClientID と Client secret を引数に渡して SlidesApi オブジェクトのオブジェクトを作成する
  • 次に、最初の PowerPoint にデータを提供する FileInfo のオブジェクトを作成します。
  • 3 番目に、マージされる PPT ファイルのリストを保持する ArrayList のインスタンスを作成します。
  • 次のステップは、マージする PowerPoint ごとに PresentationToMerge の個別のオブジェクトを作成することです。
  • ローカル ストレージから PowerPoint を読み込むには、PresentationToMerge 列挙型の REQUEST 値を使用する必要があります。
  • 結合する PowerPoint 内の特定のスライドを指定するには、setSlides(…) メソッドを使用します。
  • 次のステップは、プレゼンテーション ファイルをマージする順序を設定することです。この目的のために、OrderedMergeRequest オブジェクトを使用し、その setPresentations(..) メソッドを使用します。
  • 最後に、mergeAndSaveOnline(…) メソッドを呼び出して、PowerPoint プレゼンテーションをマージし、結果のファイルをクラウド ストレージに保存します。
try
    {	    
        // https://dashboard.aspose.cloud/ から ClientID と ClientSecret を取得します。
	String clientId = "7ef10407-c1b7-43bd-9603-5ea9c6db83cd";
	String clientSecret = "ba7cc4dc0c0478d7b508dd8ffa029845";

	// SlidesApi のインスタンスを作成する
	SlidesApi slidesApi = new SlidesApi(clientId,clientSecret);
        
	// マージするプレゼンテーションを収集します。
	FileInfo fileInfo = new FileInfo();
	// 入力プレゼンテーションを読む 
	fileInfo.setData(Files.readAllBytes(Paths.get("TemplateCV.pptx")));
	// ソース PowerPoint の名前を設定する
	fileInfo.setName("TemplateCV.pptx");

	// FileInfo オブジェクトの配列リストを作成する
	List<FileInfo> files = new ArrayList<FileInfo>();
	// FileInfo オブジェクトを配列リストに追加する
	files.add(fileInfo);

	// マージする最初のプレゼンテーションの情報を準備します。
	PresentationToMerge presentation1 = new PresentationToMerge();
	// ローカル ドライブから PowerPoint を読み取る
	presentation1.setSource(PresentationToMerge.SourceEnum.REQUEST);
	// 最初の PowerPoint ファイルのパスを設定する
	presentation1.setPath("TemplateCV.pptx");
	// マージする必要がある PowerPoint のスライドを指定します
	presentation1.setSlides(Arrays.asList(1, 2));
	       
	// マージする最初のプレゼンテーションの情報を準備します。
	PresentationToMerge presentation2 = new PresentationToMerge();
	presentation2.setPath("Presentation1.pptx");
	// PowerPoint がパスワードで保護されている場合にパスワードの詳細を設定する
	///presentation2.setPassword("my_password");
	// ソースをクラウド ストレージとして指定する
	presentation2.setSource(PresentationToMerge.SourceEnum.STORAGE);

	// マージする最初のプレゼンテーションの情報を準備します。
	PresentationToMerge presentation3 = new PresentationToMerge();
	// Web URL としての PowerPoint のパス
	presentation3.setPath("https://github.com/aspose-slides-cloud/aspose-slides-cloud-java/blob/master/TestData/test-unprotected.pptx");
	presentation3.setSlides(Arrays.asList(1));
	// パス値を URL として設定
	presentation3.setSource(PresentationToMerge.SourceEnum.URL);

        // マージ リクエストを準備します。
	OrderedMergeRequest request = new OrderedMergeRequest();
	// PowerPoint プレゼンテーションの結合順序を設定する
	request.setPresentations(Arrays.asList(presentation1, presentation2));//, presentation3));
  
        // API を呼び出して PowerPoint を結合し、出力をクラウド ストレージに保存する
	slidesApi.mergeAndSaveOnline("Merged.pptx", files, request, "internal");  // mergeOnline(files, request, null);
        
        System.out.println("Merge PowerPoint successful !");
	}catch(Exception ex)
	{
	    System.out.println(ex);
	}
PowerPoint プレビューの結合

Image1:- PowerPoint プレビューを結合

上記の例で使用したサンプル ファイルは、TemplateCV.pptxPresentation1.pptx、および Merged.ppt からダウンロードできます。

cURL コマンドを使用して PowerPoint をマージする

cURL コマンドはプラットフォームに依存せず、どのプラットフォームでも実行できます。したがって、このセクションでは、cURL コマンドを使用して PowerPoint プレゼンテーションをマージする方法について詳しく説明します。したがって、このアプローチの前提条件として、まず、次のコマンドを実行しながら、(クライアント資格情報に基づいて) JWT アクセス トークンを生成する必要があります。

curl -v "https://api.aspose.cloud/connect/token" \
-X POST \
-d "grant_type=client_credentials&client_id=bb959721-5780-4be6-be35-ff5c3a6aa4a2&client_secret=4d84d5f6584160cbd91dba1fe145db14" \
-H "Content-Type: application/x-www-form-urlencoded" \
-H "Accept: application/json"

JWT トークンを取得したら、次のステップは、次のコマンドを使用して PowerPoint プレゼンテーションをマージすることです。次のコマンドでは、最初のプレゼンテーションの最初のスライドをマージしており、2 番目のプレゼンテーションからは 1 番目と 3 番目のスライドがマージされていることに注意してください。マージ PPTX はクラウド ストレージに保存されます。

curl -v -X PUT "https://api.aspose.cloud/v3.0/slides/merge?outPath=newResultant.pptx" \
-H  "accept: application/json" \
-H  "authorization: Bearer <JWT Token>" \
-H  "Content-Type: application/json" \
-d "{  \"Presentations\": [    {      \"Path\": \"Presentation1.pptx\",      \"Password\": \"string\",      \"Slides\": [        1      ],      \"Source\": \"Storage\"    },    {      \"Path\": \"test-unprotected.pptx\",      \"Password\": \"string\",      \"Slides\": [        1,3      ],      \"Source\": \"Storage\"    }  ]}"

結論

この記事では、Java Cloud SDK を使用して PowerPoint プレゼンテーションを結合するための詳細について説明しました。 Java コード スニペットの他に、cURL コマンドを使用して複数のパワーポイントを 1 つに結合する方法の詳細についても学びました。さらに、製品 ドキュメント を調べて、Cloud API が提供する多くの素晴らしい機能について学ぶことを強くお勧めします。また、すべての Cloud SDK は MIT ライセンスの下で公開されているため、GitHub から完全なソース コードをダウンロードして、要件に応じて変更することを検討してください。問題が発生した場合は、無料の 製品サポート フォーラム から迅速な解決策を得ることができます。

関連記事

詳細については、次のリンクを参照してください。