Documentation ¶
Overview ¶
Package tiled is to to parse Tiled map editor file format (TMX).
Index ¶
- Variables
- type AnimationFrame
- type Axis
- type Data
- type DataTile
- type Ellipse
- type Group
- type HexColor
- type Image
- type ImageLayer
- type Layer
- type LayerTile
- type LoaderOption
- type Map
- type Object
- type ObjectGroup
- type Point
- type Points
- type PolyLine
- type Polygon
- type Properties
- type Property
- type StaggerIndexType
- type Template
- type Terrain
- type Tileset
- type TilesetTile
- type TilesetTileOffset
- type WangColor
- type WangPosition
- type WangSet
- type WangSets
- type WangTile
Examples ¶
Constants ¶
This section is empty.
Variables ¶
var ( // ErrInvalidDecodedTileCount error is returned when layer data has invalid tile count ErrInvalidDecodedTileCount = errors.New("tiled: invalid decoded tile count") // ErrEmptyLayerData error is returned when layer contains no data ErrEmptyLayerData = errors.New("tiled: missing layer data") // ErrUnknownEncoding error is returned when kayer data has unknown encoding ErrUnknownEncoding = errors.New("tiled: unknown data encoding") )
var ErrInvalidObjectPoint = errors.New("tiled: invalid object point")
ErrInvalidObjectPoint error is returned if there is error parsing object points
var ErrInvalidTileGID = errors.New("tiled: invalid tile GID")
ErrInvalidTileGID error is returned when tile GID is not found
var ErrUnknownCompression = errors.New("tiled: invalid compression method")
ErrUnknownCompression error is returned when file contains invalid compression method
var NilLayerTile = &LayerTile{Nil: true}
NilLayerTile is reusable layer tile that is nil
Functions ¶
This section is empty.
Types ¶
type AnimationFrame ¶
type AnimationFrame struct { // The local ID of a tile within the parent tileset. TileID uint32 `xml:"tileid,attr"` // How long (in milliseconds) this frame should be displayed before advancing to the next frame. Duration uint32 `xml:"duration,attr"` }
AnimationFrame is single frame of animation
type Data ¶
type Data struct { // The encoding used to encode the tile layer data. When used, it can be "base64" and "csv" at the moment. Encoding string `xml:"encoding,attr"` // The compression used to compress the tile layer data. Tiled Qt supports "gzip" and "zlib". Compression string `xml:"compression,attr"` // Raw data RawData []byte `xml:",innerxml"` // Only used when layer encoding is xml DataTiles []*DataTile `xml:"tile"` }
Data is raw data
type DataTile ¶
type DataTile struct { // The global tile ID. GID uint32 `xml:"gid,attr"` }
DataTile defines the value of a single tile on a tile layer
type Group ¶
type Group struct { // Custom properties Properties Properties `xml:"properties>property"` // Map layers Layers []*Layer `xml:"layer"` // Map object groups ObjectGroups []*ObjectGroup `xml:"objectgroup"` // Image layers ImageLayers []*ImageLayer `xml:"imagelayer"` // Group layers Groups []*Group `xml:"group"` // Unique ID of the layer. // Each layer that added to a map gets a unique id. Even if a layer is deleted, // no layer ever gets the same ID. Can not be changed in Tiled. (since Tiled 1.2) ID uint32 `xml:"id,attr"` // The name of the group layer. Name string `xml:"name,attr"` // The class of the group layer (since 1.9, defaults to ""). Class string `xml:"class,attr"` // Rendering offset of the image layer in pixels. Defaults to 0. (since 0.15) OffsetX int `xml:"offsetx,attr"` // Rendering offset of the image layer in pixels. Defaults to 0. (since 0.15) OffsetY int `xml:"offsety,attr"` // The opacity of the layer as a value from 0 to 1. Defaults to 1. Opacity float32 `xml:"opacity,attr"` // Whether the layer is shown (1) or hidden (0). Defaults to 1. Visible bool `xml:"visible,attr"` // The parallax x factor of the layer 0 - 1.0 ParallaxX float32 `xml:"parallaxx,attr"` // The parallax y factor of the layer 0 - 1.0 ParallaxY float32 `xml:"parallaxy,attr"` }
Group is a group layer, used to organize the layers of the map in a hierarchy.
func (*Group) DecodeGroup ¶
DecodeGroup decodes Group data. This includes all subgroups and the Layer data for each.
func (*Group) UnmarshalXML ¶
UnmarshalXML decodes a single XML element beginning with the given start element.
type HexColor ¶
type HexColor struct {
// contains filtered or unexported fields
}
HexColor handles the conversion between hex color strings in form #AARRGGBB to color.RGBA structure. Be aware that this doesn't match CSS hex color because the alpha channel appears first.
func NewHexColor ¶
NewHexColor is a shorthand to build a HexColor
func ParseHexColor ¶
ParseHexColor converts hex color strings into HexColor structures This function can handle colors with and withouth optional alpha channel The leading '#' character is not required for backwards compatibility with Transparency Tiled filed https://doc.mapeditor.org/en/stable/reference/tmx-map-format/#image
func (*HexColor) MarshalXMLAttr ¶
MarshalXMLAttr implements xml.MarshalerAttr
type Image ¶
type Image struct { // Used for embedded images, in combination with a data child element. Valid values are file extensions like png, gif, jpg, bmp, etc. Format string `xml:"format,attr"` // The reference to the tileset image file Source string `xml:"source,attr"` // Defines a specific color that is treated as transparent (example value: "#FF00FF" for magenta). // Up until Tiled 0.12, this value is written out without a # but this is planned to change. Trans *HexColor `xml:"trans,attr"` // The image width in pixels (optional, used for tile index correction when the image changes) Width int `xml:"width,attr"` // The image height in pixels (optional) Height int `xml:"height,attr"` // Embedded image content Data *Data `xml:"data,attr"` }
Image source
type ImageLayer ¶
type ImageLayer struct { // Custom properties Properties Properties `xml:"properties>property"` // The group image Image *Image `xml:"image"` // Unique ID of the layer. // Each layer that added to a map gets a unique id. Even if a layer is deleted, // no layer ever gets the same ID. Can not be changed in Tiled. (since Tiled 1.2) ID uint32 `xml:"id,attr"` // The name of the image layer. Name string `xml:"name,attr"` // The class of the image layer (since 1.9, defaults to ""). Class string `xml:"class,attr"` // Rendering offset of the image layer in pixels. Defaults to 0. (since 0.15) OffsetX int `xml:"offsetx,attr"` // Rendering offset of the image layer in pixels. Defaults to 0. (since 0.15) OffsetY int `xml:"offsety,attr"` // The x position of the image layer in pixels. (deprecated since 0.15) X int `xml:"x,attr"` // The y position of the image layer in pixels. (deprecated since 0.15) Y int `xml:"y,attr"` // The opacity of the layer as a value from 0 to 1. Defaults to 1. Opacity float32 `xml:"opacity,attr"` // Whether the layer is shown (1) or hidden (0). Defaults to 1. Visible bool `xml:"visible,attr"` // The parallax x factor of the layer 0 - 1.0 ParallaxX float32 `xml:"parallaxx,attr"` // The parallax y factor of the layer 0 - 1.0 ParallaxY float32 `xml:"parallaxy,attr"` // The repeat x settings of the image. RepeatX bool `xml:"repeatx,attr"` // The repeat y settings of the image. RepeatY bool `xml:"repeaty,attr"` }
ImageLayer is a layer consisting of a single image.
func (*ImageLayer) UnmarshalXML ¶
func (l *ImageLayer) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error
UnmarshalXML decodes a single XML element beginning with the given start element.
type Layer ¶
type Layer struct { // Custom properties Properties Properties `xml:"properties>property"` // This is the attribute you'd like to use, not Data. Tile entry at (x,y) is obtained using l.DecodedTiles[y*map.Width+x]. Tiles []LayerTile // Unique ID of the layer. // Each layer that added to a map gets a unique id. Even if a layer is deleted, // no layer ever gets the same ID. Can not be changed in Tiled. (since Tiled 1.2) ID uint32 `xml:"id,attr"` // The name of the layer. Name string `xml:"name,attr"` // The class of this layer (since 1.9, defaults to ""). Class string `xml:"class,attr"` // The opacity of the layer as a value from 0 to 1. Defaults to 1. Opacity float32 `xml:"opacity,attr"` // Whether the layer is shown (1) or hidden (0). Defaults to 1. Visible bool `xml:"visible,attr"` // Rendering offset for this layer in pixels. Defaults to 0. (since 0.14) OffsetX int `xml:"offsetx,attr"` // Rendering offset for this layer in pixels. Defaults to 0. (since 0.14) OffsetY int `xml:"offsety,attr"` // The parallax x factor of the layer 0 - 1.0 ParallaxX float32 `xml:"parallaxx,attr"` // The parallax y factor of the layer 0 - 1.0 ParallaxY float32 `xml:"parallaxy,attr"` // contains filtered or unexported fields }
Layer is a map layer
func (*Layer) DecodeLayer ¶
DecodeLayer decodes layer data
func (*Layer) GetTilePosition ¶
GetTilePosition returns the x,y position of the tileID on the current layer
func (*Layer) UnmarshalXML ¶
UnmarshalXML decodes a single XML element beginning with the given start element.
type LayerTile ¶
type LayerTile struct { // Tile ID ID uint32 // Tile tileset Tileset uint8 // Horizontal tile image flip HorizontalFlip bool // Vertical tile image flip VerticalFlip bool // Diagonal tile image flip DiagonalFlip bool // Tile is nil Nil bool }
LayerTile is a layer tile
type LoaderOption ¶
type LoaderOption func(*loader)
LoaderOption is used with LoadReader and LoadFile functions to pass additional options
func WithFileSystem ¶
func WithFileSystem(fileSystem fs.FS) LoaderOption
WithFileSystem returns an option to load level from a passed filesystem
type Map ¶
type Map struct { // Custom properties Properties *Properties `xml:"properties>property"` // Map tilesets Tilesets []*Tileset `xml:"tileset"` // Map layers Layers []*Layer `xml:"layer"` // Map object groups ObjectGroups []*ObjectGroup `xml:"objectgroup"` // Image layers ImageLayers []*ImageLayer `xml:"imagelayer"` // Group layers Groups []*Group `xml:"group"` // The background color of the map. (since 0.9, optional, may include alpha value since 0.15 in the form #AARRGGBB) BackgroundColor *HexColor `xml:"backgroundcolor,attr"` // The TMX format version, generally 1.0. Version string `xml:"version,attr"` // The Tiled version used to generate this file TiledVersion string `xml:"tiledversion,attr"` // The class of this map (since 1.9, defaults to ""). Class string `xml:"class,attr"` // Map orientation. Tiled supports "orthogonal", "isometric", "staggered" (since 0.9) and "hexagonal" (since 0.11). Orientation string `xml:"orientation,attr"` // The order in which tiles on tile layers are rendered. Valid values are right-down (the default), right-up, left-down and left-up. // In all cases, the map is drawn row-by-row. (since 0.10, but only supported for orthogonal maps at the moment) RenderOrder string `xml:"renderorder,attr"` // The map width in tiles. Width int `xml:"width,attr"` // The map height in tiles. Height int `xml:"height,attr"` // The width of a tile. TileWidth int `xml:"tilewidth,attr"` // The height of a tile. TileHeight int `xml:"tileheight,attr"` // Only for hexagonal maps. Determines the width or height (depending on the staggered axis) of the tile's edge, in pixels. HexSideLength int `xml:"hexsidelength,attr"` // For staggered and hexagonal maps, determines which axis ("x" or "y") is staggered. (since 0.11) StaggerAxis Axis `xml:"staggeraxis,attr"` // For staggered and hexagonal maps, determines whether the "even" or "odd" indexes along the staggered axis are shifted. (since 0.11) StaggerIndex StaggerIndexType `xml:"staggerindex,attr"` // Stores the next available ID for new objects. This number is stored to prevent reuse of the same ID after objects have been removed. (since 0.11) NextObjectID uint32 `xml:"nextobjectid,attr"` // contains filtered or unexported fields }
Map contains three different kinds of layers. Tile layers were once the only type, and are simply called layer, object layers have the objectgroup tag and image layers use the imagelayer tag. The order in which these layers appear is the order in which the layers are rendered by Tiled
func LoadFile ¶
func LoadFile(fileName string, options ...LoaderOption) (*Map, error)
LoadFile function loads tiled map in TMX format from file
func LoadReader ¶
LoadReader function loads tiled map in TMX format from io.Reader baseDir is used for loading additional tile data, current directory is used if empty
func (*Map) GetFileFullPath ¶
GetFileFullPath returns path to file relative to map file
func (*Map) TileGIDToTile ¶
TileGIDToTile is used to find tile data by GID
func (*Map) UnmarshalXML ¶
UnmarshalXML decodes a single XML element beginning with the given start element.
type Object ¶
type Object struct { // Unique ID of the object. Each object that is placed on a map gets a unique id. Even if an object was deleted, no object gets the same ID. // Can not be changed in Tiled Qt. (since Tiled 0.11) ID uint32 `xml:"id,attr"` // The name of the object. An arbitrary string. Name string `xml:"name,attr"` // The type of the object. An arbitrary string. (until 1.8) // // Deprecated: replaced by Class since 1.9 Type string `xml:"type,attr"` // The class of the object. An arbitrary string. (defaults to "", renamed from 'type' since 1.9) Class string `xml:"class,attr"` // The x coordinate of the object. X float64 `xml:"x,attr"` // The y coordinate of the object. Y float64 `xml:"y,attr"` // The width of the object (defaults to 0). Width float64 `xml:"width,attr"` // The height of the object (defaults to 0). Height float64 `xml:"height,attr"` // The rotation of the object in degrees clockwise (defaults to 0). (since 0.10) Rotation float64 `xml:"rotation,attr"` // An reference to a tile (optional). GID uint32 `xml:"gid,attr"` // Whether the object is shown (1) or hidden (0). Defaults to 1. (since 0.9) Visible bool `xml:"visible,attr"` // Custom properties Properties Properties `xml:"properties>property"` }
Object is used to add custom information to your tile map, such as spawn points, warps, exits, etc.
func (*Object) UnmarshalXML ¶
UnmarshalXML decodes a single XML element beginning with the given start element.
type ObjectGroup ¶
type ObjectGroup struct { // Custom properties Properties Properties `xml:"properties>property"` // Group objects Objects []Object `xml:"object"` // Unique ID of the layer. // Each layer that added to a map gets a unique id. Even if a layer is deleted, // no layer ever gets the same ID. Can not be changed in Tiled. (since Tiled 1.2) ID uint32 `xml:"id,attr"` // The name of the object group. Name string `xml:"name,attr"` // The class of the object group (since 1.9, defaults to ""). Class string `xml:"class,attr"` // The color used to display the objects in this group. Color *HexColor `xml:"color,attr"` // The opacity of the layer as a value from 0 to 1. Defaults to 1. Opacity float32 `xml:"opacity,attr"` // Whether the layer is shown (1) or hidden (0). Defaults to 1. Visible bool `xml:"visible,attr"` // Rendering offset for this layer in pixels. Defaults to 0. (since 0.14) OffsetX int `xml:"offsetx,attr"` // Rendering offset for this layer in pixels. Defaults to 0. (since 0.14) OffsetY int `xml:"offsety,attr"` // Whether the objects are drawn according to the order of appearance ("index") or sorted by their y-coordinate ("topdown"). Defaults to "topdown". DrawOrder string `xml:"draworder,attr"` // The parallax x factor of the layer 0 - 1.0 ParallaxX float32 `xml:"parallaxx,attr"` // The parallax y factor of the layer 0 - 1.0 ParallaxY float32 `xml:"parallaxy,attr"` }
ObjectGroup is in fact a map layer, and is hence called "object layer" in Tiled Qt
func (*ObjectGroup) DecodeObjectGroup ¶
func (g *ObjectGroup) DecodeObjectGroup(m *Map) error
DecodeObjectGroup decodes object group data
func (*ObjectGroup) UnmarshalXML ¶
func (g *ObjectGroup) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error
UnmarshalXML decodes a single XML element beginning with the given start element.
type PolyLine ¶
type PolyLine struct { // A list of x,y coordinates in pixels. Points *Points `xml:"points,attr"` }
PolyLine follows the same placement definition as a polygon object.
type Polygon ¶
type Polygon struct { // A list of x,y coordinates in pixels. Points *Points `xml:"points,attr"` }
Polygon object is made up of a space-delimited list of x,y coordinates. The origin for these coordinates is the location of the parent object. By default, the first point is created as 0,0 denoting that the point will originate exactly where the object is placed.
type Properties ¶
type Properties []Property
Properties wraps any number of custom properties
func (Properties) Get ¶
func (p Properties) Get(name string) []string
Get finds all properties by specified name
func (Properties) GetBool ¶
func (p Properties) GetBool(name string) bool
GetBool finds first bool property by specified name
func (Properties) GetColor ¶
func (p Properties) GetColor(name string) color.Color
GetColor returns a color.Color by parsing the first property found using name. If unable to parse the value or find the value nil is returned.
func (Properties) GetFloat ¶
func (p Properties) GetFloat(name string) float64
GetFloat finds first float property by specified name
func (Properties) GetInt ¶
func (p Properties) GetInt(name string) int
GetInt finds first int property by specified name
func (Properties) GetString ¶
func (p Properties) GetString(name string) string
GetString finds first string property by specified name
type Property ¶
type Property struct { // The name of the property. Name string `xml:"name,attr"` // The type of the property. Can be string (default), int, float, bool, color or file (since 0.16, with color and file added in 0.17). Type string `xml:"type,attr"` // The value of the property. // Boolean properties have a value of either "true" or "false". // Color properties are stored in the format #AARRGGBB. // File properties are stored as paths relative from the location of the map file. Value string `xml:"value,attr"` }
Property is used for custom properties
type StaggerIndexType ¶
type StaggerIndexType string
StaggerIndexType is stagger axis index type
const ( // StaggerIndexOdd is odd stagger index StaggerIndexOdd StaggerIndexType = "odd" // StaggerIndexEven is even stagger index StaggerIndexEven StaggerIndexType = "even" )
type Terrain ¶
type Terrain struct { // The name of the terrain type. Name string `xml:"name,attr"` // The local tile-id of the tile that represents the terrain visually. Tile uint32 `xml:"tile,attr"` // Custom properties Properties Properties `xml:"properties>property"` }
Terrain type
type Tileset ¶
type Tileset struct { // The TMX format version, generally 1.0. Version string `xml:"version,attr"` // The Tiled version used to generate this file TiledVersion string `xml:"tiledversion,attr"` // The first global tile ID of this tileset (this global ID maps to the first tile in this tileset). FirstGID uint32 `xml:"firstgid,attr"` // If this tileset is stored in an external TSX (Tile Set XML) file, this attribute refers to that file. // That TSX file has the same structure as the <tileset> element described here. (There is the firstgid // attribute missing and this source attribute is also not there. These two attributes are kept in the // TMX map, since they are map specific.) Source string `xml:"source,attr"` // External TSX source loaded. SourceLoaded bool `xml:"-"` // The name of this tileset. Name string `xml:"name,attr"` // The class of this tileset (since 1.9, defaults to ""). Class string `xml:"class,attr"` // The (maximum) width of the tiles in this tileset. TileWidth int `xml:"tilewidth,attr"` // The (maximum) height of the tiles in this tileset. TileHeight int `xml:"tileheight,attr"` // The spacing in pixels between the tiles in this tileset (applies to the tileset image). Spacing int `xml:"spacing,attr"` // The margin around the tiles in this tileset (applies to the tileset image). Margin int `xml:"margin,attr"` // The number of tiles in this tileset (since 0.13) TileCount int `xml:"tilecount,attr"` // The number of tile columns in the tileset. For image collection tilesets it is editable and is used when displaying the tileset. (since 0.15) Columns int `xml:"columns,attr"` // Offset in pixels, to be applied when drawing a tile from the related tileset. When not present, no offset is applied. TileOffset *TilesetTileOffset `xml:"tileoffset"` // Custom properties Properties Properties `xml:"properties>property"` // Embedded image Image *Image `xml:"image"` // Defines an array of terrain types, which can be referenced from the terrain of the tile element. TerrainTypes []*Terrain `xml:"terraintypes>terrain"` // Tiles in tileset Tiles []*TilesetTile `xml:"tile"` // Contains the list of Wang sets defined for this tileset. WangSets WangSets `xml:"wangsets>wangset"` // contains filtered or unexported fields }
Tileset is collection of tiles
func (*Tileset) GetFileFullPath ¶
GetFileFullPath returns path to file relative to tileset file
func (*Tileset) GetTileRect ¶
GetTileRect returns a rectangle that contains the tile in the tileset.Image
func (*Tileset) GetTilesetTile ¶
func (ts *Tileset) GetTilesetTile(tileID uint32) (*TilesetTile, error)
GetTilesetTile returns TilesetTile by tileID
Example ¶
var tiledMap *tiled.Map var err error tiledMap, err = tiled.LoadFile("assets/test_wangsets_w_properties_map.tmx") if err != nil { fmt.Printf("error parsing tiledMap: %s", err.Error()) os.Exit(2) } // get the tile so that we can read its data tile, err := tiledMap.Tilesets[tiledMap.Layers[0].Tiles[0].Tileset].GetTilesetTile(15) if err != nil { panic(err) } fmt.Print(tile.ID)
Output: 15
func (*Tileset) SetBaseDir ¶
SetBaseDir sets the base directory.
type TilesetTile ¶
type TilesetTile struct { // The local tile ID within its tileset. ID uint32 `xml:"id,attr"` // The type of the tile. Refers to an object type and is used by tile objects. (optional) (since 1.0, until 1.8) // // Deprecated: replaced by Class since 1.9 Type string `xml:"type,attr"` // The type of the tile. Refers to an object type and is used by tile objects. (optional) (renamed from 'type' since 1.9) Class string `xml:"class,attr"` // X is position of the sub-rectangle representing this tile (default: 0) X int `xml:"x,attr"` // Y is position of the sub-rectangle representing this tile (default: 0) Y int `xml:"y,attr"` // Width of the sub-rectangle representing this tile (defaults to the image width) Width int `xml:"width,attr"` // Height of the sub-rectangle representing this tile (defaults to the image height) Height int `xml:"height,attr"` // Defines the terrain type of each corner of the tile, given as comma-separated indexes in the terrain types // array in the order top-left, top-right, bottom-left, bottom-right. // Leaving out a value means that corner has no terrain. (optional) (since 0.9) Terrain string `xml:"terrain,attr"` // A percentage indicating the probability that this tile is chosen when it competes with others while editing with the terrain tool. (optional) (since 0.9) Probability float32 `xml:"probability,attr"` // Custom properties Properties Properties `xml:"properties>property"` // Embedded image Image *Image `xml:"image"` // Tile object groups ObjectGroups []*ObjectGroup `xml:"objectgroup"` // List of animation frames Animation []*AnimationFrame `xml:"animation>frame"` }
TilesetTile information
type TilesetTileOffset ¶
type TilesetTileOffset struct { // Horizontal offset in pixels X int `xml:"x,attr"` // Vertical offset in pixels (positive is down) Y int `xml:"y,attr"` }
TilesetTileOffset is used to specify an offset in pixels, to be applied when drawing a tile from the related tileset. When not present, no offset is applied
type WangColor ¶
type WangColor struct { // The name of this color. Name string `xml:"name,attr"` // The class of this color. (since 1.9) Class string `xml:"class,attr"` // The color in #RRGGBB format (example: #c17d11). Color string `xml:"color,attr"` // The tile ID of the tile representing this color. TileID int64 `xml:"tile,attr"` // The relative probability that this color is chosen over others in case of multiple options. (defaults to 0) Probability float32 `xml:"probability,attr"` }
WangColor that can be used to define the corner and/or edge of a Wang tile.
type WangPosition ¶
type WangPosition int
WangPosition Wang Color mapping to position
const ( // Top represents the top part of the tile Top WangPosition = iota // TopRight represents the top right part of the tile TopRight // Right represents the right part of the tile Right // BottomRight represents the bottom right part of the tile BottomRight // Bottom represents the bottom part of the tile Bottom // BottomLeft represents the bottom left part of the tile BottomLeft // Left represents the left part of the tile Left // TopLeft represents the top left part of the tile TopLeft )
type WangSet ¶
type WangSet struct { // The name of the Wang set. Name string `xml:"name,attr"` // The class of the Wang set. (renamed from 'type' since 1.9) Class string `xml:"class,attr"` // WangSet type. // // Deprecated: replaced by Class since 1.9 Type string `xml:"type,attr"` // The tile ID of the tile representing this Wang set. TileID int64 `xml:"tile,attr"` // The list of corner and/or edge colors. WangColors []*WangColor `xml:"wangcolor"` // The list of wang tiles. WangTiles []*WangTile `xml:"wangtile"` }
WangSet defines a list of corner colors and a list of edge colors, and any number of Wang tiles using these colors.
func (*WangSet) GetWangColors ¶
func (w *WangSet) GetWangColors(tileID uint32) (map[WangPosition]*WangColor, error)
GetWangColors returns the wangcolors for the tileId. If corner type is used it will return an array of len 4 topRight, bottomRight, bottom left, top left if corner type is not used it will return an array of len 8 in the following order. top, top right, right, bottom right, bottom, bottom left, left, top left if there is no wangcolor assigned to a part of the tile it will return an nil pointer instead for that index
Example ¶
var tiledMap *tiled.Map var err error tiledMap, err = tiled.LoadFile("assets/test_wangsets_map.tmx") if err != nil { fmt.Printf("error parsing tiledMap: %s", err.Error()) os.Exit(2) } fmt.Println(tiledMap.Tilesets[0].WangSets[0].Name) wangColors, err := tiledMap.Tilesets[0].WangSets[0].GetWangColors(16) if err != nil { panic(err) } fmt.Printf(" TopRight: %s\n", wangColors[tiled.TopRight].Name) fmt.Printf(" BottomRight: %s\n", wangColors[tiled.BottomRight].Name) fmt.Printf(" BottomLeft: %s\n", wangColors[tiled.BottomLeft].Name) fmt.Printf(" TopLeft: %s\n", wangColors[tiled.TopLeft].Name)
Output: Summer TopRight: Rock BottomRight: Water BottomLeft: Water TopLeft: Rock
type WangSets ¶
type WangSets []*WangSet
WangSets contains the list of Wang sets defined for this tileset. https://doc.mapeditor.org/en/stable/reference/tmx-map-format/#wangsets Can contain any number: <wangset>
type WangTile ¶
type WangTile struct { // The tile ID. TileID uint32 `xml:"tileid,attr"` // WangID, given by a comma-separated list of indexes (starting from 1, because 0 means _unset_) // referring to the Wang colors in the Wang set in the following order: // top, top right, right, bottom right, bottom, bottom left, left, top left (since Tiled 1.5). // Before Tiled 1.5, the Wang ID was saved as a 32-bit unsigned integer stored in the format // 0xCECECECE (where each C is a corner color and each E is an edge color, in reverse order). WangID string `xml:"wangid,attr"` }
WangTile by referring to a tile in the tileset and associating it with a certain Wang ID.