Crossfire JXClient, Trunk  R20561
FaceCache.java
Go to the documentation of this file.
1 /*
2  * This file is part of JXClient, the Fullscreen Java Crossfire Client.
3  *
4  * JXClient is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; either version 2 of the License, or
7  * (at your option) any later version.
8  *
9  * JXClient is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with JXClient; if not, write to the Free Software
16  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
17  *
18  * Copyright (C) 2005-2008 Yann Chachkoff.
19  * Copyright (C) 2006-2011 Andreas Kirschbaum.
20  */
21 
22 package com.realtime.crossfire.jxclient.faces;
23 
24 import java.util.Arrays;
25 import org.jetbrains.annotations.NotNull;
26 
31 public class FaceCache {
32 
36  @NotNull
37  private final Face[] faces = new Face[65536];
38 
42  public FaceCache() {
43  faces[0] = new Face(0, "empty", 0);
44  }
45 
50  public void addFace(@NotNull final Face face) {
51  faces[face.getFaceNum()] = face;
52  }
53 
59  @NotNull
60  public Face getFace(final int faceNum) {
61  final Face face = faces[faceNum];
62  if (face != null) {
63  return face;
64  }
65 
66  System.err.println("Warning: accessing undefined face "+faceNum);
67  faces[faceNum] = new Face(faceNum, "face#"+faceNum, 0);
68  return faces[faceNum];
69  }
70 
75  public void reset() {
76  Arrays.fill(faces, null);
77  faces[0] = new Face(0, "empty", 0);
78  }
79 
87  public void addFace(final int faceNum, final int faceSetNum, final int faceChecksum, @NotNull final String faceName) {
88  // XXX: ignores faceSetNum
89  if (faces[faceNum] != null) {
90  System.err.println("Warning: defining duplicate face "+faceNum+" ("+faceName+")");
91  }
92  faces[faceNum] = new Face(faceNum, faceName, faceChecksum);
93  }
94 
95 }
void addFace(final int faceNum, final int faceSetNum, final int faceChecksum, @NotNull final String faceName)
Adds a new face.
Definition: FaceCache.java:87
void addFace(@NotNull final Face face)
Adds a new face to the cache.
Definition: FaceCache.java:50
final Face [] faces
The cached faces.
Definition: FaceCache.java:37
Face getFace(final int faceNum)
Returns a face by face id.
Definition: FaceCache.java:60
void reset()
Forgets about all face information.
Definition: FaceCache.java:75