FieldDdeAuto
Contenido
[
Ocultar
]FieldDdeAuto class
Implementa el campo DDEAUTO.
Para obtener más información, visite elTrabajar con campos Artículo de documentación.
public class FieldDdeAuto : Field
Constructores
Nombre | Descripción |
---|---|
FieldDdeAuto() | Constructor predeterminado |
Propiedades
Nombre | Descripción |
---|---|
DisplayResult { get; } | Obtiene el texto que representa el resultado del campo mostrado. |
End { get; } | Obtiene el nodo que representa el final del campo. |
Format { get; } | Obtiene unFieldFormat objeto que proporciona acceso tipificado al formato del campo. |
InsertAsBitmap { get; set; } | Obtiene o establece si se debe insertar el objeto vinculado como un mapa de bits. |
InsertAsHtml { get; set; } | Obtiene o establece si se debe insertar el objeto vinculado como texto en formato HTML. |
InsertAsPicture { get; set; } | Obtiene o establece si se debe insertar el objeto vinculado como una imagen. |
InsertAsRtf { get; set; } | Obtiene o establece si se debe insertar el objeto vinculado en formato de texto enriquecido (RTF). |
InsertAsText { get; set; } | Obtiene o establece si se debe insertar el objeto vinculado en formato de solo texto. |
InsertAsUnicode { get; set; } | Obtiene o establece si se debe insertar el objeto vinculado como texto Unicode. |
IsDirty { get; set; } | Obtiene o establece si el resultado actual del campo ya no es correcto (obsoleto) debido a otras modificaciones realizadas al documento. |
IsLinked { get; set; } | Obtiene o establece si se debe reducir el tamaño del archivo al no almacenar datos gráficos con el documento. |
IsLocked { get; set; } | Obtiene o establece si el campo está bloqueado (no debe recalcular su resultado). |
LocaleId { get; set; } | Obtiene o establece el LCID del campo. |
ProgId { get; set; } | Obtiene o establece el tipo de aplicación de la información del enlace. |
Result { get; set; } | Obtiene o establece el texto que está entre el separador de campo y el final del campo. |
Separator { get; } | Obtiene el nodo que representa el separador de campo. Puede sernulo . |
SourceFullName { get; set; } | Obtiene o establece el nombre y la ubicación del archivo de origen. |
SourceItem { get; set; } | Obtiene o establece la parte del archivo de origen que se está vinculando. |
Start { get; } | Obtiene el nodo que representa el inicio del campo. |
virtual Type { get; } | Obtiene el tipo de campo de Microsoft Word. |
Métodos
Nombre | Descripción |
---|---|
GetFieldCode() | Devuelve el texto entre el inicio del campo y el separador de campo (o el final del campo si no hay separador). Se incluyen tanto el código de campo como el resultado de campo de los campos secundarios. |
GetFieldCode(bool) | Devuelve el texto entre el inicio del campo y el separador de campo (o el final del campo si no hay separador). |
Remove() | Elimina el campo del documento. Devuelve un nodo justo después del campo. Si el final del campo es el último hijo de su nodo padre, devuelve su párrafo padre. Si el campo ya se ha eliminado, devuelvenulo . |
Unlink() | Realiza la desvinculación del campo. |
Update() | Realiza la actualización del campo. Se lanza una excepción si el campo ya se está actualizando. |
Update(bool) | Realiza una actualización de campo. Se lanza una excepción si el campo ya se está actualizando. |
Observaciones
Para la información copiada de otra aplicación, este campo vincula esa información a su archivo fuente original mediante DDE y se actualiza automáticamente.
Ejemplos
Muestra cómo utilizar varios tipos de campos para vincularse a otros documentos en el sistema de archivos local y mostrar su contenido.
public void FieldLinkedObjectsAsText(InsertLinkedObjectAs insertLinkedObjectAs)
{
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
A continuación se muestran tres tipos de campos que podemos utilizar para mostrar el contenido de un documento vinculado en forma de texto.
// 1 - Un campo LINK:
builder.Writeln("FieldLink:\n");
InsertFieldLink(builder, insertLinkedObjectAs, "Word.Document.8", MyDir + "Document.docx", null, true);
// 2 - Un campo DDE:
builder.Writeln("FieldDde:\n");
InsertFieldDde(builder, insertLinkedObjectAs, "Excel.Sheet", MyDir + "Spreadsheet.xlsx",
"Sheet1!R1C1", true, true);
// 3 - Un campo DDEAUTO:
builder.Writeln("FieldDdeAuto:\n");
InsertFieldDdeAuto(builder, insertLinkedObjectAs, "Excel.Sheet", MyDir + "Spreadsheet.xlsx",
"Sheet1!R1C1", true);
doc.UpdateFields();
doc.Save(ArtifactsDir + "Field.LINK.DDE.DDEAUTO.docx");
}
public void FieldLinkedObjectsAsImage(InsertLinkedObjectAs insertLinkedObjectAs)
{
Document doc = new Document();
DocumentBuilder builder = new DocumentBuilder(doc);
// A continuación se muestran tres tipos de campos que podemos utilizar para mostrar el contenido de un documento vinculado en forma de imagen.
// 1 - Un campo LINK:
builder.Writeln("FieldLink:\n");
InsertFieldLink(builder, insertLinkedObjectAs, "Excel.Sheet", MyDir + "MySpreadsheet.xlsx",
"Sheet1!R2C2", true);
// 2 - Un campo DDE:
builder.Writeln("FieldDde:\n");
InsertFieldDde(builder, insertLinkedObjectAs, "Excel.Sheet", MyDir + "Spreadsheet.xlsx",
"Sheet1!R1C1", true, true);
// 3 - Un campo DDEAUTO:
builder.Writeln("FieldDdeAuto:\n");
InsertFieldDdeAuto(builder, insertLinkedObjectAs, "Excel.Sheet", MyDir + "Spreadsheet.xlsx",
"Sheet1!R1C1", true);
doc.UpdateFields();
doc.Save(ArtifactsDir + "Field.LINK.DDE.DDEAUTO.AsImage.docx");
}
/// <summary>
/// Utilice un generador de documentos para insertar un campo LINK y establecer sus propiedades según los parámetros.
/// </summary>
private static void InsertFieldLink(DocumentBuilder builder, InsertLinkedObjectAs insertLinkedObjectAs,
string progId, string sourceFullName, string sourceItem, bool shouldAutoUpdate)
{
FieldLink field = (FieldLink)builder.InsertField(FieldType.FieldLink, true);
switch (insertLinkedObjectAs)
{
case InsertLinkedObjectAs.Text:
field.InsertAsText = true;
break;
case InsertLinkedObjectAs.Unicode:
field.InsertAsUnicode = true;
break;
case InsertLinkedObjectAs.Html:
field.InsertAsHtml = true;
break;
case InsertLinkedObjectAs.Rtf:
field.InsertAsRtf = true;
break;
case InsertLinkedObjectAs.Picture:
field.InsertAsPicture = true;
break;
case InsertLinkedObjectAs.Bitmap:
field.InsertAsBitmap = true;
break;
}
field.AutoUpdate = shouldAutoUpdate;
field.ProgId = progId;
field.SourceFullName = sourceFullName;
field.SourceItem = sourceItem;
builder.Writeln("\n");
}
/// <summary>
/// Utilice un generador de documentos para insertar un campo DDE y establecer sus propiedades según los parámetros.
/// </summary>
private static void InsertFieldDde(DocumentBuilder builder, InsertLinkedObjectAs insertLinkedObjectAs, string progId,
string sourceFullName, string sourceItem, bool isLinked, bool shouldAutoUpdate)
{
FieldDde field = (FieldDde)builder.InsertField(FieldType.FieldDDE, true);
switch (insertLinkedObjectAs)
{
case InsertLinkedObjectAs.Text:
field.InsertAsText = true;
break;
case InsertLinkedObjectAs.Unicode:
field.InsertAsUnicode = true;
break;
case InsertLinkedObjectAs.Html:
field.InsertAsHtml = true;
break;
case InsertLinkedObjectAs.Rtf:
field.InsertAsRtf = true;
break;
case InsertLinkedObjectAs.Picture:
field.InsertAsPicture = true;
break;
case InsertLinkedObjectAs.Bitmap:
field.InsertAsBitmap = true;
break;
}
field.AutoUpdate = shouldAutoUpdate;
field.ProgId = progId;
field.SourceFullName = sourceFullName;
field.SourceItem = sourceItem;
field.IsLinked = isLinked;
builder.Writeln("\n");
}
/// <summary>
/// Utilice un generador de documentos para insertar un campo DDEAUTO y establecer sus propiedades según los parámetros.
/// </summary>
private static void InsertFieldDdeAuto(DocumentBuilder builder, InsertLinkedObjectAs insertLinkedObjectAs,
string progId, string sourceFullName, string sourceItem, bool isLinked)
{
FieldDdeAuto field = (FieldDdeAuto)builder.InsertField(FieldType.FieldDDEAuto, true);
switch (insertLinkedObjectAs)
{
case InsertLinkedObjectAs.Text:
field.InsertAsText = true;
break;
case InsertLinkedObjectAs.Unicode:
field.InsertAsUnicode = true;
break;
case InsertLinkedObjectAs.Html:
field.InsertAsHtml = true;
break;
case InsertLinkedObjectAs.Rtf:
field.InsertAsRtf = true;
break;
case InsertLinkedObjectAs.Picture:
field.InsertAsPicture = true;
break;
case InsertLinkedObjectAs.Bitmap:
field.InsertAsBitmap = true;
break;
}
field.ProgId = progId;
field.SourceFullName = sourceFullName;
field.SourceItem = sourceItem;
field.IsLinked = isLinked;
}
public enum InsertLinkedObjectAs
{
// ObjetoEnlazadoComoTexto
Text,
Unicode,
Html,
Rtf,
//ObjetoEnlazadoComoImagen
Picture,
Bitmap
}
Ver también
- class Field
- espacio de nombres Aspose.Words.Fields
- asamblea Aspose.Words