Image
Содержание
[
Скрывать
]ImageFieldMergingArgs.Image property
Указывает изображение, которое механизм слияния почты должен вставить в документ.
public Image Image { get; set; }
Примеры
Показывает, как использовать обратный вызов для настройки логики слияния изображений.
public void MergeFieldImages()
{
Document doc = new Document();
// Вставляем MERGEFIELD, который будет принимать изображения из источника во время слияния почты. Используйте код поля для ссылки
// столбец в источнике данных, содержащий имена локальных системных файлов изображений, которые мы хотим использовать при слиянии писем.
DocumentBuilder builder = new DocumentBuilder(doc);
FieldMergeField field = (FieldMergeField)builder.InsertField("MERGEFIELD Image:ImageColumn");
// В этом случае поле ожидает, что источник данных будет иметь такой столбец с именем «ImageColumn».
Assert.AreEqual("Image:ImageColumn", field.FieldName);
// Имена файлов могут быть длинными, и если мы найдем способ избежать их хранения в источнике данных,
// мы можем значительно уменьшить его размер.
// Создайте источник данных, который ссылается на изображения, используя короткие имена.
DataTable dataTable = new DataTable("Images");
dataTable.Columns.Add(new DataColumn("ImageColumn"));
dataTable.Rows.Add("Dark logo");
dataTable.Rows.Add("Transparent logo");
// Назначаем обратный вызов слияния, который содержит всю логику, обрабатывающую эти имена,
// а затем выполнить слияние почты.
doc.MailMerge.FieldMergingCallback = new ImageFilenameCallback();
doc.MailMerge.Execute(dataTable);
doc.Save(ArtifactsDir + "Field.MERGEFIELD.Images.docx");
}
/// <summary>
/// Содержит словарь, который сопоставляет имена изображений с именами локальных системных файлов, содержащих эти изображения.
/// Если источник данных слияния почты использует одно из имен словаря для ссылки на изображение,
/// этот обратный вызов передаст соответствующее имя файла в пункт назначения слияния.
/// </summary>
private class ImageFilenameCallback : IFieldMergingCallback
{
public ImageFilenameCallback()
{
mImageFilenames = new Dictionary<string, string>();
mImageFilenames.Add("Dark logo", ImageDir + "Logo.jpg");
mImageFilenames.Add("Transparent logo", ImageDir + "Transparent background logo.png");
}
void IFieldMergingCallback.FieldMerging(FieldMergingArgs args)
{
throw new NotImplementedException();
}
void IFieldMergingCallback.ImageFieldMerging(ImageFieldMergingArgs args)
{
if (mImageFilenames.ContainsKey(args.FieldValue.ToString()))
{
#if NET48 || JAVA
args.Image = Image.FromFile(mImageFilenames[args.FieldValue.ToString()]);
#elif NET5_0_OR_GREATER
args.Image = SKBitmap.Decode(mImageFilenames[args.FieldValue.ToString()]);
args.ImageFileName = mImageFilenames[args.FieldValue.ToString()];
#endif
}
Assert.NotNull(args.Image);
}
private readonly Dictionary<string, string> mImageFilenames;
}
Смотрите также
- class ImageFieldMergingArgs
- пространство имен Aspose.Words.MailMerging
- сборка Aspose.Words