diff options
author | Svetoslav <svetoslavganov@google.com> | 2013-10-31 14:27:16 -0700 |
---|---|---|
committer | Svetoslav <svetoslavganov@google.com> | 2013-10-31 14:30:58 -0700 |
commit | d270cb9264f762257d1aadbeba9c4b38866e171c (patch) | |
tree | 3d02c1c04403b62f1e3fd5a546d40916cbf2df89 /core/java/android/print | |
parent | b207ea960911867e7c1951338df24108d37ad189 (diff) | |
download | frameworks_base-d270cb9264f762257d1aadbeba9c4b38866e171c.zip frameworks_base-d270cb9264f762257d1aadbeba9c4b38866e171c.tar.gz frameworks_base-d270cb9264f762257d1aadbeba9c4b38866e171c.tar.bz2 |
Cancel current work in PrintDocumentAdatper if printing is cancelled.
Layout and write may take some time during which the user can
cancel printing. Currently we wait for the last operation,
being write or layout, to complete before closing the print
dialog. Now in such a scenario we request a cancellation of
the ongoing operation.
bug:11329523
Change-Id: Ia9d747163cc73509369a86c8b5afc83b7ee54859
Diffstat (limited to 'core/java/android/print')
-rw-r--r-- | core/java/android/print/IPrintDocumentAdapter.aidl | 1 | ||||
-rw-r--r-- | core/java/android/print/PrintManager.java | 12 |
2 files changed, 13 insertions, 0 deletions
diff --git a/core/java/android/print/IPrintDocumentAdapter.aidl b/core/java/android/print/IPrintDocumentAdapter.aidl index 9d384fb..2b95c12 100644 --- a/core/java/android/print/IPrintDocumentAdapter.aidl +++ b/core/java/android/print/IPrintDocumentAdapter.aidl @@ -37,4 +37,5 @@ oneway interface IPrintDocumentAdapter { void write(in PageRange[] pages, in ParcelFileDescriptor fd, IWriteResultCallback callback, int sequence); void finish(); + void cancel(); } diff --git a/core/java/android/print/PrintManager.java b/core/java/android/print/PrintManager.java index bbfc307..d6d56bb 100644 --- a/core/java/android/print/PrintManager.java +++ b/core/java/android/print/PrintManager.java @@ -616,6 +616,18 @@ public final class PrintManager { } @Override + public void cancel() { + // Start not called or finish called or destroyed - nothing to do. + if (!mStartReqeusted || mFinishRequested || mDestroyed) { + return; + } + // Request cancellation of pending work if needed. + synchronized (mLock) { + cancelPreviousCancellableOperationLocked(); + } + } + + @Override public void onActivityPaused(Activity activity) { /* do nothing */ } |