javauis/m2g_qt/javasrc/com/nokia/microedition/m2g/M2GSVGAnimator.java
author hgs
Fri, 23 Jul 2010 12:27:20 +0300
changeset 56 abc41079b313
permissions -rw-r--r--
v2.2.7_1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
56
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     1
/*
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
     2
* Copyright (c) 2005-2007 Nokia Corporation and/or its subsidiary(-ies).
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
package com.nokia.microedition.m2g;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    19
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    20
import javax.microedition.m2g.*;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    21
import java.util.*;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    22
import javax.microedition.lcdui.*;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    23
import javax.microedition.lcdui.game.GameCanvas;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    24
import java.lang.ref.WeakReference;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    25
import com.nokia.mj.impl.rt.support.Finalizer;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    26
import com.nokia.mj.impl.utils.Logger;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    27
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    28
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    29
public class M2GSVGAnimator extends SVGAnimator 
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    30
{
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    31
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    32
    // STATIC CONSTANTS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    33
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    34
    private static final String ANIMATOR_CANVAS_BASE_CLASS =
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    35
        "javax.microedition.lcdui.Canvas";
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    36
    // Exception text
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    37
    /* Optimization: static finals changed to local variables
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    38
    private static final String COMPONENT_BASE_CLASS_NOT_SUPPORTED_ESTR =
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    39
    "The requested componentBaseClass is not supported by the implementation.";
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    40
    private static final String ILLEGAL_TIME_INCREMENT_ESTR =
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    41
    "The timeIncrement is less than or equal to zero.";
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    42
    private static final String ANIMATOR_PLAY_ESTR =
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    43
    "The animator is not currently in the stopped or paused state.";
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    44
    private static final String ANIMATOR_PAUSE_ESTR =
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    45
    "The animator is not in the playing  state.";
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    46
    private static final String ANIMATOR_STOP_ESTR =
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    47
    "The animator is not in the playing or paused state.";
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    48
    private static final String INVALID_RUNNABLE_ESTR =
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    49
    "The runnable is null.";
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    50
    private static final String ANIMATOR_IS_STOPPED_ESTR =
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    51
    "The animator is in the stopped state.";
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    52
    private static final String RUNNABLE_IS_NULL_ESTR =
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    53
    "The runnable is null.";
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    54
    private static final String ANIMATOR_INVOKE_ESTR =
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    55
    "The animator is in the stopped state.";
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    56
    */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    57
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    58
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    59
    // VARIABLES
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    60
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    61
    private M2GSVGCanvas    iSVGCanvas      = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    62
    private Finalizer mFinalizer;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    63
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    64
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    65
    // METHODS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    66
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    67
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    68
     * Constructor
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    69
     * @param aImage
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    70
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    71
    protected M2GSVGAnimator(SVGImage aImage)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    72
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    73
				System.out.println("P-Do In  M2GSVGAnimator(SVGImage aImage).");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    74
        iSVGCanvas = new M2GSVGCanvas(false, aImage);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    75
        mFinalizer = new Finalizer()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    76
        {	
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    77
            public void finalizeImpl()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    78
            {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    79
            		System.out.println("P-Do In  M2GSVGAnimator(SVGImage aImage).mFinalizer creation doFinalize" );
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    80
                doFinalize();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    81
            }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    82
        };
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    83
				System.out.println("P-Do In  M2GSVGAnimator(SVGImage aImage).mFinalizer M2GDestroyer creation " );      
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    84
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    85
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    86
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    87
     * @see javax.microedition.m2g.SVGAnimator#getTargetComponent()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    88
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    89
    public Object getTargetComponent()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    90
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    91
        return iSVGCanvas;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    92
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    93
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    94
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    95
    * @see javax.microedition.m2g.SVGAnimator#getTimeIncrement()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    96
    */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    97
    public float getTimeIncrement()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    98
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
    99
        return iSVGCanvas.getTimeIncrement();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   100
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   101
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   102
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   103
    * @see javax.microedition.m2g.SVGAnimator#invokeAndWait()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   104
    */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   105
    public void invokeAndWait(java.lang.Runnable runnable)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   106
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   107
        if (runnable == null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   108
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   109
            throw new NullPointerException(
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   110
                /*SF*/"The runnable is null."/*SF*/);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   111
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   112
        if (iSVGCanvas.isStopped())
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   113
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   114
            throw new IllegalStateException(
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   115
                /*SF*/"The animator is in the stopped state."/*SF*/);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   116
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   117
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "invokeAndWait()");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   118
        runnable.run();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   119
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   120
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   121
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   122
     * @see javax.microedition.m2g.SVGAnimator#invokeLater()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   123
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   124
    public void invokeLater(java.lang.Runnable runnable)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   125
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   126
        if (runnable == null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   127
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   128
            throw new NullPointerException(
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   129
                /*SF*/"The runnable is null."/*SF*/);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   130
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   131
        if (iSVGCanvas.isStopped())
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   132
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   133
            throw new IllegalStateException(
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   134
                /*SF*/"The animator is in the stopped state."/*SF*/);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   135
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   136
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "invokeLater()");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   137
        Thread thread = new Thread(runnable);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   138
        thread.start();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   139
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   140
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   141
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   142
     * @see javax.microedition.m2g.SVGAnimator#pause()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   143
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   144
    public void pause()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   145
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   146
        if (!iSVGCanvas.isPlaying())
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   147
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   148
            throw new IllegalStateException(
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   149
                /*SF*/"The animator is not in the playing or paused state."/*SF*/);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   150
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   151
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "pause()");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   152
        iSVGCanvas.pause();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   153
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   154
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   155
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   156
    * @see javax.microedition.m2g.SVGAnimator#play()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   157
    */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   158
    public void play()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   159
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   160
				System.out.println("P-Do In  M2GSVGAnimator Play " );      
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   161
        if (iSVGCanvas.isPlaying())
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   162
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   163
            throw new IllegalStateException(
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   164
                /*SF*/"The animator is not currently in the stopped or paused state."/*SF*/);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   165
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   166
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "play()");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   167
        System.out.println("P-Do In  M2GSVGAnimator canvas sPlay " );      
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   168
        iSVGCanvas.play();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   169
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   170
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   171
    private void doFinalize()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   172
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   173
        if (mFinalizer != null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   174
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   175
						System.out.println("P-Do Finalize called");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   176
            registeredFinalize();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   177
            mFinalizer = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   178
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   179
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   180
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   181
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   182
     * Finalize
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   183
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   184
    synchronized void registeredFinalize()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   185
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   186
        iSVGCanvas.cancel();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   187
        iSVGCanvas = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   188
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   189
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   190
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   191
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   192
     * @see javax.microedition.m2g.SVGAnimator#setSVGEventListener()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   193
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   194
    public void setSVGEventListener(SVGEventListener svgEventListener)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   195
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   196
        iSVGCanvas.setEventListener(svgEventListener);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   197
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   198
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   199
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   200
     * @see javax.microedition.m2g.SVGAnimator#setTimeIncrement()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   201
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   202
    public void setTimeIncrement(float timeIncrement)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   203
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   204
    		System.out.println("P-Do In  M2GSVGAnimator TimeIncrement.." );      
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   205
        if (timeIncrement <= 0)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   206
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   207
            throw new IllegalArgumentException(
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   208
                /*SF*/"The time increment is less than or equal to zero."/*SF*/);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   209
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   210
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "setTimeIncrement() - "
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   211
                   + timeIncrement);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   212
        iSVGCanvas.setTimeIncrement(timeIncrement);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   213
        System.out.println("P-Do In  M2GSVGAnimator Canvas Time Increment.." );      
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   214
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   215
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   216
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   217
     * @see javax.microedition.m2g.SVGAnimator#stop()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   218
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   219
    public void stop()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   220
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   221
    		System.out.println("P-Do In  M2GSVGAnimator Stoop " );      
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   222
        if (iSVGCanvas.isStopped())
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   223
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   224
            throw new IllegalStateException(
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   225
                /*SF*/"The animator is not in the playing or paused state."/*SF*/);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   226
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   227
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "stop()");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   228
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   229
        iSVGCanvas.stop();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   230
        System.out.println("P-Do In  M2GSVGAnimator Canvas Stop" );      
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   231
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   232
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   233
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   234
    // STATIC METHODS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   235
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   236
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   237
     * Builds animator
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   238
     * @param svgImage -
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   239
     * @return SVGAnimator
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   240
     * @see javax.microedition.m2g.SVGAnimator#createAnimator()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   241
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   242
    public static SVGAnimator buildAnimator(SVGImage svgImage)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   243
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   244
	   		System.out.println("P-Do SVGAnimator buildAnimator.");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   245
        if (svgImage == null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   246
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   247
        		System.out.println("P-Do SVGAnimator buildAnimator.NullPointerException.");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   248
            throw new NullPointerException();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   249
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   250
        System.out.println("P-Do SVGAnimator buildAnimator.retunrning handle");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   251
        return new M2GSVGAnimator(svgImage);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   252
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   253
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   254
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   255
     * Builds animator
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   256
     * @param svgImage -
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   257
     * @param componentBaseClass -
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   258
     * @return SVGAnimator
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   259
     * @see javax.microedition.m2g.SVGAnimator#createAnimator()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   260
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   261
    public static SVGAnimator buildAnimator(
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   262
        SVGImage svgImage, String componentBaseClass)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   263
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   264
        if (svgImage == null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   265
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   266
            throw new NullPointerException();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   267
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   268
        if ((componentBaseClass != null) &&
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   269
                (!componentBaseClass.equals(ANIMATOR_CANVAS_BASE_CLASS)))
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   270
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   271
            throw new IllegalArgumentException(
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   272
                /*SF*/"The requested componentBaseClass is not supported by the implementation."/*SF*/);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   273
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   274
        return buildAnimator(svgImage);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   275
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   276
}
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   277
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   278
//--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   279
// OTHER CLASSES
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   280
//--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   281
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   282
/**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   283
 * Canvas
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   284
 */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   285
class M2GSVGCanvas extends GameCanvas implements M2GDOMChangeObserver
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   286
{
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   287
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   288
    // STATIC CONSTANTS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   289
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   290
    public static final int STATE_STOPPED = 1;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   291
    public static final int STATE_PLAYING = 2;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   292
    public static final int STATE_PAUSED  = 3;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   293
    public static final float DEFAULT_DELTA_TIME = 0.1f;  // (10fps) - defined by specs
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   294
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   295
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   296
    // VARIABLES
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   297
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   298
    private int                 iState;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   299
    private SVGImage            iSVGImage;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   300
    private ScalableGraphics    iSg;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   301
    private Graphics            iOffscreen      = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   302
    private M2GSVGSVGElement    iRootElement    = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   303
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   304
    private float               iDeltaTime;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   305
    private Timer               iTimer          = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   306
    private SVGCanvasTask       iTask           = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   307
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   308
    private SVGEventListener    iEventListener  = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   309
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   310
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   311
     * True if the GameCanvas is in background or false otherwise
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   312
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   313
    private boolean iWasPlaying                 = false;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   314
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   315
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   316
    // METHODS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   317
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   318
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   319
     * @see javax.microedition.lcdui.game.GameCanvas#GameCanvas()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   320
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   321
    public M2GSVGCanvas(boolean aSuppressKeyEvents, SVGImage aSVGImage)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   322
    {					
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   323
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   324
        super(aSuppressKeyEvents);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   325
				System.out.println("P-Do M2GSVGCanvas Canvas called");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   326
        // get the instance to the Graphics of the offscreen buffer
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   327
        iOffscreen = getGraphics();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   328
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   329
        iSVGImage     = aSVGImage;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   330
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   331
        // down-casting to M2GDocument/M2GSVGSVGElement to have access to internal methods
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   332
        M2GDocument doc = (M2GDocument)iSVGImage.getDocument();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   333
        iRootElement  = (M2GSVGSVGElement)iSVGImage.getDocument().getDocumentElement();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   334
        
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   335
				System.out.println("P-Do M2GSVGCanvas Doc and RootElement Created");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   336
        iState = STATE_STOPPED;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   337
        // Create render context
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   338
        iSg = ScalableGraphics.createInstance();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   339
        iSg.setRenderingQuality(ScalableGraphics.RENDERING_QUALITY_HIGH);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   340
        iDeltaTime = DEFAULT_DELTA_TIME;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   341
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   342
        doc.registerDOMChangeObserver(this);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   343
        
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   344
        System.out.println("P-Do M2GSVGCanvas Canvas Registered Dom Observer");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   345
        
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   346
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "Ctor - delta time:"
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   347
                   + iDeltaTime + ", state:" + iState);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   348
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   349
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   350
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   351
     * Handles any change in DOM.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   352
     * <br>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   353
     * While in PAUSE state, SVGAnimator must repaint any changes in SVGImage
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   354
     * done via the API (e.g. setTrait(), insertBefore())
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   355
     * <br>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   356
     * @see M2GDOMChangeObserver.notifyDOMChange()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   357
     * @since S60 3.2
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   358
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   359
    public void notifyDOMChange()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   360
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   361
        if (isPaused())
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   362
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   363
            repaint();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   364
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   365
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   366
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   367
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   368
     * Cancel a timed task
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   369
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   370
    public void cancel()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   371
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   372
        if (iTimer != null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   373
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   374
            iTimer.cancel();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   375
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   376
        if (iTask != null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   377
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   378
            iTask.cancel();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   379
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   380
        iTask = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   381
        iTimer = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   382
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   383
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   384
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   385
     * Returns event listener
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   386
     * @return event listener
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   387
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   388
    public synchronized SVGEventListener getEventListener()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   389
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   390
        return iEventListener;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   391
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   392
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   393
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   394
     * @see javax.microedition.m2g.SVGAnimator#getTimeIncrement()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   395
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   396
    public synchronized float getTimeIncrement()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   397
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   398
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "getTimeIncrement() - "
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   399
                   + iDeltaTime);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   400
        return iDeltaTime;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   401
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   402
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   403
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   404
     * Increases the increment time of the SVGImage.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   405
     * Increment is done only if the playing state is active.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   406
     * @see javax.microedition.m2g.SVGImage#incrementTime()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   407
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   408
    public synchronized void increaseCurrentTime(float time)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   409
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   410
        if (iState == STATE_PLAYING)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   411
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   412
            // update the time only in java side
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   413
            // the time in engine side is updated during rendering
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   414
            iRootElement.incrementTimeNoUpdate(time);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   415
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   416
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   417
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   418
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   419
    * Checks if playing
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   420
    * @return true if playing
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   421
    */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   422
    public synchronized boolean isPlaying()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   423
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   424
        return iState == STATE_PLAYING;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   425
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   426
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   427
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   428
     * Checks if paused
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   429
     * @return true if paused
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   430
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   431
    public synchronized boolean isPaused()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   432
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   433
        return iState == STATE_PAUSED;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   434
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   435
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   436
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   437
     * Checks if stopped
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   438
     * @return true if stopped
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   439
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   440
    public synchronized boolean isStopped()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   441
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   442
        return iState == STATE_STOPPED;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   443
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   444
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   445
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   446
     * @see javax.microedition.lcdui.Canvas#keyPressed()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   447
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   448
    protected synchronized void keyPressed(int keyCode)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   449
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   450
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "keyPressed() - " + keyCode);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   451
        if (iEventListener != null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   452
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   453
            iEventListener.keyPressed(keyCode);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   454
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   455
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   456
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   457
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   458
     * @see javax.microedition.lcdui.Canvas#keyReleased()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   459
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   460
    protected synchronized void keyReleased(int keyCode)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   461
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   462
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "keyReleased() - " + keyCode);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   463
        if (iEventListener != null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   464
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   465
            iEventListener.keyReleased(keyCode);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   466
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   467
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   468
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   469
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   470
     * @see javax.microedition.lcdui.Canvas#pointerPressed()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   471
     * @see javax.microedition.m2g.SVGEventListener#pointerPressed()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   472
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   473
    protected synchronized void pointerPressed(int x, int y)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   474
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   475
        Logger.LOG(Logger.EJavaUI, Logger.EInfo,
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   476
                   "pointerPressed() - x:" + x + ", y:" + y);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   477
        if (iEventListener != null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   478
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   479
            iEventListener.pointerPressed(x, y);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   480
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   481
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   482
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   483
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   484
     * @see javax.microedition.lcdui.Canvas#pointerReleased()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   485
     * @see javax.microedition.m2g.SVGEventListener#pointerReleased()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   486
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   487
    protected synchronized void pointerReleased(int x, int y)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   488
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   489
        Logger.LOG(Logger.EJavaUI, Logger.EInfo,
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   490
                   "pointerReleased() - x:" + x + ", y:" + y);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   491
        if (iEventListener != null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   492
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   493
            iEventListener.pointerReleased(x, y);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   494
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   495
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   496
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   497
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   498
     * @see javax.microedition.lcdui.game.GameCanvas#paint()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   499
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   500
    public void paint(Graphics g)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   501
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   502
        // Clears bitmap
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   503
        System.out.println("P-Do M2GSVGAnimator Paint");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   504
        g.setColor(255, 255, 255);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   505
        g.fillRect(0, 0, getWidth(), getHeight());
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   506
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   507
        try
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   508
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   509
        		System.out.println("P-Do M2GSVGAnimatorBind Target");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   510
            iSg.bindTarget(g);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   511
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   512
						System.out.println("P-Do M2GSVGAnimatorBind Target");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   513
            // NOTE: Source is defaultly fully opaque
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   514
            iSg.render(0, 0, iSVGImage);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   515
            System.out.println("P-Do M2GSVGAnimatorBind Target");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   516
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   517
        finally
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   518
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   519
        		System.out.println("P-Do M2GSVGAnimator Release Target");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   520
            iSg.releaseTarget();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   521
            System.out.println("P-Out M2GSVGAnimator Release Target");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   522
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   523
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   524
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   525
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   526
     * Paints a frame to the offscreen of this GameCanvas
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   527
     * @note GameCanvas.getGraphics() is not used since it always creates a new instance of Graphics
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   528
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   529
    public void paintToOffscreen()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   530
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   531
        paint(iOffscreen);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   532
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   533
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   534
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   535
     * @see javax.microedition.m2g.SVGAnimator#setSVGEventListener()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   536
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   537
    public synchronized void setEventListener(SVGEventListener eventListener)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   538
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   539
        iEventListener = eventListener;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   540
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   541
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   542
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   543
     * @see javax.microedition.m2g.SVGAnimator#setTimeIncrement()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   544
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   545
    public synchronized void setTimeIncrement(float aDeltaTime)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   546
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   547
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "setTimeIncrement() - "
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   548
                   + aDeltaTime);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   549
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   550
        iDeltaTime = aDeltaTime;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   551
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   552
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   553
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   554
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   555
     * @see javax.microedition.lcdui.Canvas#showNotify()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   556
     * @see javax.microedition.m2g.SVGEventListener#showNotify()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   557
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   558
    protected synchronized void showNotify()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   559
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   560
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "showNotify()");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   561
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   562
        if (iEventListener != null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   563
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   564
            iEventListener.showNotify();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   565
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   566
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   567
        // A common use-case could be that the developer plays the animation by themselves
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   568
        // in SVGEventListener.showNotify().
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   569
        // Therefore we play the animation only if the developer didn't resume it already.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   570
        if (iWasPlaying)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   571
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   572
            iWasPlaying = false;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   573
            play();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   574
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   575
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   576
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   577
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   578
     * @see javax.microedition.lcdui.Canvas#hideNotify()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   579
     * @see javax.microedition.m2g.SVGEventListener#hideNotify()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   580
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   581
    protected synchronized void hideNotify()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   582
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   583
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "hideNotify()");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   584
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   585
        if (iEventListener != null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   586
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   587
            iEventListener.hideNotify();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   588
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   589
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   590
        // A common use-case could be that developer pause the animation by themselves
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   591
        // in SVGEventListener.hideNotify().
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   592
        // Therefore we pause the animation only if the developer didn't pause it already.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   593
        if (isPlaying())
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   594
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   595
            pause();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   596
            iWasPlaying = true;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   597
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   598
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   599
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   600
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   601
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   602
     * @see javax.microedition.lcdui.Canvas#sizeChanged()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   603
     * @see javax.microedition.m2g.SVGEventListener#sizeChanged()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   604
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   605
    protected synchronized void sizeChanged(int w, int h)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   606
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   607
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "sizeChanged() - w:"
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   608
                   + w + ", h:" + h);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   609
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   610
        // get a new instance of offscreen Graphics since the Graphics object
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   611
        // does not update its size or clipping area.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   612
        // If not updating this, the GameCanvas is clipped when it is switched
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   613
        // to full-screen
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   614
        if (iOffscreen != null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   615
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   616
            // sizeChanged() is called twice when the Canvas is set as Displayable.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   617
            // If we try to get the Graphics object (first time), the Graphics object is not
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   618
            // fully initialized, so GameCanvas.getGraphics() will throw a NullPointerException
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   619
            iOffscreen = getGraphics();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   620
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   621
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   622
        if (iSVGImage != null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   623
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   624
            iSVGImage.setViewportWidth(w);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   625
            iSVGImage.setViewportHeight(h);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   626
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   627
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   628
        if (iEventListener != null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   629
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   630
            iEventListener.sizeChanged(w, h);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   631
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   632
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   633
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   634
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   635
     * @see javax.microedition.m2g.SVGAnimator#play()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   636
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   637
    public synchronized void play()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   638
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   639
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "play()");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   640
				System.out.println("P-Do M2GSVGAnimator Play )= Target");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   641
        if (iState == STATE_PLAYING)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   642
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   643
            // don't do anything if animation is already playing
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   644
            return;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   645
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   646
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   647
        if ((iState == STATE_PAUSED)||(iState == STATE_STOPPED))
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   648
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   649
            iTask = new SVGCanvasTask(this);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   650
            iTimer = new Timer();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   651
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   652
        iState = STATE_PLAYING;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   653
        if (iTimer != null && iTask != null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   654
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   655
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   656
            iTimer.schedule(iTask,0,(long)(iDeltaTime*1000.0f));
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   657
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   658
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   659
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   660
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   661
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   662
     * @see javax.microedition.m2g.SVGAnimator#pause()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   663
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   664
    public synchronized void pause()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   665
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   666
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "pause()");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   667
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   668
        if (iState == STATE_PLAYING)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   669
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   670
            iTask.cancel();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   671
            iTask = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   672
            iTimer.cancel();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   673
            iTimer = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   674
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   675
        iState = STATE_PAUSED;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   676
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   677
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   678
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   679
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   680
     * @see javax.microedition.m2g.SVGAnimator#stop()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   681
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   682
    public synchronized void stop()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   683
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   684
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "stop()");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   685
        if (iState == STATE_PLAYING)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   686
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   687
            iTask.cancel();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   688
            iTask = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   689
            iTimer.cancel();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   690
            iTimer = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   691
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   692
        iState = STATE_STOPPED;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   693
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   694
}
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   695
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   696
/**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   697
 * Timer task for rendering frames
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   698
 */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   699
class SVGCanvasTask extends TimerTask
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   700
{
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   701
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   702
    // VARIABLES
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   703
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   704
    // private WeakReference   iWeakCanvas;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   705
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   706
    private M2GSVGCanvas    iCanvas                 = null;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   707
    private long           iPrevTime        = 0;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   708
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   709
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   710
    // METHODS
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   711
    //--------------------------------------------------
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   712
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   713
     * Constructor
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   714
     * @param aCanvas SVG canvas
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   715
     */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   716
    public SVGCanvasTask(M2GSVGCanvas aCanvas)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   717
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   718
        // iWeakCanvas = new WeakReference(aCanvas);
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   719
        // iCanvas = (M2GSVGCanvas)iWeakCanvas.get();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   720
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   721
        iCanvas = aCanvas;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   722
        iPrevTime = System.currentTimeMillis();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   723
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   724
    /**
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   725
        * Updates the animation time and generates frames which get flushed to the screen
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   726
        * <br>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   727
        * * @note The timing for the next frame is decided upon the max(iDeltaTime*1000, elapsedTime)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   728
          * iDeltaTime:  FrameTime set by client.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   729
          * elapsedTime: Actual Time taken for rendering
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   730
              the  max(iDeltaTime*1000, elapsedTime) will be incremented on the SVGElement
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   731
        * @note rendering will be done only in PLAY state.
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   732
        * @note While in PAUSE state, SVGAnimator will repaint any changes done
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   733
        * to SVGImage via <code>M2GDOMChangeObserver.notifyDOMChange()</code>
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   734
        */
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   735
    public void run()
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   736
    {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   737
        Logger.LOG(Logger.EJavaUI, Logger.EInfo,
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   738
                   "SVGCanvasTask: run() - begin");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   739
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   740
        if (iCanvas == null)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   741
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   742
            return;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   743
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   744
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   745
        try
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   746
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   747
            synchronized (iCanvas)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   748
            {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   749
                long elapsedTime = System.currentTimeMillis()- iPrevTime;
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   750
                if (elapsedTime > 0)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   751
                    iCanvas.increaseCurrentTime((float)(elapsedTime/ 1000.));
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   752
                iPrevTime = System.currentTimeMillis();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   753
                iCanvas.paintToOffscreen();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   754
                iCanvas.flushGraphics();
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   755
            }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   756
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   757
        catch (Exception e)
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   758
        {
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   759
            Logger.ELOG(Logger.EJavaUI,
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   760
                        "SVGCanvasTask: run() - exception: " + e.toString());
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   761
        }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   762
        Logger.LOG(Logger.EJavaUI, Logger.EInfo, "SVGCanvasTask: run() - end");
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   763
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   764
    }
abc41079b313 v2.2.7_1
hgs
parents:
diff changeset
   765
}