javauis/m2g_qt/javasrc/javax/microedition/m2g/ExternalResourceHandler.java
author hgs
Fri, 29 Oct 2010 11:49:32 +0300
changeset 87 1627c337e51e
parent 56 abc41079b313
permissions -rw-r--r--
v2.2.21_1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
56
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     1
/*
87
1627c337e51e v2.2.21_1
hgs
parents: 56
diff changeset
     2
* Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies).
56
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     3
* All rights reserved.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     8
*
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     9
* Initial Contributors:
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    11
*
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    12
* Contributors:
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    13
*
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    14
* Description:
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    15
*
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    16
*/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    17
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    18
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    19
package javax.microedition.m2g;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    20
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    21
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    22
/**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    23
* <p>This interface is used to load external resources that are referenced
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    24
* within a ScalableImage, namely within an SVG document in the case of SVG.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    25
* In SVGT 1.1, these resources are not required for displaying the SVG document.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    26
* If no ExternalResourceHandler is registered when creating the image,
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    27
* the engine will retrieve these resources using its own implementation
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    28
* of the requestResource method.</p>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    29
*<p>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    30
* The default engine behaviour can be overwritten by passing to {@link javax.microedition.m2g.ScalableImage#createImage createImage}
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    31
* an implementation of this interface as paramater when the default implementation
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    32
* is insufficient. For example, if the SVGImage is loaded from within a
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    33
* Jar file, the implementation will not be able to load images that
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    34
* have relative URIs (e.g., &lt;image xlink:href="myImage.png" /&gt;).
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    35
* All the external resources are requested by the engine at the time of
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    36
* the <code>createImage</code> call. Note that SVGT 1.1 does
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    37
* not contain external references to SVG files, therefore an external
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    38
* resource can not contain subsequent external resources. </p>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    39
*
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    40
* @see      javax.microedition.m2g.ScalableImage
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    41
*/
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    42
public interface ExternalResourceHandler
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    43
{
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    44
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    45
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    46
     * This method is invoked when an external resource is required by the underlying implementation.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    47
     * When the request is completed by the implementation of this handler, a notification
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    48
     * must be sent to the SVG engine through the requestCompleted() method of <code>ScalableImage</code>.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    49
     * To get a synchronous behaviour, requestCompleted() can be called in the implementation
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    50
     * of requestResource. If called later, rendering the document before
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    51
     * completing all the requests will just display the currently available content.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    52
     * Once the request is completed, the image will have to be redrawn to reflect the newly
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    53
     * available data.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    54
     * For more details on required resources, please refer to the <code>externalResourcesRequired</code>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    55
     * attribute description in the SVG specification.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    56
     *
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    57
     * @param image image that originated the external data request
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    58
     * @param URI the URI for the external resource.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    59
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    60
    public void requestResource(ScalableImage image, String URI);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    61
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    62
};