EquidistantSquareAttractionGenerator.java 2.77 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
/*
 * Copyright (c) 2005-2010 KOM – Multimedia Communications Lab
 *
 * This file is part of PeerfactSim.KOM.
 * 
 * PeerfactSim.KOM is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * any later version.
 * 
 * PeerfactSim.KOM 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 General Public License for more details.
 * 
 * You should have received a copy of the GNU General Public License
 * along with PeerfactSim.KOM.  If not, see <http://www.gnu.org/licenses/>.
 *
 */

package de.tud.kom.p2psim.impl.topology.movement.modularosm.attraction;

import java.util.List;
import de.tud.kom.p2psim.api.topology.Topology;
import de.tud.kom.p2psim.impl.topology.util.PositionVector;
import de.tudarmstadt.maki.simonstrator.api.Binder;
import de.tudarmstadt.maki.simonstrator.api.component.sensor.location.AttractionPoint;
Julian Zobel's avatar
Julian Zobel committed
28
import de.tudarmstadt.maki.simonstrator.api.util.XMLConfigurableConstructor;
29
30
31
32
33
34
35
36
37
38
39
40
41

/**
 * Implementation of the interface {@link AttractionGenerator}.
 * 
 * Generates the given number of {@link AttractionPoint}s and sets the
 * position randomly within the world dimensions.
 * 
 * @author  Julian Zobel
 * @version 1.0, Nov 2018
 */
public class EquidistantSquareAttractionGenerator implements IAttractionGenerator {

	private PositionVector worldDimension;
Julian Zobel's avatar
Julian Zobel committed
42
	private double squareSize;
43
	
Julian Zobel's avatar
Julian Zobel committed
44
45
	@XMLConfigurableConstructor({ "squareSize" })
	public EquidistantSquareAttractionGenerator(double squareSize) {
46
47
48
49
		
		this.worldDimension = Binder.getComponentOrNull(Topology.class)
				.getWorldDimensions();
				
Julian Zobel's avatar
Julian Zobel committed
50
		this.squareSize = squareSize;
51
52
53
54
55
56
57
58
59
60
61
62
		createAttractionPoints();
	}

	@Override
	public List<AttractionPoint> getAttractionPoints() {
		if(attractionPoints.isEmpty())
			createAttractionPoints();
		
		return attractionPoints;
	}
	
	private void createAttractionPoints() {
Julian Zobel's avatar
Julian Zobel committed
63
64
65
						
		double x = worldDimension.getX() / 2;
		double y = worldDimension.getY() / 2;
66
		
Julian Zobel's avatar
Julian Zobel committed
67
		PositionVector p1 = new PositionVector(x - squareSize, y - squareSize);		
68
69
70
		AttractionPoint ap1 = new AttractionPointImpl("AP1", p1);
		attractionPoints.add(ap1);
		
Julian Zobel's avatar
Julian Zobel committed
71
		PositionVector p2 = new PositionVector(x - squareSize, y + squareSize);		
72
73
74
		AttractionPoint ap2 = new AttractionPointImpl("AP2", p2);
		attractionPoints.add(ap2);
		
Julian Zobel's avatar
Julian Zobel committed
75
		PositionVector p3 = new PositionVector(x + squareSize, y - squareSize);		
76
77
78
		AttractionPoint ap3 = new AttractionPointImpl("AP3", p3);
		attractionPoints.add(ap3);
		
Julian Zobel's avatar
Julian Zobel committed
79
		PositionVector p4 = new PositionVector(x + squareSize, y + squareSize);		
80
81
82
83
84
85
		AttractionPoint ap4 = new AttractionPointImpl("AP4", p4);
		attractionPoints.add(ap4);
	}

	
}