IDocumentLoadingCallback
Inhalt
[
Ausblenden
]IDocumentLoadingCallback interface
Implementieren Sie diese Schnittstelle, wenn Sie möchten, dass beim Laden eines Dokuments Ihre eigene benutzerdefinierte Methode aufgerufen wird.
public interface IDocumentLoadingCallback
Methoden
Name | Beschreibung |
---|---|
Notify(DocumentLoadingArgs) | Dies wird aufgerufen, um über den Ladefortschritt des Dokuments zu informieren. |
Beispiele
Zeigt, wie der Benutzer benachrichtigt wird, wenn das Laden des Dokuments die erwartete Ladezeit überschreitet.
public void ProgressCallback()
{
LoadingProgressCallback progressCallback = new LoadingProgressCallback();
LoadOptions loadOptions = new LoadOptions { ProgressCallback = progressCallback };
try
{
Document doc = new Document(MyDir + "Big document.docx", loadOptions);
}
catch (OperationCanceledException exception)
{
Console.WriteLine(exception.Message);
// Problem mit der Ladedauer behandeln.
}
}
/// <summary>
/// Das Laden eines Dokuments nach den „MaxDuration“-Sekunden abbrechen.
/// </summary>
public class LoadingProgressCallback : IDocumentLoadingCallback
{
/// <summary>
/// Ctr.
/// </summary>
public LoadingProgressCallback()
{
mLoadingStartedAt = DateTime.Now;
}
/// <summary>
/// Callback-Methode, die beim Laden des Dokuments aufgerufen wurde.
/// </summary>
/// <param name="args">Argumente werden geladen.</param>
public void Notify(DocumentLoadingArgs args)
{
DateTime canceledAt = DateTime.Now;
double ellapsedSeconds = (canceledAt - mLoadingStartedAt).TotalSeconds;
if (ellapsedSeconds > MaxDuration)
throw new OperationCanceledException($"EstimatedProgress = {args.EstimatedProgress}; CanceledAt = {canceledAt}");
}
/// <summary>
/// Datum und Uhrzeit, wann das Laden des Dokuments gestartet wird.
/// </summary>
private readonly DateTime mLoadingStartedAt;
/// <summary>
/// Maximal zulässige Dauer in Sekunden.
/// </summary>
private const double MaxDuration = 0.5;
}
Siehe auch
- namensraum Aspose.Words.Loading
- Montage Aspose.Words