Rev 3356 |
Blame |
Compare with Previous |
Last modification |
View Log
| RSS feed
/*
* Copyright (C) 2008 Steve Ratcliffe
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*
* This program 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.
*
*
* Author: Steve Ratcliffe
* Create date: 02-Nov-2008
*/
package uk.me.parabola.mkgmap.reader.osm;
import java.util.Set;
import uk.me.parabola.mkgmap.general.LineAdder;
/**
* A style converts an OSM element into a garmin element.
*
* You start with an OSM element which is just a bunch of name/value tags
* and you need to convert this to the information required by the .img
* format which is basically just a name and an
* integer type. You also need to know at what zoom levels to show the
* element at.
*
* The Style interface holds the rules for doing this.
*
* @author Steve Ratcliffe
*/
public interface Style {
public String getOption
(String name
);
public StyleInfo getInfo
();
/**
* Get the rules that apply to ways. This includes lines and polygons
* as they are not separate primitives in osm. It is a merge of the line
* rules and the polygon rules.
*/
public Rule getWayRules
();
/**
* Get the rules that apply to nodes.
*/
public Rule getNodeRules
();
/**
* Get the rules that apply to lines.
*/
public Rule getLineRules
();
/**
* Get the rules that apply to polygons.
*/
public Rule getPolygonRules
();
/**
* Get the relation rules.
*/
public Rule getRelationRules
();
/**
* Get the overlay definitions. Most styles will not use this.
*/
public LineAdder getOverlays
(LineAdder lineAdder
);
/**
* Get the tags that are used by this style.
*/
public Set<String> getUsedTags
();
/**
* Report statistics for rule expressions.
*/
public void reportStats
();
}