C++を使用してAcroFormsを作成する
PDFドキュメントにフォームフィールドを追加する
Documentクラスは、PDFドキュメント内のフォームフィールドを管理するのに役立つFormという名のコレクションを提供します。
フォームフィールドを追加するには:
- 追加したいフォームフィールドを作成します。
- Formコレクションのaddメソッドを呼び出します。
この例では、TextBoxFieldを追加する方法を示します。同じアプローチで任意のフォームフィールドを追加できます:
- まず、フィールドオブジェクトを作成し、そのプロパティを設定します。
- 次に、フィールドをFormコレクションに追加します。
TextBoxFieldの追加
テキストフィールドは、受信者がフォームにテキストを入力できるようにするフォーム要素です。 ユーザーが自由に入力できるようにしたい場合に使用されます。
次のコードスニペットは、PDFドキュメントにTextBoxFieldを追加する方法を示しています。
using namespace System;
using namespace Aspose::Pdf;
using namespace Aspose::Pdf::Forms;
using namespace Aspose::Pdf::Annotations;
void AddingTextBoxField()
{
String _dataDir("C:\\Samples\\");
// ドキュメントを開く
auto document = MakeObject<Document>(_dataDir + u"TextField.pdf");
// フィールドを作成
auto textBoxField = MakeObject<TextBoxField>(document->get_Pages()->idx_get(1), MakeObject<Aspose::Pdf::Rectangle>(100, 200, 300, 300));
textBoxField->set_PartialName (u"textbox1");
textBoxField->set_Value (u"Text Box");
// TextBoxField.Border = new Border(
auto border = MakeObject<Aspose::Pdf::Annotations::Border>(textBoxField);
border->set_Width(5);
border->set_Dash (MakeObject<Aspose::Pdf::Annotations::Dash>(1, 1));
textBoxField->set_Border(border);
textBoxField->set_Color(Aspose::Pdf::Color::get_Green());
// ドキュメントにフィールドを追加
document->get_Form()->Add(textBoxField, 1);
// 修正されたPDFを保存
document->Save(_dataDir + u"TextBox_out.pdf");
}
RadioButtonFieldの追加
ラジオボタンは、1つの回答のみ選択できる状況で、複数選択問題に最も一般的に使用されます。
次のコードスニペットは、PDFドキュメントにRadioButtonFieldを追加する方法を示しています。
void AddingRadioButtonField()
{
String _dataDir("C:\\Samples\\");
// ドキュメントを開く
auto document = MakeObject<Document>();
// PDFファイルにページを追加
document->get_Pages()->Add();
// 引数としてページ番号を持つRadioButtonFieldオブジェクトをインスタンス化
auto radio = MakeObject<RadioButtonField>(document->get_Pages()->idx_get(1));
// 最初のラジオボタンのオプションを追加し、Rectangleオブジェクトを使用してその位置を指定
radio->AddOption(u"Option 1", MakeObject<Rectangle>(0, 0, 20, 20));
// 2番目のラジオボタンのオプションを追加
radio->AddOption(u"Option 2", MakeObject<Rectangle>(20, 20, 40, 40));
// Documentオブジェクトのフォームオブジェクトにラジオボタンを追加
document->get_Form()->Add(radio,1);
// PDFファイルを保存
document->Save(_dataDir + u"RadioButton_out.pdf");
}
以下のコードスニペットは、3つのオプションを持つRadioButtonFieldを追加し、それらをテーブルのセル内に配置する手順を示しています。
void AddRadioButtonFieldInsideTableCells()
{
String _dataDir("C:\\Samples\\");
auto document = MakeObject<Document>();
auto page = document->get_Pages()->Add();
auto table = MakeObject<Aspose::Pdf::Table>();
table->set_ColumnWidths(u"120 120 120");
page->get_Paragraphs()->Add(table);
auto r1 = table->get_Rows()->Add();
auto c1 = r1->get_Cells()->Add();
auto c2 = r1->get_Cells()->Add();
auto c3 = r1->get_Cells()->Add();
auto rf = MakeObject<RadioButtonField>(page);
rf->set_PartialName(u"radio");
document->get_Form()->Add(rf, 1);
auto opt1 = MakeObject<RadioButtonOptionField>();
auto opt2 = MakeObject<RadioButtonOptionField>();
auto opt3 = MakeObject<RadioButtonOptionField>();
opt1->set_OptionName(u"Item1");
opt2->set_OptionName(u"Item2");
opt3->set_OptionName(u"Item3");
opt1->set_Width (15);
opt1->set_Height(15);
opt2->set_Width (15);
opt2->set_Height(15);
opt3->set_Width (15);
opt3->set_Height(15);
rf->Add(opt1);
rf->Add(opt2);
rf->Add(opt3);
opt1->set_Border(MakeObject<Border>(opt1));
opt1->get_Border()->set_Width(1);
opt1->get_Border()->set_Style(BorderStyle::Solid);
opt1->get_Characteristics()->set_Border(System::Drawing::Color::get_Black());
opt1->get_DefaultAppearance()->set_TextColor(System::Drawing::Color::get_Red());
opt1->set_Caption(MakeObject<Aspose::Pdf::Text::TextFragment>(u"Item1"));
opt2->set_Border(MakeObject<Border>(opt2));
opt2->get_Border()->set_Width(1);
opt2->get_Border()->set_Style(BorderStyle::Solid);
opt2->get_Characteristics()->set_Border(System::Drawing::Color::get_Black());
opt2->get_DefaultAppearance()->set_TextColor(System::Drawing::Color::get_Red());
opt2->set_Caption(MakeObject<Aspose::Pdf::Text::TextFragment>(u"Item2"));
opt3->set_Border(MakeObject<Border>(opt3));
opt3->get_Border()->set_Width(1);
opt3->get_Border()->set_Style(BorderStyle::Solid);
opt3->get_Characteristics()->set_Border(System::Drawing::Color::get_Black());
opt3->get_DefaultAppearance()->set_TextColor(System::Drawing::Color::get_Red());
opt3->set_Caption(MakeObject<Aspose::Pdf::Text::TextFragment>(u"Item3"));
c1->get_Paragraphs()->Add(opt1);
c2->get_Paragraphs()->Add(opt2);
c3->get_Paragraphs()->Add(opt3);
// PDFファイルを保存
document->Save(_dataDir + u"RadioButtonWithOptions_out.pdf");
}
ラジオボタンフィールドへのキャプションの追加
次のコードスニペットは、RadioButtonField に関連付けられるキャプションを追加する方法を示します:
void AddingCaptionToRadioButtonField()
{
String _dataDir("C:\\Samples\\");
auto document = MakeObject<Document>();
// ソースPDFフォームをロード
auto form1 =
MakeObject<Aspose::Pdf::Facades::Form>(_dataDir + u"RadioButtonField.pdf");
auto PDF_Template_PDF_HTML = MakeObject<Document>(_dataDir + u"RadioButtonField.pdf");
for(auto item : form1->get_FieldNames())
{
System::Console::WriteLine(item);
auto radioOptions = form1->GetButtonOptionValues(item);
if (item.Contains(u"radio1"))
{
auto field0 = System::DynamicCast<RadioButtonField>(PDF_Template_PDF_HTML->get_Form()->idx_get(item));
auto fieldoption = MakeObject<RadioButtonOptionField>();
fieldoption->set_OptionName (u"Yes");
fieldoption->set_PartialName (u"Yesname");
auto updatedFragment = MakeObject<Aspose::Pdf::Text::TextFragment>(u"test123");
updatedFragment->get_TextState()->set_Font (Aspose::Pdf::Text::FontRepository::FindFont(u"Arial"));
updatedFragment->get_TextState()->set_FontSize(10);
updatedFragment->get_TextState()->set_LineSpacing(6.32f);
// TextParagraphオブジェクトを作成
auto par = MakeObject<Aspose::Pdf::Text::TextParagraph>();
// 段落の位置を設定
par->set_Position(MakeObject<Aspose::Pdf::Text::Position>(field0->get_Rect()->get_LLX(), field0->get_Rect()->get_LLY() + updatedFragment->get_TextState()->get_FontSize()));
// ワードラッピングモードを指定
par->get_FormattingOptions()->set_WrapMode(Aspose::Pdf::Text::TextFormattingOptions::WordWrapMode::ByWords);
// 段落に新しいTextFragmentを追加
par->AppendLine(updatedFragment);
// TextBuilderを使用してTextParagraphを追加
auto textBuilder = MakeObject<Aspose::Pdf::Text::TextBuilder>(PDF_Template_PDF_HTML->get_Pages()->idx_get(1));
textBuilder->AppendParagraph(par);
field0->DeleteOption(u"item1");
}
}
PDF_Template_PDF_HTML->Save(_dataDir + u"RadioButtonField_out.pdf");
}
コンボボックスフィールドの追加
コンボボックスは、ドキュメントにドロップダウンメニューを追加するフォームフィールドです。
以下のコードスニペットは、PDFドキュメントにComboBoxフィールドを追加する方法を示しています。
void AddingComboBoxField()
{
String _dataDir("C:\\Samples\\");
// ドキュメントオブジェクトを作成
auto document = MakeObject<Document>();
// ドキュメントオブジェクトにページを追加
document->get_Pages()->Add();
// コンボボックスフィールドオブジェクトをインスタンス化
auto combo = MakeObject<ComboBoxField>(document->get_Pages()->idx_get(1),
MakeObject<Rectangle>(100, 600, 150, 616));
// コンボボックスにオプションを追加
combo->AddOption(u"Red");
combo->AddOption(u"Yellow");
combo->AddOption(u"Green");
combo->AddOption(u"Blue");
// ドキュメントオブジェクトのフォームフィールドコレクションにコンボボックスオブジェクトを追加
document->get_Form()->Add(combo);
// PDFドキュメントを保存
document->Save(_dataDir + u"ComboBox_out.pdf");
}
フォームにツールチップを追加
The Document クラスは、PDF ドキュメント内のフォームフィールドを管理する Form というコレクションを提供します。フォームフィールドにツールチップを追加するには、Field クラスの AlternateName を使用します。Adobe Acrobat は、「代替名」をフィールドのツールチップとして使用します。
以下のコードスニペットは、C++でフォームフィールドにツールチップを追加する方法を示しています。
void AddTooltipToFormField()
{
String _dataDir("C:\\Samples\\");
// ソース PDF フォームをロード
auto document = new Document(_dataDir + u"AddTooltipToField.pdf");
// テキストフィールドのツールチップを設定
//(doc.Form["textbox1"] as Field).AlternateName = "テキストボックスのツールチップ";
// 更新されたドキュメントを保存
document->Save(_dataDir + u"AddTooltipToField_out.pdf");
}