Notify
Contenido
[
Ocultar
]IDocumentSavingCallback.Notify method
Esto se llama para notificar el progreso de guardado del documento.
public void Notify(DocumentSavingArgs args)
Parámetro | Escribe | Descripción |
---|---|---|
args | DocumentSavingArgs | Un argumento del evento. |
Observaciones
El uso principal de esta interfaz es permitir que el código de la aplicación obtenga el estado de progreso y cancele el proceso de guardado.
Se debe generar una excepción desde la devolución de llamada de progreso para el aborto y se debe incluir en el código del consumidor.
Ejemplos
Muestra cómo administrar un documento mientras se guarda en HTML.
public void ProgressCallback(SaveFormat saveFormat, string ext)
{
Document doc = new Document(MyDir + "Big document.docx");
// Se admiten los siguientes formatos: Html, Mhtml, Epub.
HtmlSaveOptions saveOptions = new HtmlSaveOptions(saveFormat)
{
ProgressCallback = new SavingProgressCallback()
};
var exception = Assert.Throws<OperationCanceledException>(() =>
doc.Save(ArtifactsDir + $"HtmlSaveOptions.ProgressCallback.{ext}", saveOptions));
Assert.True(exception?.Message.Contains("EstimatedProgress"));
}
/// <summary>
/// Guardando la devolución de llamada de progreso. Cancele el guardado de un documento después de los segundos de "MaxDuration".
/// </summary>
public class SavingProgressCallback : IDocumentSavingCallback
{
/// <summary>
/// Centro.
/// </summary>
public SavingProgressCallback()
{
mSavingStartedAt = DateTime.Now;
}
/// <summary>
/// Método de devolución de llamada que llamó durante el guardado del documento.
/// </summary>
/// <param name="args">Guardando argumentos.</param>
public void Notify(DocumentSavingArgs args)
{
DateTime canceledAt = DateTime.Now;
double ellapsedSeconds = (canceledAt - mSavingStartedAt).TotalSeconds;
if (ellapsedSeconds > MaxDuration)
throw new OperationCanceledException($"EstimatedProgress = {args.EstimatedProgress}; CanceledAt = {canceledAt}");
}
/// <summary>
/// Fecha y hora en que se inicia el guardado del documento.
/// </summary>
private readonly DateTime mSavingStartedAt;
/// <summary>
/// Duración máxima permitida en seg.
/// </summary>
private const double MaxDuration = 0.1d;
}
Muestra cómo administrar un documento mientras se guarda en docx.
public void ProgressCallback(SaveFormat saveFormat, string ext)
{
Document doc = new Document(MyDir + "Big document.docx");
// Se admiten los siguientes formatos: Docx, FlatOpc, Docm, Dotm, Dotx.
OoxmlSaveOptions saveOptions = new OoxmlSaveOptions(saveFormat)
{
ProgressCallback = new SavingProgressCallback()
};
var exception = Assert.Throws<OperationCanceledException>(() =>
doc.Save(ArtifactsDir + $"OoxmlSaveOptions.ProgressCallback.{ext}", saveOptions));
Assert.True(exception?.Message.Contains("EstimatedProgress"));
}
/// <summary>
/// Guardando la devolución de llamada de progreso. Cancele el guardado de un documento después de los segundos de "MaxDuration".
/// </summary>
public class SavingProgressCallback : IDocumentSavingCallback
{
/// <summary>
/// Centro.
/// </summary>
public SavingProgressCallback()
{
mSavingStartedAt = DateTime.Now;
}
/// <summary>
/// Método de devolución de llamada que llamó durante el guardado del documento.
/// </summary>
/// <param name="args">Guardando argumentos.</param>
public void Notify(DocumentSavingArgs args)
{
DateTime canceledAt = DateTime.Now;
double ellapsedSeconds = (canceledAt - mSavingStartedAt).TotalSeconds;
if (ellapsedSeconds > MaxDuration)
throw new OperationCanceledException($"EstimatedProgress = {args.EstimatedProgress}; CanceledAt = {canceledAt}");
}
/// <summary>
/// Fecha y hora en que se inicia el guardado del documento.
/// </summary>
private readonly DateTime mSavingStartedAt;
/// <summary>
/// Duración máxima permitida en seg.
/// </summary>
private const double MaxDuration = 0.01d;
}
Muestra cómo administrar un documento mientras se guarda en xamlflow.
public void ProgressCallback(SaveFormat saveFormat, string ext)
{
Document doc = new Document(MyDir + "Big document.docx");
// Se admiten los siguientes formatos: XamlFlow, XamlFlowPack.
XamlFlowSaveOptions saveOptions = new XamlFlowSaveOptions(saveFormat)
{
ProgressCallback = new SavingProgressCallback()
};
var exception = Assert.Throws<OperationCanceledException>(() =>
doc.Save(ArtifactsDir + $"XamlFlowSaveOptions.ProgressCallback.{ext}", saveOptions));
Assert.True(exception?.Message.Contains("EstimatedProgress"));
}
/// <summary>
/// Guardando la devolución de llamada de progreso. Cancele el guardado de un documento después de los segundos de "MaxDuration".
/// </summary>
public class SavingProgressCallback : IDocumentSavingCallback
{
/// <summary>
/// Centro.
/// </summary>
public SavingProgressCallback()
{
mSavingStartedAt = DateTime.Now;
}
/// <summary>
/// Método de devolución de llamada que llamó durante el guardado del documento.
/// </summary>
/// <param name="args">Guardando argumentos.</param>
public void Notify(DocumentSavingArgs args)
{
DateTime canceledAt = DateTime.Now;
double ellapsedSeconds = (canceledAt - mSavingStartedAt).TotalSeconds;
if (ellapsedSeconds > MaxDuration)
throw new OperationCanceledException($"EstimatedProgress = {args.EstimatedProgress}; CanceledAt = {canceledAt}");
}
/// <summary>
/// Fecha y hora en que se inicia el guardado del documento.
/// </summary>
private readonly DateTime mSavingStartedAt;
/// <summary>
/// Duración máxima permitida en seg.
/// </summary>
private const double MaxDuration = 0.01d;
}
Ver también
- class DocumentSavingArgs
- interface IDocumentSavingCallback
- espacio de nombres Aspose.Words.Saving
- asamblea Aspose.Words