Project

General

Profile

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

library / src / main / java / org / distorted / library / message / EffectListener.java @ e458a4ba

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.message;
21

    
22
///////////////////////////////////////////////////////////////////////////////////////////////////
23

    
24
import org.distorted.library.DistortedBitmap;
25
import org.distorted.library.EffectNames;
26

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

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

    
54
///////////////////////////////////////////////////////////////////////////////////////////////////
(1-1/2)