Project

General

Profile

Download (3.43 KB) Statistics
| Branch: | Revision:

library / src / main / java / org / distorted / library / EffectListener.java @ d333eb6b

1
///////////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2016 Leszek Koltunski                                                               //
3
//                                                                                               //
4
// This file is part of Distorted.                                                               //
5
//                                                                                               //
6
// Distorted is free software: you can redistribute it and/or modify                             //
7
// it under the terms of the GNU General Public License as published by                          //
8
// the Free Software Foundation, either version 2 of the License, or                             //
9
// (at your option) any later version.                                                           //
10
//                                                                                               //
11
// Distorted is distributed in the hope that it will be useful,                                  //
12
// but WITHOUT ANY WARRANTY; without even the implied warranty of                                //
13
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the                                 //
14
// GNU General Public License for more details.                                                  //
15
//                                                                                               //
16
// You should have received a copy of the GNU General Public License                             //
17
// along with Distorted.  If not, see <http://www.gnu.org/licenses/>.                            //
18
///////////////////////////////////////////////////////////////////////////////////////////////////
19

    
20
package org.distorted.library;
21

    
22
///////////////////////////////////////////////////////////////////////////////////////////////////
23
/**
24
 * This interface lets users of the Distorted library get notified when something happens to one of the effects.
25
 * To receive the notifications, we first have to register with a call to {@link DistortedBitmap#addEventListener(EffectListener)}.
26
 * List of all possible events that can happen is defined in {@link EffectMessage}
27
 */
28

    
29
public interface EffectListener 
30
  {
31
/**
32
 * Gets called when event of type 'em' happens to effect 'effectID'. 
33
 * 
34
 * @param eventType  Type of event that happened.
35
 * @param effectID   ID of the effect the event happened to. This ID must have been previously returned by one
36
 *                   of the DistortedBitmap.{deform,distort,move,...} functions.
37
 * @param effectName Name of the effect as defined in EffectNames, e.g. if effectType==EffectNames.MOVE.ordinal(),
38
 *                   then the event happened to a MOVE effect.
39
 * @param bitmapID   the ID of the DistortedBitmap object, as returned by {@link DistortedBitmap#getID()}, this event
40
 *                   happened to. If the object has been created using a copy constructor from another instance of
41
 *                   DistortedBitmap, the ID here will be the one of the original object.
42
 * @param message    Any message string associated with it. 'Failed' event types have one.
43
 * @see EffectMessage
44
 * @see EffectNames
45
 */
46
   
47
  void effectMessage(final EffectMessage eventType, final long effectID, final int effectName, final long bitmapID, final String message);
48
  }
49

    
50
///////////////////////////////////////////////////////////////////////////////////////////////////
(8-8/30)