Warning
Contenido
[
Ocultar
]IWarningCallback.Warning method
Aspose.Words invoca este método cuando encuentra algún problema durante la carga del documento o al guardarlo que podría resultar en la pérdida de formato o fidelidad de los datos.
public void Warning(WarningInfo info)
Ejemplos
Muestra cómo configurar la propiedad para encontrar la coincidencia más cercana para una fuente faltante entre las fuentes de fuentes disponibles.
public void EnableFontSubstitution()
{
// Abra un documento que contenga texto formateado con una fuente que no existe en ninguna de nuestras fuentes de fuentes.
Document doc = new Document(MyDir + "Missing font.docx");
// Asigna una devolución de llamada para manejar las advertencias de sustitución de fuentes.
HandleDocumentSubstitutionWarnings substitutionWarningHandler = new HandleDocumentSubstitutionWarnings();
doc.WarningCallback = substitutionWarningHandler;
// Establece un nombre de fuente predeterminado y habilita la sustitución de fuentes.
FontSettings fontSettings = new FontSettings();
fontSettings.SubstitutionSettings.DefaultFontSubstitution.DefaultFontName = "Arial";
;
fontSettings.SubstitutionSettings.FontInfoSubstitution.Enabled = true;
// Las métricas de fuente originales deben usarse después de la sustitución de fuentes.
doc.LayoutOptions.KeepOriginalFontMetrics = true;
// Recibiremos una advertencia de sustitución de fuente si guardamos un documento al que le falta una fuente.
doc.FontSettings = fontSettings;
doc.Save(ArtifactsDir + "FontSettings.EnableFontSubstitution.pdf");
using (IEnumerator<WarningInfo> warnings = substitutionWarningHandler.FontWarnings.GetEnumerator())
while (warnings.MoveNext())
Console.WriteLine(warnings.Current.Description);
// También podemos verificar las advertencias en la colección y borrarlas.
Assert.AreEqual(WarningSource.Layout, substitutionWarningHandler.FontWarnings[0].Source);
Assert.AreEqual(
"Font '28 Days Later' has not been found. Using 'Calibri' font instead. Reason: alternative name from document.",
substitutionWarningHandler.FontWarnings[0].Description);
substitutionWarningHandler.FontWarnings.Clear();
Assert.That(substitutionWarningHandler.FontWarnings, Is.Empty);
}
public class HandleDocumentSubstitutionWarnings : IWarningCallback
{
/// <summary>
/// Se llama cada vez que ocurre una advertencia durante la carga/guardado.
/// </summary>
public void Warning(WarningInfo info)
{
if (info.WarningType == WarningType.FontSubstitution)
FontWarnings.Warning(info);
}
public WarningInfoCollection FontWarnings = new WarningInfoCollection();
}
Ver también
- class WarningInfo
- interface IWarningCallback
- espacio de nombres Aspose.Words
- asamblea Aspose.Words