/*
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You 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 org.apache.batik.ext.awt.image.spi;
import org.apache.batik.ext.awt.image.renderable.Filter;
import org.apache.batik.util.ParsedURL;
This type of Image tag registy entry is used for 'odd' URL types.
Ussually this means that the URL uses a non-standard protocol. In
these cases you should be aware that in order for the construction
of the URL object to succeed you must register a @see
URLStreamHandler using one of the methods listed in
See Also: Version: $Id: URLRegistryEntry.java 1808001 2017-09-11 09:51:29Z ssteiner $
/**
* This type of Image tag registy entry is used for 'odd' URL types.
* Ussually this means that the URL uses a non-standard protocol. In
* these cases you should be aware that in order for the construction
* of the URL object to succeed you must register a @see
* URLStreamHandler using one of the methods listed in
* @see java.net.URL#URL(java.lang.String, java.lang.String, int, java.lang.String)
*
* @version $Id: URLRegistryEntry.java 1808001 2017-09-11 09:51:29Z ssteiner $
*/
public interface URLRegistryEntry extends RegistryEntry {
Check if the URL references an image that can be
handled by this format handler. Generally speaking
this should not open the URL. The decision should
be based on the structure of the URL (such as
the protocol in use).
If you don't care about the structure of the URL and only about
the contents of the URL you should register as a
StreamRegistryEntry, so the URL "connection" will be made
only once.
Params: - url – The URL to inspect.
/**
* Check if the URL references an image that can be
* handled by this format handler. Generally speaking
* this should not open the URL. The decision should
* be based on the structure of the URL (such as
* the protocol in use).<p>
*
* If you don't care about the structure of the URL and only about
* the contents of the URL you should register as a
* StreamRegistryEntry, so the URL "connection" will be made
* only once.
*
* @param url The URL to inspect.
*/
boolean isCompatibleURL(ParsedURL url);
Decode the URL into a RenderableImage, here you should feel
free to open the URL yourself.
This should only return a broken link image if the image
is clearly of this format, but is unreadable for some reason.
otherwise return null.
If all entries refuse the url or return null then the registry
will automatically return a broken link image for you.
Params: - url – The url that reference the image.
- needRawData – If true the image returned should not have
any default color correction the file may
specify applied.
/**
* Decode the URL into a RenderableImage, here you should feel
* free to open the URL yourself.<P>
*
* This should only return a broken link image if the image
* is clearly of this format, but is unreadable for some reason.
* otherwise return null.<p>
*
* If all entries refuse the url or return null then the registry
* will automatically return a broken link image for you.
*
* @param url The url that reference the image.
* @param needRawData If true the image returned should not have
* any default color correction the file may
* specify applied.
*/
Filter handleURL(ParsedURL url, boolean needRawData);
}