Создание AcroForms с использованием C++
Добавление поля формы в PDF-документ
Класс Document предоставляет коллекцию с именем Form, которая помогает управлять полями формы в PDF-документе.
Чтобы добавить поле формы:
- Создайте поле формы, которое вы хотите добавить.
- Вызовите метод добавления коллекции Form.
Этот пример показывает, как добавить TextBoxField. Вы можете добавить любое поле формы, используя тот же подход:
- Сначала создайте объект поля и задайте его свойства.
- Затем добавьте поле в коллекцию Form.
Добавление TextBoxField
Текстовое поле — это элемент формы, который позволяет получателю ввести текст в вашу форму. Это будет использоваться всякий раз, когда вы хотите предоставить пользователю свободу вводить то, что они хотят.
Следующий фрагмент кода показывает, как добавить TextBoxField в PDF-документ.
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
RadioButton чаще всего используется для вопросов с несколькими вариантами ответов, в сценарии, когда можно выбрать только один ответ.
Следующие фрагменты кода показывают, как добавить RadioButtonField в PDF документ.
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));
// Добавить второй вариант радио-кнопки
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");
}
Следующий фрагмент кода показывает шаги по добавлению 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
Следующий фрагмент кода показывает, как добавить подпись, которая будет связана с 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);
// Добавить TextParagraph с помощью TextBuilder
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");
}
Добавление поля ComboBox
Combo Box — это поле формы, которое добавляет выпадающее меню в ваш документ.
Следующие фрагменты кода показывают, как добавить поле ComboBox в PDF-документ.
void AddingComboBoxField()
{
String _dataDir("C:\\Samples\\");
// Создать объект документа
auto document = MakeObject<Document>();
// Добавить страницу к объекту документа
document->get_Pages()->Add();
// Создать объект поля ComboBox
auto combo = MakeObject<ComboBoxField>(document->get_Pages()->idx_get(1),
MakeObject<Rectangle>(100, 600, 150, 616));
// Добавить опцию в ComboBox
combo->AddOption(u"Red");
combo->AddOption(u"Yellow");
combo->AddOption(u"Green");
combo->AddOption(u"Blue");
// Добавить объект ComboBox в коллекцию полей формы объекта документа
document->get_Form()->Add(combo);
// Сохранить PDF-документ
document->Save(_dataDir + u"ComboBox_out.pdf");
}
Добавить подсказку к форме
The Document класс предоставляет коллекцию под названием Form, которая управляет полями формы в PDF документе. Чтобы добавить подсказку к полю формы, используйте класс 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");
}