HealingMethod.java 6.53 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
/*-
 *  Copyright 2020 Beuth Hochschule für Technik Berlin, Hochschule für Technik Stuttgart
 * 
 *  This file is part of CityDoctor2.
 *
 *  CityDoctor2 is free software: you can redistribute it and/or modify
 *  it under the terms of the GNU Lesser General Public License as published by
 *  the Free Software Foundation, either version 3 of the License, or
 *  (at your option) any later version.
 *
 *  CityDoctor2 is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU Lesser General Public License for more details.
 *
 *  You should have received a copy of the GNU Lesser General Public License
 *  along with CityDoctor2.  If not, see <https://www.gnu.org/licenses/>.
 */
package de.hft.stuttgart.citydoctor2.check;

import de.hft.stuttgart.citydoctor2.check.error.AllPolygonsWrongOrientationError;
22
import de.hft.stuttgart.citydoctor2.check.error.AttributeMissingError;
23
24
25
26
import de.hft.stuttgart.citydoctor2.check.error.ConsecutivePointSameError;
import de.hft.stuttgart.citydoctor2.check.error.DependenciesNotMetError;
import de.hft.stuttgart.citydoctor2.check.error.MultipleConnectedComponentsError;
import de.hft.stuttgart.citydoctor2.check.error.NestedRingError;
Matthias Betz's avatar
Matthias Betz committed
27
import de.hft.stuttgart.citydoctor2.check.error.NonManifoldEdgeError;
28
import de.hft.stuttgart.citydoctor2.check.error.NonManifoldVertexError;
Matthias Betz's avatar
Matthias Betz committed
29
30
import de.hft.stuttgart.citydoctor2.check.error.NonPlanarPolygonDistancePlaneError;
import de.hft.stuttgart.citydoctor2.check.error.NonPlanarPolygonNormalsDeviation;
31
32
33
34
35
36
import de.hft.stuttgart.citydoctor2.check.error.NotCeilingError;
import de.hft.stuttgart.citydoctor2.check.error.NotFloorError;
import de.hft.stuttgart.citydoctor2.check.error.NotGroundError;
import de.hft.stuttgart.citydoctor2.check.error.NotWallError;
import de.hft.stuttgart.citydoctor2.check.error.NullAreaError;
import de.hft.stuttgart.citydoctor2.check.error.PointTouchesEdgeError;
Matthias Betz's avatar
Matthias Betz committed
37
38
import de.hft.stuttgart.citydoctor2.check.error.PolygonHoleOutsideError;
import de.hft.stuttgart.citydoctor2.check.error.PolygonInteriorDisconnectedError;
Matthias Betz's avatar
Matthias Betz committed
39
import de.hft.stuttgart.citydoctor2.check.error.PolygonIntersectingRingsError;
Matthias Betz's avatar
Matthias Betz committed
40
import de.hft.stuttgart.citydoctor2.check.error.PolygonSameOrientationError;
41
import de.hft.stuttgart.citydoctor2.check.error.PolygonWrongOrientationError;
Matthias Betz's avatar
Matthias Betz committed
42
43
import de.hft.stuttgart.citydoctor2.check.error.RingDuplicatePointError;
import de.hft.stuttgart.citydoctor2.check.error.RingEdgeIntersectionError;
44
import de.hft.stuttgart.citydoctor2.check.error.RingNotClosedError;
Matthias Betz's avatar
Matthias Betz committed
45
import de.hft.stuttgart.citydoctor2.check.error.RingTooFewPointsError;
46
47
48
49
import de.hft.stuttgart.citydoctor2.check.error.SchematronError;
import de.hft.stuttgart.citydoctor2.check.error.SolidNotClosedError;
import de.hft.stuttgart.citydoctor2.check.error.SolidSelfIntError;
import de.hft.stuttgart.citydoctor2.check.error.SurfaceUnfragmentedError;
50
import de.hft.stuttgart.citydoctor2.check.error.DegeneratedPolygonError;
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
import de.hft.stuttgart.citydoctor2.check.error.TooFewPolygonsError;
import de.hft.stuttgart.citydoctor2.check.error.UnknownCheckError;

/**
 * Visitor pattern interface used in the healing procedures. The modification
 * listener is to report changed polygons and the returned boolean indicates
 * that changes have happened.
 * 
 * @author Matthias Betz
 *
 */
public interface HealingMethod {

	default boolean visit(CheckError e, ModificationListener l) {
		return false;
	}
	
68
	default boolean visit(DegeneratedPolygonError e, ModificationListener l) {
69
70
71
		return false;
	}

Matthias Betz's avatar
Matthias Betz committed
72
	default boolean visit(RingEdgeIntersectionError edgeIntersectionError, ModificationListener l) {
73
74
75
		return false;
	}

Matthias Betz's avatar
Matthias Betz committed
76
	default boolean visit(RingDuplicatePointError duplicatePointError, ModificationListener l) {
77
78
79
80
81
82
83
84
85
86
87
		return false;
	}

	default boolean visit(AllPolygonsWrongOrientationError err, ModificationListener l) {
		return false;
	}

	default boolean visit(DependenciesNotMetError err, ModificationListener l) {
		return false;
	}

Matthias Betz's avatar
Matthias Betz committed
88
	default boolean visit(NonPlanarPolygonDistancePlaneError err, ModificationListener l) {
89
90
91
92
93
94
95
		return false;
	}

	default boolean visit(ConsecutivePointSameError err, ModificationListener l) {
		return false;
	}

Matthias Betz's avatar
Matthias Betz committed
96
	default boolean visit(PolygonHoleOutsideError err, ModificationListener l) {
97
98
99
		return false;
	}

Matthias Betz's avatar
Matthias Betz committed
100
	default boolean visit(PolygonInteriorDisconnectedError err, ModificationListener l) {
101
102
103
		return false;
	}

Matthias Betz's avatar
Matthias Betz committed
104
	default boolean visit(NonManifoldEdgeError err, ModificationListener l) {
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
		return false;
	}

	default boolean visit(MultipleConnectedComponentsError err, ModificationListener l) {
		return false;
	}

	default boolean visit(NestedRingError err, ModificationListener l) {
		return false;
	}

	default boolean visit(NonManifoldVertexError err, ModificationListener l) {
		return false;
	}

Matthias Betz's avatar
Matthias Betz committed
120
	default boolean visit(NonPlanarPolygonNormalsDeviation err, ModificationListener l) {
121
122
123
124
125
126
127
		return false;
	}

	default boolean visit(NullAreaError err, ModificationListener l) {
		return false;
	}

Matthias Betz's avatar
Matthias Betz committed
128
	default boolean visit(PolygonIntersectingRingsError err, ModificationListener l) {
129
130
131
132
133
134
135
136
137
138
139
		return false;
	}

	default boolean visit(PolygonWrongOrientationError err, ModificationListener l) {
		return false;
	}

	default boolean visit(RingNotClosedError err, ModificationListener l) {
		return false;
	}

Matthias Betz's avatar
Matthias Betz committed
140
	default boolean visit(PolygonSameOrientationError err, ModificationListener l) {
141
142
143
144
145
146
147
148
149
150
151
		return false;
	}

	default boolean visit(SolidNotClosedError err, ModificationListener l) {
		return false;
	}

	default boolean visit(SolidSelfIntError err, ModificationListener l) {
		return false;
	}

Matthias Betz's avatar
Matthias Betz committed
152
	default boolean visit(RingTooFewPointsError err, ModificationListener l) {
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
		return false;
	}

	default boolean visit(TooFewPolygonsError err, ModificationListener l) {
		return false;
	}

	default boolean visit(UnknownCheckError err, ModificationListener l) {
		return false;
	}

	default boolean visit(PointTouchesEdgeError err, ModificationListener l) {
		return false;
	}

	default boolean visit(NotCeilingError err, ModificationListener l) {
		return false;
	}

	default boolean visit(NotFloorError err, ModificationListener l) {
		return false;
	}

	default boolean visit(NotWallError err, ModificationListener l) {
		return false;
	}

	default boolean visit(NotGroundError err, ModificationListener l) {
		return false;
	}
	
	default boolean visit(SchematronError err, ModificationListener l) {
		return false;
	}
	
	default boolean visit(SurfaceUnfragmentedError err, ModificationListener l) {
		return false;
	}
191
192
193
194
	
	default boolean visit(AttributeMissingError err, ModificationListener l) {
		return false;
	}
195
196
197
198

	public HealingMethod createNew();

}