C#でDOCXに画像を追加する方法

This article was translated from English: Does it need improvement?
Translated
View the article in English

IronWordはImageContentクラスを提供し、画像(.jpg、.png、.bmp、.tiff、.gif)を幅、高さ、テキストの折り返しなどのカスタマイズ可能なプロパティでDOCXファイルに挿入します。 IronWordを使用してWord文書に画像を追加し、文書の自動化やレポート作成を行います。

クイックスタート: C#でDOCXに画像を追加する

1.NuGetパッケージマネージャ経由でIronWordをインストールする 2.新しい WordDocument インスタンスを作成します。 3.ImageContentクラスを使って画像を読み込みます。 4.AddImage()を使用してドキュメントに画像を追加します。 5.ドキュメントをDOCXとして保存

Nuget Icon今すぐ NuGet で PDF を作成してみましょう:

  1. NuGet パッケージ マネージャーを使用して IronWord をインストールします

    PM > Install-Package IronWord

  2. このコード スニペットをコピーして実行します。

    using IronWord;
    using IronWord.Models;
    
    // Create new document
    WordDocument doc = new WordDocument();
    
    // Add image
    ImageContent image = new ImageContent("photo.jpg");
    doc.AddImage(image);
    
    // Save document
    doc.SaveAs("document-with-image.docx");
  3. 実際の環境でテストするためにデプロイする

    今すぐ無料トライアルでプロジェクトに IronWord を使い始めましょう
    arrow pointer

IronWordを試す

今日あなたのプロジェクトでIronWordを無料トライアルで使用開始。

最初のステップ:
green arrow pointer


DOCXに画像を追加するには?

ファイルパスを使用して画像を参照します。 まず、ImageContentクラスを、ファイルパスを文字列としてインスタンス化します。 幅や高さなどのプロパティを変更するには、ファイル全体でimage変数を使用してください。 AddImage()関数を使用して、画像を.docxファイルに追加します。 ドキュメントをエクスポートし、ローカルに保存します。

以下の例では、親ノードなしでドキュメントに画像を追加しています。 対応ファイル形式は、.jpg、.png、.bmp、.tiff、.gifです。 この柔軟性により、どのような一般的な画像フォーマットでも扱うことができます。

BRACKET-t-OPEN--段落内の子要素として画像を挿入し、ドキュメントの階層構造を改善します。 この段落では、テキストの折り返しやその他のテキストフォーマットプロパティを定義します。 このアプローチでは、画像の位置をより自由にコントロールでき、画像が周囲のテキストと一緒に流れるようになります。

:path=/static-assets/word/content-code-examples/how-to/add-image-insert-image.cs
using IronWord;
using IronWord.Models;
using IronWord.Models.Enums;

// initializing docx file
WordDocument doc = new IronWord.WordDocument();

// instantiating image file
IronWord.Models.ImageContent image = new IronWord.Models.ImageContent("sample-image.jpg");

// modifying image properties
image.Width = 200;
image.Height = 200;

// AddImage function saving the image
doc.AddImage(image);

// Save and export the file
doc.SaveAs("inserted-image.docx");
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel
挿入された夜景の画像を表示するWord文書と、書式設定オプションを表示する.

どの画像形式がサポートされていますか?

対応ファイル形式.jpg、.png、.bmp、.tiff、.gif。 各フォーマットは、挿入時に品質を維持します。 写真にはJPEGが最適です。PNGはロゴやグラフィックの透過性をサポートします。 BMPは非圧縮の品質を提供します。 TIFFは高品質の印刷文書に適しています。 GIFでは、簡単なアニメーションが可能です(静的なドキュメントでは、最初のフレームのみが表示されます)。

ドキュメントのどこに画像を配置しますか?

画像は、親ノードなしで、デフォルトで現在のカーソル位置に追加されます。 画像を段落内の子要素として挿入すると、正確な位置決めができます。こうすることで、テキストの流れをよりよく制御でき、画像を文書の構造に統合することができます。

なぜ ImageContent クラスを使用するのですか?

ImageContent クラスは、画像のプロパティを構造的に管理します。 挿入前に寸法、位置、書式を修正します。 このアプローチでは、ドキュメント生成プロセス全体の一貫性を確保し、アプリケーション全体に標準書式ルールを適用します。 このクラスは、すべての画像関連プロパティをカプセル化し、コードの保守性を高め、フォーマットエラーを減らします。

ストリーム経由で画像を追加するにはどうすればよいですか?

ローカルまたは静的URLの画像は、前述の方法で簡単に追加できます。 しかし、アプリケーションでは、データベース、ウェブサービス、動的に生成されたコンテンツからの画像を扱うことがよくあります。 Streamメソッドを使用して、認証を必要とするセキュアなAPIの背後に画像を追加します。

以下の例は、認証された画像ストリームを取得するために認証トークンを送信するHTTPクライアントを示しています。 ストリームは、エクスポート前にドキュメントに直接統合されます。 このアプローチにより、一時的なファイルの保存が不要になり、機密性の高い画像データのセキュリティが向上します。

:path=/static-assets/word/content-code-examples/how-to/add-image-insert-image-via-http-stream.cs
using IronWord;
using IronWord.Models;
using IronWord.Models.Enums;

// initializing docx file
WordDocument doc = new IronWord.WordDocument();

using (HttpClient client = new HttpClient())
{
    // Add authentication headers
    client.DefaultRequestHeaders.Add("Authorization", "Bearer YOUR_API_KEY_HERE");
    client.DefaultRequestHeaders.Add("User-Agent", "MyApp/1.0");

    // Get image from authenticated endpoint
    Stream authenticatedStream = client.GetStreamAsync("https://api.example.com/secure/image.png");
    doc.AddImage(authenticatedStream);
}

// Export docx
doc.SaveAs("added-image-via-http-stream.docx");
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText   $csharpLabel

ストリーム メソッドはいつ使うべきですか?

Streamメソッドは、次のような場合に使用します:

  • 画像は認証が必要なセキュアAPIの背後にあります。
  • 画像をメモリから動的に処理する
  • データベースにバイナリデータとして保存された画像の操作

この方法は、画像が文書管理システムやクラウドストレージに保存されていたり、画像処理サービスによって生成されていたりする企業アプリケーションで効果的です。

ストリーム ローディングの利点は何ですか?

ストリーム・ローディングは、一時ファイルを保存することなく、認証されたエンドポイントから画像を統合します。 これにより、セキュリティとパフォーマンスが向上します。 利点は以下の通りです:

  • ディスクI/O操作の削減
  • ディスクに機密画像をキャッシュしない
  • リアルタイム画像処理ワークフロー
  • 大きな画像のメモリ管理を改善
  • 柔軟な画像ソースオプション

画像のプロパティを変更するにはどうすればよいですか?

. 。 IronWordは画像のプロパティをカスタマイズする包括的な方法を提供します。 ドキュメントに画像を追加する前または後に、これらのプロパティを調整してください。
設定 翻訳内容 翻訳例
画像の水平寸法(ピクセル image.幅 = 500;.
高さ 画像の縦寸法(ピクセル image.高さ = 300;.
ラップテキスト 画像の周りのテキストの折り返し動作 image.ラップテキスト = ラップテキスト.Square;.
左からの距離 左端からのスペーシング(単位:ピクセル image.左からの距離 = 10;.
ディスタンスフロムライト 右端からのスペーシング(単位:ピクセル image.ディスタンスフロムライト = 10;.
距離トップ 上端からのスペーシング(単位:ピクセル image.距離トップ = 15;.
下からの距離 下端からのスペーシング(単位:ピクセル image.下からの距離 = 15;.
ポジション 空間配置情報(XおよびY座標) <コード>image.ポジション = new Elementポジション(50, 100);
規模 X軸とY軸の比例サイズ係数 image.規模 = new PointF(1.5f, 1.5f);
翻訳 再配置のための変位座標 <コード>image.翻訳 = new PointF(20, 30);
### 幅と高さをカスタマイズするにはどうすればよいですか? アスペクト比を変更することで、カスタムの幅と高さを実装します。 画像の比率を維持したり、特定のレイアウト制約に合わせたりと、文書内での画像の表示方法を制御します。 ```csharp :path=/static-assets/word/content-code-examples/how-to/add-image-custom-size.cs ```
Add Image Custom Size related to 画像のプロパティを変更するにはどうすればよいですか?.
### アスペクト比はどうなりますか? 幅と高さのカスタム値は、元のアスペクト比を上書きします。 ヘッダー、サイドバー、固定サイズのコンテナなどのレイアウト要件に合わせて、画像を伸張または圧縮します。 極端な歪曲はプロらしくない印象を与えかねません。 リサイズ時にアスペクト比を維持するため、ターゲットサイズに基づいて比例寸法を計算してください。 ### どのプロパティを最初に設定すべきですか? この順序でプロパティを設定します: 1.寸法(幅/高さ) - 画像レイアウトの基礎 2.ポジショニング(DistanceFromプロパティ) - スペーシングとマージンのコントロール 3.高度なプロパティ(拡大縮小/翻訳)-微調整 このアプローチは、各プロパティが前のプロパティを論理的に構築することを保証します。 いくつかのプロパティは相互作用します - テキストの折り返しは、距離プロパティの動作に影響します。

よくある質問

C#でDOCXファイルに画像を追加するには?

IronWordでは、画像ファイルのパスでImageContentインスタンスを作成し、AddImage()メソッドを使用することで、DOCXファイルに画像を追加することができます。IronWordはJPG、PNG、BMP、TIFF、GIFのような一般的なフォーマットをサポートしており、Word文書にプログラムで簡単に画像を挿入することができます。

Word文書に画像を追加する場合、どのような画像形式がサポートされますか?

IronWordは.jpg、.png、.bmp、.tiff、.gifファイルを含むすべての主要な画像フォーマットをサポートしています。JPEGは写真、PNGは透過画像、BMPは非圧縮、TIFFは高品質の印刷文書、GIFはシンプルなアニメーション(最初のフレームのみ表示)に適しています。

DOCXファイルの画像のサイズや位置を制御できますか?

IronWordのImageContentクラスでは、幅、高さ、テキストの折り返しなどの画像プロパティをカスタマイズできます。挿入前に寸法や位置を変更することができ、Word文書での画像の表示方法を完全に制御することができます。

段落内に画像を挿入して文書構造を改善するにはどうすればよいですか?

IronWordでは、段落内の子要素として画像を挿入することができ、より優れた文書階層とテキストの折り返しを制御することができます。このアプローチは、画像を周囲のテキストフローと統合し、親ノードなしで画像を追加する場合と比較して、より正確な位置決めオプションを提供します。

プログラムでWord文書に画像を追加する最も簡単な方法は何ですか?

IronWordで最も手っ取り早い方法は、WordDocumentインスタンスを作成し、new ImageContent('photo.jpg')で画像を読み込み、doc.AddImage(image)を呼び出し、doc.SaveAs('document-with-image.docx')で保存することです。このシンプルな4ステップのプロセスで、画像挿入のワークフロー全体が処理されます。

Ahmad Sohail
フルスタックデベロッパー

Ahmadは、C#、Python、およびウェブ技術に強い基盤を持つフルスタック開発者です。彼はスケーラブルなソフトウェアソリューションの構築に深い関心を持ち、デザインと機能が実際のアプリケーションでどのように融合するかを探求することを楽しんでいます。

Iron Softwareチームに参加する前、Ahmadは自動化プロジェクトやAPI統合に取り組み、パフォーマンスの向上と開発者の体験向上に注力してきました。

彼の自由時間には、UI/UXのアイデアを試したり、オープンソースツールに貢献したり、時折テクニカルライティングやドキュメンテーションに取り組んで、複雑なトピックを理解しやすくすることを目指しています。

準備はできましたか?
Nuget ダウンロード 28,054 | バージョン: 2025.12 リリース