Drawables
This page is about defining drawables in json files. These are used in backgrounds on themes for example.
In all examples we will use background
.
Drawables have a type (for example images). Each type has different properties. For each type each property will be listed and explained.
Empty Drawable
Type name: empty
or null
Empty Drawables are special since they don't need to be an object. The can juts be null
.
Empty Drawables don't have any properties.
Example:
Both definitions are equivalent.
{
"background1": null,
"background2": {
"type": "empty"
}
}
Images
Type name: texture
You can get an existing image with name
or id
. In this case all other properties will be ignored.
{
"background": {
"type": "texture",
"id": "vanilla_background"
}
}
Or you can define a new image. An image has multiple subtypes.
- Full image: Uses the whole image at the given path (will be stretched to fit the render size)
- Sub image: Uses a rectangular part of an image (will be stretched to fit the render size)
- Adaptable image: has a border and a plain center. The border is drawn separately, so it won't be stretched no matter how large the texture is drawn. The center should be plain because it will be stretched to fit the render size.
- Tiled image: The image will be drawn multiples times at its original size like tiles to fit the render size. This can be combined with adaptable image.
For all image types you need the location
property. It defines where the image file is. The value is a resource
location.
Check out
the GroovyScript docs to
find out more.
Full image
Full images only need the location property
, which is explained above.
Sub image
Here you want to define a rectangle inside the image. You can do that using x
, y
, w
, h
, iw
and ih
. All these
properties are in pixel. w
is also width
, h
is also height
, iw
is also imageWidth
and ih
is
also imageHeight
.
Or you can define a rectangle with u0
, v0
, u1
and v1
. These are relative values from 0.0 to 1.0. u
is the
x-axis and v
the y-axis. 0 means start and 1 means end.
Warning
You can NOT mix both types!
Adaptable image
Can be a full image or a sub image. To make an image adaptable you need borderX
and/or borderY
or just border
(
sets both axis).
borderX
is the border size on the x-axis. All properties are in pixels.
Tiled image
Can be a full image or a sub image. Can also have border properties for adaptable image.
For tiled images you need "tiled": true
and imageWidth
(or iw
) and imageHeigth
(or ih
).
Example
This is an example for an adaptable sub image (we set the values to still be the full image).
{
"background": {
"type": "texture",
"location": "modularui:gui/background/background",
"imageWidth": 195,
"imageHeight": 136,
"x": 0,
"y": 0,
"width": 195,
"height": 136,
"border": 4
}
}
Colored rectangle
Type name: color
or rectangle
Properties:
cornerRadius
is the corner radius. Default is 0cornerSegments
is the amount of segments the corner has if the corner radius is not 0. Default is 6. Lower means more pointy but faster drawing, higher means smoother but slower drawing.color
is the color of the whole rectangle (see colors)
We can also set colors for each corner individually. This way we can create beautiful gradients.
colorTop
sets the color of the top left and top right corner.colorBottom
,colorLeft
andcolorRight
work analoguecolorTopLeft
orcolorTL
sets the color of the top left corner.colorTopRight
,colorBottomLeft
andcolorBottomRight
work analogue
Of course, you can combine multiple colors. For example, you can set color
and then colorBL
. This will make all
corners
have the color of color
except the bottom left corner which will have the colorBL
color.
Ellipse / Circle
Type name: ellipse
The ellipse will always stretch to its render size. It will only be a circle if render width and render height are the same.
Properties:
color
sets the color of the whole circlecolorInner
sets the center color, creating a gradientcolorOuter
sets the outer color, creating a gradientsegments
is the amount of edges the circle will have. Default is 40. Lower means more pointer and, but faster drawing and higher means smoother and slower drawing. With low segment count you can also draw polygons
Text
Type name: text
Properties:
text
,string
orkey
: The text (Required)lang
ortranslate
: If the text is a lang key and should be translated (Default is false)color
: Text color (see color) (Uses color of the widget theme if applicable by default)shadow
: True if the text should have a shadow. (Uses shadow of the widget theme if applicable by default)align
oralignment
: The alignment of the text in the render size. (see alignment) (Default is center)scale
: The scale to draw text at. (Default is 1.0)
Example
{
"type": "text",
"text": "Hello World",
"lang": false
}
The text can also be an array. In this case the lang
property is ignored.
Each of the elements in the array can either be a string or an object with the text
and lang
property. Those objects
can also have any style property like color
and shadow
.
Example
{
"type": "text",
"text": [
"Hello ",
{
"text": "this.part.is.translated",
"lang": true
},
"I18n:this.part.is.also.translated"
]
}
As you can see in the example above you can also start a string with I18n:
to make it translated.
Item
Type name: item
item
: The format ismod:item_id:meta
where meta is optionalnbt
: nbt data (untested)
Example
{
"background": {
"type": "item",
"item": "minecraft:diamond"
}
}
Icon
An icon is a drawable wrapper which can draw a drawable at a fixed size.
Type name: icon
Properties:
drawable
oricon
: The wrapped drawable. (Required)width
orw
: The width to render the drawable at.height
orh
: The height to render the drawable at.autoWidth
andautoHeight
: True if the width/height should match the render size (how normal drawables work).autoSize
: True if the width and height should match the render size (how normal drawables work). (Default is true)alignment
oralign
: The alignment of the drawable in the render size. (see alignment) (default is center)
You can also set margins. But they only work if the width (for left and right) or the height (for top and bottom) is set to auto. Multiple margins can be combined.
margin
: The margin on all edgesmarginHorizontal
andmarginVertical
: The margin on horizontal (left and right) or vertical (top and bottom) edgesmarginTop
,marginBottom
,marginLeft
,marginRight
; The margin of each edge
Example
{
"background": {
"type": "icon",
"drawable": {
"type": "...",
"...": "..."
},
"width": 18,
"height": 18
}
}
Drawable array
A drawable can also be multiple drawable. You can do that by using square brackets []
instead of curly brackets {}
.
And inside there you just define multiple drawable objects
Example
{
"background": [
{
"type": "...",
"...": "..."
},
{
"type": "...",
"...": "..."
},
{
"type": "...",
"...": "..."
}
]
}