small changes

git-svn-id: https://osmand.googlecode.com/svn/trunk@10 e29c36b1-1cfa-d876-8d93-3434fc2bb7b8
This commit is contained in:
Victor Shcherb 2010-04-27 20:37:40 +00:00
parent 690c336946
commit ad43c7785d
8 changed files with 199 additions and 29 deletions

View file

@ -9,6 +9,7 @@ import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent; import java.awt.event.WindowEvent;
import java.io.File; import java.io.File;
import java.io.FileInputStream; import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.util.ArrayList; import java.util.ArrayList;
@ -150,6 +151,7 @@ public class DataExtraction implements IMapLocationListener {
n.putTag("amenity", "shop"); n.putTag("amenity", "shop");
amenities.add(n); amenities.add(n);
} }
// TODO leisure
if (n.getTag("place") != null) { if (n.getTag("place") != null) {
places.add(n); places.add(n);
if (places.size() % 500 == 0) System.out.println(); if (places.size() % 500 == 0) System.out.println();
@ -230,12 +232,19 @@ public class DataExtraction implements IMapLocationListener {
runUI(country); runUI(country);
List<Long> interestedObjects = new ArrayList<Long>();
NodeUtil.fillList(places, interestedObjects);
NodeUtil.fillList(amenities, interestedObjects);
NodeUtil.fillList(mapWays, interestedObjects);
// NodeUtil.fillList(buildings, interestedObjects);
storage.saveStorage(new FileOutputStream("C:/1_tmp.osm"), interestedObjects, true);
System.out.println(); System.out.println();
System.out.println("USED Memory " + (Runtime.getRuntime().totalMemory() - Runtime.getRuntime().freeMemory()) / 1e6); System.out.println("USED Memory " + (Runtime.getRuntime().totalMemory() - Runtime.getRuntime().freeMemory()) / 1e6);
System.out.println("TIME : " + (System.currentTimeMillis() - st)); System.out.println("TIME : " + (System.currentTimeMillis() - st));
} }
/////////////////////////////////////////// ///////////////////////////////////////////
// 2. Showing UI // 2. Showing UI

View file

@ -112,12 +112,22 @@ public class MapPanel extends JPanel {
for (int i = 0; i < images.length; i++) { for (int i = 0; i < images.length; i++) {
for (int j = 0; j < images[i].length; j++) { for (int j = 0; j < images[i].length; j++) {
if(images[i][j] == null){ if(images[i][j] == null){
if ((i + j + (int) getXTile() + (int) getYTile()) % 2 == 0) { int div = 4;
g.setColor(Color.gray); int tileDiv = tileSize / div;
} else { for(int k1 = 0; k1 < div; k1++){
g.setColor(Color.white); for(int k2 = 0; k2 < div; k2++){
} if ((k1 + k2) % 2 == 0) {
g.fillRect(i * tileSize+xStartingImage, j * tileSize + yStartingImage, tileSize, tileSize); g.setColor(Color.gray);
} else {
g.setColor(Color.white);
}
g.fillRect(i * tileSize+xStartingImage + k1*tileDiv,
j * tileSize + yStartingImage + k2*tileDiv, tileDiv, tileDiv);
}
}
} else { } else {
g.drawImage(images[i][j], i * tileSize+xStartingImage, j * tileSize + yStartingImage, this); g.drawImage(images[i][j], i * tileSize+xStartingImage, j * tileSize + yStartingImage, this);
} }
@ -179,35 +189,29 @@ public class MapPanel extends JPanel {
} }
} }
} }
double xTile = getXTile();
double yTile = getYTile();
double leftX = (getSize().width/2d - (xTile - Math.floor(xTile)) *tileSize)/tileSize;
double leftY = (getSize().height/2d - (yTile - Math.floor(yTile)) *tileSize)/tileSize;
int xStartInd = (int) (Math.floor(xTile) - Math.ceil(leftX)); double xTileLeft = getXTile() -getSize().width/(2d*tileSize);
int yStartInd = (int) (Math.floor(yTile) - Math.ceil(leftY)); double xTileRight = getXTile() + getSize().width/(2d*tileSize);
double yTileUp = getYTile() -getSize().height/(2d*tileSize);
double yTileDown = getYTile() + getSize().height/(2d*tileSize);
xStartingImage = - (int) ((xTileLeft - Math.floor(xTileLeft))*tileSize);
yStartingImage = - (int) ((yTileUp - Math.floor(yTileUp))*tileSize);
xStartingImage = (int) ((leftX - Math.ceil(leftX))*tileSize); int tileXCount = ((int)xTileRight - (int) xTileLeft + 1);
yStartingImage = (int) ((leftY - Math.ceil(leftY))*tileSize); int tileYCount = ((int)yTileDown - (int) yTileUp + 1);
int tileXCount = (int) Math.ceil((getSize().width - xStartingImage)/ (double)tileSize );
int tileYCount = (int) Math.ceil((getSize().height- yStartingImage)/ (double)tileSize );
images = new BufferedImage[tileXCount][tileYCount]; images = new BufferedImage[tileXCount][tileYCount];
for(int i=0; i<images.length; i++){ for(int i=0; i<images.length; i++){
for(int j=0; j<images[i].length; j++){ for(int j=0; j<images[i].length; j++){
images[i][j]= getImageFor(xStartInd + i, yStartInd + j); images[i][j]= getImageFor((int)xTileLeft + i, (int) yTileUp + j);
} }
} }
if(points != null){ if(points != null){
double latDown = NodeUtil.getLatitudeFromTile(zoom, double latDown = NodeUtil.getLatitudeFromTile(zoom, yTileDown);
NodeUtil.getTileNumberY(zoom, latitude) + ((double)getHeight()/tileSize)); double longDown = NodeUtil.getLongitudeFromTile(zoom, xTileRight);
double longDown = NodeUtil.getLongitudeFromTile(zoom, double latUp = NodeUtil.getLatitudeFromTile(zoom, yTileUp);
NodeUtil.getTileNumberX(zoom, longitude) + ((double)getWidth()/tileSize)); double longUp = NodeUtil.getLongitudeFromTile(zoom, xTileLeft);
double latUp = NodeUtil.getLatitudeFromTile(zoom,
NodeUtil.getTileNumberY(zoom, latitude) - ((double)getHeight()/tileSize));
double longUp = NodeUtil.getLongitudeFromTile(zoom,
NodeUtil.getTileNumberX(zoom, longitude) - ((double)getWidth()/tileSize));
List<LatLon> objects = points.getObjects(latUp, longUp, latDown, longDown); List<LatLon> objects = points.getObjects(latUp, longUp, latDown, longDown);
pointsToDraw.clear(); pointsToDraw.clear();
for(LatLon n : objects){ for(LatLon n : objects){

View file

@ -2,6 +2,7 @@ package com.osmand;
import java.util.Collection; import java.util.Collection;
import java.util.List;
import com.osmand.osm.Entity; import com.osmand.osm.Entity;
import com.osmand.osm.LatLon; import com.osmand.osm.LatLon;
@ -22,6 +23,12 @@ public class NodeUtil {
return getDistance(e1.getLatitude(), e1.getLongitude(), point.getLatitude(), point.getLongitude()); return getDistance(e1.getLatitude(), e1.getLongitude(), point.getLatitude(), point.getLongitude());
} }
public static void fillList(Collection<? extends Entity> source, List<Long> ids){
for(Entity e : source){
ids.add(e.getId());
}
}
/** /**
* Gets distance in meters * Gets distance in meters
*/ */

View file

@ -7,7 +7,7 @@ public class WayUtil {
if(tagHighway != null){ if(tagHighway != null){
String[] cars = new String[]{"trunk", "motorway", "primary", "secondary", "tertiary", "service", "residential", String[] cars = new String[]{"trunk", "motorway", "primary", "secondary", "tertiary", "service", "residential",
"trunk_link", "motorway_link", "primary_link", "secondary_link", "residential_link", "trunk_link", "motorway_link", "primary_link", "secondary_link", "residential_link",
"tertiary_link" }; "tertiary_link", "track" };
for(String c : cars){ for(String c : cars){
if(c.equals(tagHighway)){ if(c.equals(tagHighway)){
return true; return true;

View file

@ -33,6 +33,9 @@ public abstract class Entity {
} }
public Map<String, String> getTags() { public Map<String, String> getTags() {
if(tags == null){
return Collections.emptyMap();
}
return Collections.unmodifiableMap(tags); return Collections.unmodifiableMap(tags);
} }

View file

@ -41,6 +41,17 @@ public class Relation extends Entity {
return members.get(id); return members.get(id);
} }
public Collection<Long> getMemberIds() {
return getMemberIds(null);
}
public Map<Long, String> getMembersMap() {
if(members == null){
return Collections.emptyMap();
}
return Collections.unmodifiableMap(members);
}
public Collection<Long> getMemberIds(String role) { public Collection<Long> getMemberIds(String role) {
if (members == null) { if (members == null) {
return Collections.emptyList(); return Collections.emptyList();

View file

@ -1,6 +1,7 @@
package com.osmand.osm; package com.osmand.osm;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -31,10 +32,16 @@ public class Way extends Entity {
} }
public List<Long> getNodeIds(){ public List<Long> getNodeIds(){
if(nodeIds == null){
return Collections.emptyList();
}
return nodeIds; return nodeIds;
} }
public List<Node> getNodes() { public List<Node> getNodes() {
if(nodes == null){
return Collections.emptyList();
}
return nodes; return nodes;
} }

View file

@ -2,12 +2,23 @@ package com.osmand.osm.io;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashSet;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set;
import java.util.Stack;
import java.util.Map.Entry;
import javax.xml.parsers.ParserConfigurationException; import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory; import javax.xml.parsers.SAXParserFactory;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamWriter;
import javax.xml.transform.OutputKeys;
import org.xml.sax.Attributes; import org.xml.sax.Attributes;
import org.xml.sax.SAXException; import org.xml.sax.SAXException;
@ -17,6 +28,8 @@ import com.osmand.osm.Entity;
import com.osmand.osm.Node; import com.osmand.osm.Node;
import com.osmand.osm.Relation; import com.osmand.osm.Relation;
import com.osmand.osm.Way; import com.osmand.osm.Way;
import com.sun.org.apache.xerces.internal.impl.PropertyManager;
import com.sun.xml.internal.stream.writers.XMLStreamWriterImpl;
public class OsmBaseStorage extends DefaultHandler { public class OsmBaseStorage extends DefaultHandler {
@ -96,10 +109,19 @@ public class OsmBaseStorage extends DefaultHandler {
return ret; return ret;
} }
private static final Set<String> supportedVersions = new HashSet<String>();
static {
supportedVersions.add("0.6");
supportedVersions.add("0.5");
}
private final String INDENT = " ";
private final String INDENT2 = INDENT + INDENT;
@Override @Override
public void startElement(String uri, String localName, String name, Attributes attributes) throws SAXException { public void startElement(String uri, String localName, String name, Attributes attributes) throws SAXException {
if(!parseStarted){ if(!parseStarted){
if(!ELEM_OSM.equals(name) || !"0.6".equals(attributes.getValue(ATTR_VERSION))){ if(!ELEM_OSM.equals(name) || !supportedVersions.contains(attributes.getValue(ATTR_VERSION))){
throw new OsmVersionNotSupported(); throw new OsmVersionNotSupported();
} }
parseStarted = true; parseStarted = true;
@ -147,6 +169,8 @@ public class OsmBaseStorage extends DefaultHandler {
if(oldEntity!= null){ if(oldEntity!= null){
throw new UnsupportedOperationException("Entity with id=" + oldEntity.getId() +" is duplicated in osm map"); throw new UnsupportedOperationException("Entity with id=" + oldEntity.getId() +" is duplicated in osm map");
} }
} else {
// System.gc();
} }
currentParsedEntity = null; currentParsedEntity = null;
} }
@ -161,6 +185,111 @@ public class OsmBaseStorage extends DefaultHandler {
} }
} }
public void saveStorage(OutputStream output, Collection<Long> interestedObjects, boolean includeLinks) throws XMLStreamException, IOException {
PropertyManager propertyManager = new PropertyManager(PropertyManager.CONTEXT_WRITER);
// transformer.setOutputProperty(OutputKeys.INDENT, "yes");
// String indent = "{http://xml.apache.org/xslt}indent-amount";
// transformer.setOutputProperty(indent, "4");
XMLStreamWriter streamWriter = new XMLStreamWriterImpl(output, propertyManager);
List<Node> nodes = new ArrayList<Node>();
List<Way> ways = new ArrayList<Way>();
List<Relation> relations = new ArrayList<Relation>();
if(interestedObjects == null){
interestedObjects = entities.keySet();
}
Stack<Long> toResolve = new Stack<Long>();
toResolve.addAll(interestedObjects);
while(!toResolve.isEmpty()){
Long l = toResolve.pop();
if(entities.get(l) instanceof Node){
nodes.add((Node) entities.get(l));
} else if(entities.get(l) instanceof Way){
ways.add((Way) entities.get(l));
toResolve.addAll(((Way)entities.get(l)).getNodeIds());
} else if(entities.get(l) instanceof Relation){
relations.add((Relation) entities.get(l));
toResolve.addAll(((Relation)entities.get(l)).getMemberIds());
}
}
streamWriter.writeStartDocument();
writeStartElement(streamWriter, ELEM_OSM, "");
streamWriter.writeAttribute(ATTR_VERSION, "0.6");
for(Node n : nodes){
writeStartElement(streamWriter, ELEM_NODE, INDENT);
streamWriter.writeAttribute(ATTR_LAT, n.getLatitude()+"");
streamWriter.writeAttribute(ATTR_LON, n.getLongitude()+"");
streamWriter.writeAttribute(ATTR_ID, n.getId()+"");
writeTags(streamWriter, n);
streamWriter.writeEndElement();
}
for(Way w : ways){
writeStartElement(streamWriter, ELEM_WAY, INDENT);
streamWriter.writeAttribute(ATTR_ID, w.getId()+"");
for(Long r : w.getNodeIds()){
writeStartElement(streamWriter, ELEM_ND, INDENT2);
streamWriter.writeAttribute(ATTR_REF, r+"");
streamWriter.writeEndElement();
}
writeTags(streamWriter, w);
streamWriter.writeEndElement();
}
for(Relation r : relations){
writeStartElement(streamWriter, ELEM_RELATION, INDENT);
streamWriter.writeAttribute(ATTR_ID, r.getId()+"");
for(Entry<Long, String> e : r.getMembersMap().entrySet()){
writeStartElement(streamWriter, ELEM_MEMBER, INDENT2);
streamWriter.writeAttribute(ATTR_REF, e.getKey()+"");
String s = e.getValue();
if(s == null){
s = "";
}
streamWriter.writeAttribute(ATTR_ROLE, s);
streamWriter.writeAttribute(ATTR_TYPE, getEntityType(e.getKey()));
streamWriter.writeEndElement();
}
writeTags(streamWriter, r);
streamWriter.writeEndElement();
}
streamWriter.writeEndElement(); // osm
streamWriter.writeEndDocument();
streamWriter.flush();
}
private String getEntityType(Long id){
Entity e = entities.get(id);
if(e instanceof Way){
return "way";
} else if(e instanceof Relation){
return "relation";
}
return "node";
}
private void writeStartElement(XMLStreamWriter writer, String name, String indent) throws XMLStreamException{
writer.writeCharacters("\n"+indent);
writer.writeStartElement(name);
}
private void writeTags(XMLStreamWriter writer, Entity e) throws XMLStreamException{
for(Entry<String, String> en : e.getTags().entrySet()){
writeStartElement(writer, ELEM_TAG, INDENT2);
writer.writeAttribute(ATTR_K, en.getKey());
writer.writeAttribute(ATTR_V, en.getValue());
writer.writeEndElement();
}
}
public boolean acceptEntityToLoad(Entity e){ public boolean acceptEntityToLoad(Entity e){
if(e instanceof Way){ if(e instanceof Way){
return acceptWayToLoad((Way) e); return acceptWayToLoad((Way) e);