All Downloads are FREE. Search and download functionalities are using the official Maven repository.

src.android.print.PrintJob Maven / Gradle / Ivy

Go to download

A library jar that provides APIs for Applications written for the Google Android Platform.

There is a newer version: 15-robolectric-12650502
Show newest version
/*
 * Copyright (C) 2013 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package android.print;

import android.annotation.NonNull;
import android.annotation.Nullable;

import java.util.Objects;

/**
 * This class represents a print job from the perspective of an
 * application. It contains behavior methods for performing operations
 * on it as well as methods for querying its state. A snapshot of the
 * print job state is represented by the {@link PrintJobInfo} class.
 * The state of a print job may change over time. An application receives
 * instances of this class when creating a print job or querying for
 * its print jobs.
 */
public final class PrintJob {

    private final @NonNull PrintManager mPrintManager;

    private @NonNull PrintJobInfo mCachedInfo;

    PrintJob(@NonNull PrintJobInfo info, @NonNull PrintManager printManager) {
        mCachedInfo = info;
        mPrintManager = printManager;
    }

    /**
     * Gets the unique print job id.
     *
     * @return The id.
     */
    public @Nullable PrintJobId getId() {
        return mCachedInfo.getId();
    }

    /**
     * Gets the {@link PrintJobInfo} that describes this job.
     * 

* Node:The returned info object is a snapshot of the * current print job state. Every call to this method returns a fresh * info object that reflects the current print job state. *

* * @return The print job info. */ public @NonNull PrintJobInfo getInfo() { if (isInImmutableState()) { return mCachedInfo; } PrintJobInfo info = mPrintManager.getPrintJobInfo(mCachedInfo.getId()); if (info != null) { mCachedInfo = info; } return mCachedInfo; } /** * Cancels this print job. You can request cancellation of a * queued, started, blocked, or failed print job. * * @see #isQueued() * @see #isStarted() * @see #isBlocked() * @see #isFailed() */ public void cancel() { final int state = getInfo().getState(); if (state == PrintJobInfo.STATE_QUEUED || state == PrintJobInfo.STATE_STARTED || state == PrintJobInfo.STATE_BLOCKED || state == PrintJobInfo.STATE_FAILED) { mPrintManager.cancelPrintJob(mCachedInfo.getId()); } } /** * Restarts this print job. You can request restart of a failed * print job. * * @see #isFailed() */ public void restart() { if (isFailed()) { mPrintManager.restartPrintJob(mCachedInfo.getId()); } } /** * Gets whether this print job is queued. Such a print job is * ready to be printed. You can request a cancellation via * {@link #cancel()}. * * @return Whether the print job is queued. * * @see #cancel() */ public boolean isQueued() { return getInfo().getState() == PrintJobInfo.STATE_QUEUED; } /** * Gets whether this print job is started. Such a print job is * being printed. You can request a cancellation via * {@link #cancel()}. * * @return Whether the print job is started. * * @see #cancel() */ public boolean isStarted() { return getInfo().getState() == PrintJobInfo.STATE_STARTED; } /** * Gets whether this print job is blocked. Such a print job is halted * due to an abnormal condition. You can request a cancellation via * {@link #cancel()}. * * @return Whether the print job is blocked. * * @see #cancel() */ public boolean isBlocked() { return getInfo().getState() == PrintJobInfo.STATE_BLOCKED; } /** * Gets whether this print job is completed. Such a print job * is successfully printed. You can neither cancel nor restart * such a print job. * * @return Whether the print job is completed. */ public boolean isCompleted() { return getInfo().getState() == PrintJobInfo.STATE_COMPLETED; } /** * Gets whether this print job is failed. Such a print job is * not successfully printed due to an error. You can request * a restart via {@link #restart()} or cancel via {@link #cancel()}. * * @return Whether the print job is failed. * * @see #restart() * @see #cancel() */ public boolean isFailed() { return getInfo().getState() == PrintJobInfo.STATE_FAILED; } /** * Gets whether this print job is cancelled. Such a print job was * cancelled as a result of a user request. This is a final state. * You cannot restart such a print job. * * @return Whether the print job is cancelled. */ public boolean isCancelled() { return getInfo().getState() == PrintJobInfo.STATE_CANCELED; } private boolean isInImmutableState() { final int state = mCachedInfo.getState(); return state == PrintJobInfo.STATE_COMPLETED || state == PrintJobInfo.STATE_CANCELED; } @Override public boolean equals(@Nullable Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (getClass() != obj.getClass()) { return false; } PrintJob other = (PrintJob) obj; return Objects.equals(mCachedInfo.getId(), other.mCachedInfo.getId()); } @Override public int hashCode() { PrintJobId printJobId = mCachedInfo.getId(); if (printJobId == null) { return 0; } else { return printJobId.hashCode(); } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy