MergeFieldImageDimension
Содержание
[
Скрывать
]MergeFieldImageDimension class
Представляет размер изображения (т. е. ширину или высоту), используемый в процессе слияния почты.
Чтобы узнать больше, посетитеРабота с полями статья документации.
public class MergeFieldImageDimension
Конструкторы
Имя | Описание |
---|---|
MergeFieldImageDimension(double) | Создает экземпляр размера изображения с заданным значением в пунктах. |
MergeFieldImageDimension(double, MergeFieldImageDimensionUnit) | Создает экземпляр измерения изображения с заданным значением и заданной единицей измерения. |
Характеристики
Имя | Описание |
---|---|
Unit { get; set; } | Единица измерения. |
Value { get; set; } | Значение. |
Примечания
Чтобы указать, что изображение должно быть вставлено с исходным размером во время слияния почты, , вам следует присвоить отрицательное значениеValue
свойство.
Примеры
Показывает, как установить размеры изображений, поскольку MERGEFIELDS принимает их во время слияния почты.
public void MergeFieldImageDimension()
{
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(ImageDir + "Logo.jpg");
dataTable.Rows.Add(ImageDir + "Transparent background logo.png");
dataTable.Rows.Add(ImageDir + "Enhanced Windows MetaFile.emf");
// Настройте обратный вызов для изменения размеров изображений во время слияния, а затем выполните слияние почты.
doc.MailMerge.FieldMergingCallback = new MergedImageResizer(200, 200, MergeFieldImageDimensionUnit.Point);
doc.MailMerge.Execute(dataTable);
doc.UpdateFields();
doc.Save(ArtifactsDir + "Field.MERGEFIELD.ImageDimension.docx");
}
/// <summary>
/// Устанавливает размер всех объединенных изображений почты в одну определенную ширину и высоту.
/// </summary>
private class MergedImageResizer : IFieldMergingCallback
{
public MergedImageResizer(double imageWidth, double imageHeight, MergeFieldImageDimensionUnit unit)
{
mImageWidth = imageWidth;
mImageHeight = imageHeight;
mUnit = unit;
}
public void FieldMerging(FieldMergingArgs e)
{
throw new NotImplementedException();
}
public void ImageFieldMerging(ImageFieldMergingArgs args)
{
args.ImageFileName = args.FieldValue.ToString();
args.ImageWidth = new MergeFieldImageDimension(mImageWidth, mUnit);
args.ImageHeight = new MergeFieldImageDimension(mImageHeight, mUnit);
Assert.AreEqual(mImageWidth, args.ImageWidth.Value);
Assert.AreEqual(mUnit, args.ImageWidth.Unit);
Assert.AreEqual(mImageHeight, args.ImageHeight.Value);
Assert.AreEqual(mUnit, args.ImageHeight.Unit);
}
private readonly double mImageWidth;
private readonly double mImageHeight;
private readonly MergeFieldImageDimensionUnit mUnit;
}
Смотрите также
- пространство имен Aspose.Words.Fields
- сборка Aspose.Words