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

src.com.android.printservice.recommendation.PrintServicePlugin Maven / Gradle / Ivy

/*
 * Copyright (C) 2016 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 com.android.printservice.recommendation;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.annotation.StringRes;

import java.net.InetAddress;
import java.util.List;

/**
 * Interface to be implemented by each print service plugin.
 * 

* A print service plugin is a minimal version of a real {@link android.printservice.PrintService * print service}. You cannot print using the plugin. The only functionality in the plugin is to * report the number of printers that the real service would discover. */ public interface PrintServicePlugin { /** * Call back used by the print service plugins. */ interface PrinterDiscoveryCallback { /** * Announce that something changed and the UI for this plugin should be updated. * * @param discoveredPrinters The printers discovered. */ void onChanged(@Nullable List discoveredPrinters); } /** * Get the name (a string reference) of the {@link android.printservice.PrintService print * service} with the {@link #getPackageName specified package name}. This is read once, hence * returning different data at different times is not allowed. * * @return The name of the print service as a string reference. The localization is handled * outside of the plugin. */ @StringRes int getName(); /** * The package name of the full print service. * * @return The package name */ @NonNull CharSequence getPackageName(); /** * Start the discovery plugin. * * @param callback Callbacks used by this plugin. * * @throws Exception If anything went wrong when starting the plugin */ void start(@NonNull PrinterDiscoveryCallback callback) throws Exception; /** * Stop the plugin. This can only return once the plugin is completely finished and cleaned up. * * @throws Exception If anything went wrong while stopping plugin */ void stop() throws Exception; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy