Skip to content
Gravecorp edited this page May 19, 2013 · 51 revisions

Documentation is in the process of being streamlined. Should be complete.

The proxy generator.

##Table of contents

  1. Overview
  2. Block Elements
    2.1. Location element
    2.2. Text element
    2.3. Border element
    2.4. Wordwrap element
  3. Templates
    3.1 Template element
    3.2 Template matching
    3.2.1 Matches element
    3.2.2 Match element
    3.3 Overlayblocks element
    3.4 Textblocks element
    3.5 Link element
  4. Example XML

##Overview

This is an option that can be used for definitions to generator mock cards with actual card data. I will try and explain how it is used.

Starting with the basic xml layout and then explaining the different tags in detail.

The basic framework:

<?xml version="1.0" encoding="UTF-8"?>
<templates>
	<blocks>
		<block type=""  id="" >
			<location x=""  y="" />
		</block>
	</blocks>
	<template src="" >
		<matches>
			<match name=""  value="" />
		</matches>
		<overlayblocks>

		</overlayblocks>
		<textblocks>

		</textblocks>
	</template>
</templates>

Template are made up of various blocks which can then be linked in any number of templates. For example you can have a default location of the card name. You define it once and then link it in the template you want to use.

Table of contents
##Block elements Currently block elements have a few attributes of which most are mandatory and some are optional depending on the type of block defined.
Attributes:

  1. type Mandatory attribute. This defines what sort of block it is. Can only be set to overlay or text. Overlay blocks are used for constructing an image made of various parts. And the text blocks are used to define where on the image you want text to appear.
  2. id Mandatory attribute. This is the id to be used for linking it in various templates. Has be be a unique id not used in any other blocks.
  3. src Optional attribute. This is only used if type is set to overlay. It should contain a relative path to the image file you want to use in constructing the card.
    Overlay block:
<block type="overlay" id="overlay1" src="path/to/image">

Text block:

<block type="text" id="textblock1">

block elements can have various sub elements defining where they should be placed and for text blocks you can also define the text color, a rectangle to be used with word wrap and a border to be drawn around the text in a different color to improve readability.

The elements are:

  1. location Mandatory element. Where the block should be placed.
  2. text Optional element. What color the text should be and what font size.
  3. border Optional element. Draw a border around the text with a specified color and thickness.
  4. wordwrap Optional element. Define a rectangle of a specified height and width to apply word wrapping in.

Now to describe the elements used in blocks in detail.

###Location element Attributes:

  1. x Mandatory attribute. The placement of the block on the x axis.
  2. y Mandatory attribute. The placement of the block on the y axis.
  3. rotate Optional attribute. The amount of degrees to rotate the text.(0-359) Note: does not work with wordwrap.
  4. altrotate Optional attribute. Use an alternate rotate algorithm True or False. Defaults to False.
  5. flip Optional attribute. Flip the text True or False. Defaults to False.
<location x="0" y="0" rotate="0" altrotate="False" flip="False" />

###Text element
Attributes:

  1. color Mandatory attribute. The color of the text in a html color format. The # at start of the color code is mandatory.
  2. size Mandatory attribute. The size of the font in em.
  3. font Optional attribute. Relative path to a font file.
<text color="#FFFFFF" size="12" font="relative/path/to/fontfile" />

###Border element
Attributes:

  1. color Mandatory attribute. The color of the border to be drawn around the text in html color format. The # at the start of the color code is mandatory.
  2. size Mandatory attribute. The size in pixels of the border to be drawn.
<border color="#000000" size="2" />

###Wordwrap element
Attributes:

  1. height Mandatory attribute. The height of the rectangle to word wrap in.
  2. width Mandatory attribute. The width of the rectangle to word wrap in.
  3. align Optional attribute. Horizontal text alignment. Options: near, center, far.
  4. valign Optional attribute. Vertical text alignment. Options: near, center, far.
  5. shrinktofit Optional attribute. Resize the text to fit the wordwrap box. True or False. Defaults to False.
<wordwrap height="150" width="300" align="near" valign="near" shrinktofit="False" />

Table of contents
##Templates A template defines how all the various blocks are placed on a card both for images that get merged into one and the various text that should be used by a specific template. Also which template should be used based on rules you define for the selection.

The template to be used can consist of the base image defined in the template element src attribute, but can also have any number of other images added to it as overlays. For overlays to be used in a template the corresponding blocks with the images and locations have to be linked to the template in a overlayblocks element using the link element.

###Template element
Attributes:

  1. src Mandatory attribute. The relative path to the base template image.
  2. default Optional attribute. Its set to False by default. Adding it with True is required on a single template to be used a fallback should no matching templates be found when searching.
<template src="path/to/image" default="True">

###Template matching
Templates are matched on predefined values of certain properties which are declared in match elements. These match elements should always be nested in a single matches element.
There is no limit on the amount of match elements you can use for matching a card to a template.

####Matches element The matches element has no attributes and can only contain match elements.

<matches>
  <match name="propertyName" value="propertyValue" />
</matches>

####Match element
Attributes:

  1. name Mandatory attribute. The case sensitive name of the card property to check for a value.
  2. value Mandatory attribute. The case sensitive value of the card property.
<match name="propertyName" value="thepropertyValue" />

###Overlayblocks element

###Textblocks element

###Link element:
Attributes:

  1. block Mandatory attribute. The case sensitive id you assigned to the block you want to link here.
  2. separator Optional attribute. This property is used for text blocks which require various properties to be separated. Defined in this attribute is a string sequence that will be used as the glue for it.
<link block="overlay1" separator=" - " />

The text is printed on the image after the overlays are merged into the base image. It uses the same link element as overlays uses but with a sub element name property for getting the right properties printed to the defined locations. You can put multiple property elements under a single link element to have them separated with each other. The default separator is a single spacebar but if defined on the separator attribute of the link element it will use that instead.

The property element:
Attributes:

  1. name Mandatory attribute. The case sensitive card property to be printed here.
<property name="Name" />

Linebreak character:

&#10; or &#xd;&#xa;

###Conditional element
A conditional element can be used to add link elements to overlays or textblocks based on certain conditions.

Basic structure:

<conditional>
  <if property="propertyname" value="propertyvalue">
    <link block="block" />
  </if>
  <elseif property="propertyname" value="propertvalue">
    <link block="block" />
  </elseif>
  <else>
    <link block="block" />
  </else>
</conditional>

An if element can have any number of link elements nested in it. And you need to define either the value or contains attribute. Only use one or the other at a time.

The if element:
Attributes:

  1. property Mandatory attribute. The name of the property to be used.
  2. value Optional attribute. The value to be matched exactly.
  3. contains Optional attribute. The value to be checked for presence in the property.(partial match)
<if property="propertyname" value="propertyvalue">
  <link block="block" />
</if>
<if property="propertyname" contains="partialvalue">
  <link block="block" />
</if>

The elseif element is the same as the if element but can be repeated any number of times.
the elseif element:

  <elseif property="propertyname" value="propertvalue">
    <link block="block" />
  </elseif>
  <elseif property="propertyname" contains="partialvalue">
    <link block="block" />
  </elseif>

The else element is optional and can also contain any number of link elements.

The else element:

<else>
  <link block="block" />
</else>

Notes:
Conditional elements or its various sub elements cannot be nested in each other.

Table of contents
#Example xml

<?xml version="1.0" encoding="utf-8" ?>
<templates>
	<blocks>
		<block type="overlay" id="colorlesstextbox" src="proxy/textbox/colorless.png">
			<location x="0" y="0" />
		</block>
		<block type="overlay" id="colorlesstypeline" src="proxy/typeline/colorless.png">
			<location x="0" y="0" />
		</block>
		<block type="overlay" id="colorlesspt" src="proxy/pt/colorless.png">
			<location x="300" y="500" />
		</block>
		<block type="overlay" id="redtextbox" src="proxy/textbox/red.png">
			<location x="0" y="0" />
		</block>
		<block type="overlay" id="redtypeline" src="proxy/typeline/red.png">
			<location x="0" y="0" />
		</block>
		<block type="overlay" id="redpt" src="proxy/pt/red.png">
			<location x="300" y="500" />
		</block>
		<block type="text" id="title">
			<location x="40" y="34" />
			<text color="#000000" size="15" />
			<border color="#FFFFFF" size="2" />
		</block>
		<block type="text" id="cost">
			<location x="295" y="34" />
			<text color="#000000" size="15" />
			<border color="#FFFFFF" size="2" />
		</block>
		<block type="text" id="cardtype">
			<location x="40" y="300" />
			<text color="#000000" size="15" />
			<border color="#FFFFFF" size="2" />
		</block>
		<block type="text" id="text">
			<location x="40" y="330" />
			<text color="#000000" size="15" />
			<border color="#FFFFFF" size="2" />
			<wordwrap height="150" width="300" />
		</block>
		<block type="text" id="PTBox">
			<location x="300" y="470" />
			<text color="#000000" size="15" />
			<border color="#FFFFFF" size="2" />
		</block>
	</blocks>
	<template src="proxy/border/colorless.png" default="True">
		<matches>
			<match name="Color" value="value" />
			<match name="property2" value="value" />
		</matches>
		<overlayblocks>
			<link block="colorlesstextbox" />
			<link block="colorlesstypeline" />
			<link block="colorlesspt" />
		</overlayblocks>
		<textblocks>
			<link block="title">
				<property name="Name" />
			</link>
			<link block="cost">
				<property name="Cost" />
			</link>
			<link block="cardtype" separator=" - ">
				<property name="Type" />
				<property name="Subtype" />
			</link>
			<link block="text">
				<property name="Rules" />
			</link>
			<link block="PTBox">
				<property name="PTBox" />
			</link>
		</textblocks>
	</template>
	<template src="proxy/border/red.png">
		<matches>
			<match name="Color" value="Red" />
			<match name="Type" value="Creature" />
		</matches>
		<overlayblocks>
			<link block="redtextbox" />
			<link block="redtypeline" />
			<link block="redpt" />
		</overlayblocks>
		<textblocks>
			<link block="title">
				<property name="Name" />
			</link>
			<link block="cost">
				<property name="Cost" />
			</link>
			<link block="cardtype" separator=" - ">
				<property name="Type" />
				<property name="Subtype" />
			</link>
			<link block="text">
				<property name="Rules" />
			</link>
			<link block="PTBox">
				<property name="PTBox" />
			</link>
		</textblocks>
	</template>
</templates>

example gamedef mapping

	<proxygen definitionsrc="proxy/proxydef.xml">
	</proxygen>

fully generated xml based on the xsd.

<?xml version="1.0" encoding="UTF-8"?>
<templates>
	<blocks>
		<block type=""  id=""  src="" >
			<location x=""  y=""  rotate=""  altrotate=""  flip="" />
			<text color=""  size=""  font="" />
			<border color=""  size="" />
			<wordwrap height=""  width=""  align=""  valign="" />
		</block>
	</blocks>
	<template src=""  default="" >
		<matches>
			<match name=""  value="" />
		</matches>
		<overlayblocks>
			<conditional>
				<if property=""  value=""  contains="" >
					<link block="" separator="">
						<property name="" />
					</link>
				</if>
				<elseif property=""  value=""  contains="" >
					<link block="" separator="">
						<property name="" />
					</link>
				</elseif>
				<else>
					<link block="" separator="">
						<property name="" />
					</link>
				</else>
				<switch property="" >
					<case value=""  contains=""  break="" >
						<link block="" separator="">
							<property name="" />
						</link>
					</case>
					<default>
						<link block="" separator="">
							<property name="" />
						</link>
					</default>
				</switch>
			</conditional>
			<link block="" separator="">
				<property name="" />
			</link>
		</overlayblocks>
		<textblocks>
			<conditional>
				<if property=""  value=""  contains="" >
					<link block="" separator="">
						<property name="" />
					</link>
				</if>
				<elseif property=""  value=""  contains="" >
					<link block="" separator="">
						<property name="" />
					</link>
				</elseif>
				<else>
					<link block="" separator="">
						<property name="" />
					</link>
				</else>
				<switch property="" >
					<case value=""  contains=""  break="" >
						<link block="" separator="">
							<property name="" />
						</link>
					</case>
					<default>
						<link block="" separator="">
							<property name="" />
						</link>
					</default>
				</switch>
			</conditional>
			<link block="" separator="">
				<property name="" />
			</link>
		</textblocks>
	</template>
</templates>

Table of contents

<?xml version="1.0" encoding="utf-8" ?>
<templates>
  <blocks>
    <block type="" id="" src=""> <!-- a block that will be linked in the templates -->
      <!-- various options for a block are placed here -->
    </block>
  </blocks>
  <template src="" default="True">
    <matches>
      <match name="property" value="" /><!-- match a template to a specified property and value-->
    </matches>
    <overlayblocks>
      <link block="" /><!-- the blocks for overlays are linked here like this -->
    </overlayblocks>
    <textblocks>
      <link block="" separator=""><!-- the blocks for text are linked here like this -->
        <property name=""  /><!-- The property defined on a card to be placed here -->
      </link>
    </textblocks>
  </template>
</templates>
Clone this wiki locally