Gridarta Editor
FloodFill.java
Go to the documentation of this file.
1 /*
2  * Gridarta MMORPG map editor for Crossfire, Daimonin and similar games.
3  * Copyright (C) 2000-2015 The Gridarta Developers.
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation; either version 2 of the License, or
8  * (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License along
16  * with this program; if not, write to the Free Software Foundation, Inc.,
17  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18  */
19 
20 package net.sf.gridarta.model.floodfill;
21 
22 import java.awt.Point;
23 import java.util.List;
31 import net.sf.gridarta.utils.Size2D;
32 import org.jetbrains.annotations.NotNull;
33 
57 public class FloodFill<G extends GameObject<G, A, R>, A extends MapArchObject<A>, R extends Archetype<G, A, R>> {
58 
62  private static final byte NOT_LOOKED_AT = 0;
63 
64  private static final byte BORDER = 1;
65 
66  private static final byte WAS_EMPTY = 2;
67 
68  private static final byte BLOCKED = 3;
69 
77  public void floodFill(@NotNull final MapModel<G, A, R> mapModel, @NotNull final Point start, @NotNull final List<? extends BaseObject<G, A, R, ?>> archList, @NotNull final InsertionModeSet<G, A, R> insertionModeSet) {
78  final MapArchObject<A> mapArchObject = mapModel.getMapArchObject();
79  final Size2D mapSize = mapArchObject.getMapSize();
80  final byte[][] area = new byte[mapSize.getWidth()][mapSize.getHeight()];
81  area[start.x][start.y] = BORDER;
82  mapModel.beginTransaction("Flood Fill"); // TODO: I18N/L10N
83  try {
84  int border = 1;
85  while (border > 0) {
86  final Point p = new Point();
87  for (p.x = 0; p.x < mapSize.getWidth(); p.x++) {
88  for (p.y = 0; p.y < mapSize.getHeight(); p.y++) {
89  if (area[p.x][p.y] == BORDER) {
90  border--;
91  if (mapArchObject.isPointValid(p) && mapModel.getMapSquare(p).isEmpty()) {
92  area[p.x][p.y] = WAS_EMPTY;
93  final BaseObject<G, A, R, ?> gameObject = archList.get(RandomUtils.RND.nextInt(archList.size()));
94  mapModel.insertBaseObject(gameObject, p, false, false, insertionModeSet.getTopmostInsertionMode());
95  //noinspection ProhibitedExceptionCaught
96  try {
97  if (area[p.x - 1][p.y] == NOT_LOOKED_AT) {
98  area[p.x - 1][p.y] = BORDER;
99  border++;
100  }
101  } catch (final ArrayIndexOutOfBoundsException ignored) {
102  // ignore
103  }
104  //noinspection ProhibitedExceptionCaught
105  try {
106  if (area[p.x + 1][p.y] == NOT_LOOKED_AT) {
107  area[p.x + 1][p.y] = BORDER;
108  border++;
109  }
110  } catch (final ArrayIndexOutOfBoundsException ignored) {
111  // ignore
112  }
113  //noinspection ProhibitedExceptionCaught
114  try {
115  if (area[p.x][p.y - 1] == NOT_LOOKED_AT) {
116  area[p.x][p.y - 1] = BORDER;
117  border++;
118  }
119  } catch (final ArrayIndexOutOfBoundsException ignored) {
120  // ignore
121  }
122  //noinspection ProhibitedExceptionCaught
123  try {
124  if (area[p.x][p.y + 1] == NOT_LOOKED_AT) {
125  area[p.x][p.y + 1] = BORDER;
126  border++;
127  }
128  } catch (final ArrayIndexOutOfBoundsException ignored) {
129  // ignore
130  }
131  } else {
132  area[p.x][p.y] = BLOCKED;
133  }
134  }
135  }
136  }
137  }
138  } finally {
139  mapModel.endTransaction();
140  }
141  }
142 
143 }
net.sf.gridarta.utils.RandomUtils
Definition: RandomUtils.java:28
net.sf.gridarta.utils.Size2D.getWidth
int getWidth()
Definition: Size2D.java:96
net.sf.gridarta.model.floodfill.FloodFill.BORDER
static final byte BORDER
Definition: FloodFill.java:64
net.sf.gridarta.model.mapmodel.MapModel
Definition: MapModel.java:75
net.sf.gridarta.model.mapmodel.InsertionModeSet
Definition: InsertionModeSet.java:33
net.sf.gridarta
net.sf.gridarta.model.maparchobject.MapArchObject.isPointValid
boolean isPointValid(@Nullable Point pos)
net.sf
net.sf.gridarta.model.mapmodel
Definition: AboveFloorInsertionMode.java:20
net.sf.gridarta.model.archetype
Definition: AbstractArchetype.java:20
net.sf.gridarta.model.gameobject.GameObject
Definition: GameObject.java:36
net.sf.gridarta.model.maparchobject.MapArchObject.getMapSize
Size2D getMapSize()
net.sf.gridarta.model.gameobject
Definition: AbstractGameObject.java:20
net
net.sf.gridarta.utils.Size2D.getHeight
int getHeight()
Definition: Size2D.java:104
net.sf.gridarta.model.floodfill.FloodFill.WAS_EMPTY
static final byte WAS_EMPTY
Definition: FloodFill.java:66
net.sf.gridarta.utils.RandomUtils.RND
static final Random RND
Definition: RandomUtils.java:33
net.sf.gridarta.model.maparchobject.MapArchObject
Definition: MapArchObject.java:40
net.sf.gridarta.model.baseobject.BaseObject
Definition: BaseObject.java:34
net.sf.gridarta.model
net.sf.gridarta.model.archetype.Archetype
Definition: Archetype.java:41
net.sf.gridarta.model.baseobject
Definition: AbstractBaseObject.java:20
net.sf.gridarta.model.floodfill.FloodFill.BLOCKED
static final byte BLOCKED
Definition: FloodFill.java:68
net.sf.gridarta.model.maparchobject
Definition: AbstractMapArchObject.java:20
net.sf.gridarta.model.floodfill.FloodFill.NOT_LOOKED_AT
static final byte NOT_LOOKED_AT
Definition: FloodFill.java:62
net.sf.gridarta.model.floodfill.FloodFill
Definition: FloodFill.java:57
net.sf.gridarta.utils.Size2D
Definition: Size2D.java:30
net.sf.gridarta.utils
Definition: ActionBuilderUtils.java:20
net.sf.gridarta.model.floodfill.FloodFill.floodFill
void floodFill(@NotNull final MapModel< G, A, R > mapModel, @NotNull final Point start, @NotNull final List<? extends BaseObject< G, A, R, ?>> archList, @NotNull final InsertionModeSet< G, A, R > insertionModeSet)
Definition: FloodFill.java:77