{
"inputs": [
{
"displayed_name": "Pressure",
"hard_maximum": null,
"hard_minimum": 0.0,
"id": "pressure",
"normal": 0.4,
"soft_maximum": 1.0,
"soft_minimum": 0.0,
"tooltip": "The pressure reported by the tablet. Usually between 0.0 and 1.0, but it may get larger when a pressure gain is used. If you use the mouse, it will be 0.5 when a button is pressed and 0.0 otherwise."
},
{
"tcomment_name": "\"fine\" refers to the accuracy and update frequency of the speed value, as in \"fine grained\"",
"displayed_name": "Fine speed",
"hard_maximum": null,
"hard_minimum": null,
"id": "speed1",
"normal": 0.5,
"soft_maximum": 4.0,
"soft_minimum": 0.0,
"tooltip": "How fast you currently move. This can change very quickly. Try 'print input values' from the 'help' menu to get a feeling for the range; negative values are rare but possible for very low speed."
},
{
"tcomment_name": "changes more smoothly but is less accurate than \"Fine speed\"",
"displayed_name": "Gross speed",
"hard_maximum": null,
"hard_minimum": null,
"id": "speed2",
"normal": 0.5,
"soft_maximum": 4.0,
"soft_minimum": 0.0,
"tooltip": "Same as fine speed, but changes slower. Also look at the 'gross speed filter' setting."
},
{
"displayed_name": "Random",
"hard_maximum": 1.0,
"hard_minimum": 0.0,
"id": "random",
"normal": 0.5,
"soft_maximum": 1.0,
"soft_minimum": 0.0,
"tooltip": "Fast random noise, changing at each evaluation. Evenly distributed between 0 and 1."
},
{
"displayed_name": "Stroke",
"hard_maximum": 1.0,
"hard_minimum": 0.0,
"id": "stroke",
"normal": 0.5,
"soft_maximum": 1.0,
"soft_minimum": 0.0,
"tooltip": "This input slowly goes from zero to one while you draw a stroke. It can also be configured to jump back to zero periodically while you move. Look at the 'stroke duration' and 'stroke hold time' settings."
},
{
"displayed_name": "Direction",
"hard_maximum": 180.0,
"hard_minimum": 0.0,
"id": "direction",
"normal": 0.0,
"soft_maximum": 180.0,
"soft_minimum": 0.0,
"tooltip": "The angle of the stroke, in degrees. The value will stay between 0.0 and 180.0, effectively ignoring turns of 180 degrees."
},
{
"displayed_name": "Declination/Tilt",
"hard_maximum": 90.0,
"hard_minimum": 0.0,
"id": "tilt_declination",
"normal": 0.0,
"soft_maximum": 90.0,
"soft_minimum": 0.0,
"tooltip": "Declination of stylus tilt. 0 when stylus is parallel to tablet and 90.0 when it's perpendicular to tablet."
},
{
"displayed_name": "Ascension",
"hard_maximum": 180.0,
"hard_minimum": -180.0,
"id": "tilt_ascension",
"normal": 0.0,
"soft_maximum": 180.0,
"soft_minimum": -180.0,
"tooltip": "Right ascension of stylus tilt. 0 when stylus working end points to you, +90 when rotated 90 degrees clockwise, -90 when rotated 90 degrees counterclockwise."
},
{
"tcomment_name": "the input is the output of the \"Custom input\" setting",
"displayed_name": "Custom",
"hard_maximum": null,
"hard_minimum": null,
"id": "custom",
"normal": 0.0,
"soft_maximum": 10.0,
"soft_minimum": -10.0,
"tooltip": "This is a user defined input. Look at the 'custom input' setting for details."
},
{
"tcomment_name": "refers to the direction of the stroke",
"displayed_name": "Direction 360",
"hard_maximum": 360.0,
"hard_minimum": 0.0,
"id": "direction_angle",
"normal": 0.0,
"soft_maximum": 360.0,
"soft_minimum": 0.0,
"tooltip": "The angle of the stroke, from 0 to 360 degrees."
},
{
"displayed_name": "Attack Angle",
"hard_maximum": 180.0,
"hard_minimum": -180.0,
"id": "attack_angle",
"normal": 0.0,
"soft_maximum": 180.0,
"soft_minimum": -180.0,
"tooltip": "The difference, in degrees, between the angle the stylus is pointing and the angle of the stroke movement.\nThe range is +/-180.0.\n0.0 means the stroke angle corresponds to the angle of the stylus.\n90 means the stroke angle is perpendicular to the angle of the stylus.\n180 means the angle of the stroke is directly opposite the angle of the stylus."
},
{
"displayed_name": "Declination/Tilt X",
"hard_maximum": 90.0,
"hard_minimum": -90.0,
"id": "tilt_declinationx",
"normal": 0.0,
"soft_maximum": 90.0,
"soft_minimum": -90.0,
"tooltip": "Declination of stylus tilt on X-Axis. 90/-90 when stylus is parallel to tablet and 0 when it's perpendicular to tablet."
},
{
"displayed_name": "Declination/Tilt Y",
"hard_maximum": 90.0,
"hard_minimum": -90.0,
"id": "tilt_declinationy",
"normal": 0.0,
"soft_maximum": 90.0,
"soft_minimum": -90.0,
"tooltip": "Declination of stylus tilt on Y-Axis. 90/-90 when stylus is parallel to tablet and 0 when it's perpendicular to tablet."
},
{
"displayed_name": "GridMap X",
"hard_maximum": 256.0,
"hard_minimum": 0,
"id": "gridmap_x",
"normal": 0.0,
"soft_maximum": 256.0,
"soft_minimum": 0.0,
"tooltip": "The X coordinate on a 256 pixel grid. This will wrap around 0-256 as the cursor is moved on the X axis. Similar to \"Stroke\". Can be used to add paper texture by modifying opacity, etc.\nThe brush size should be considerably smaller than the grid scale for best results."
},
{
"displayed_name": "GridMap Y",
"hard_maximum": 256.0,
"hard_minimum": 0,
"id": "gridmap_y",
"normal": 0.0,
"soft_maximum": 256.0,
"soft_minimum": 0.0,
"tooltip": "The Y coordinate on a 256 pixel grid. This will wrap around 0-256 as the cursor is moved on the Y axis. Similar to \"Stroke\". Can be used to add paper texture by modifying opacity, etc.\nThe brush size should be considerably smaller than the grid scale for best results."
},
{
"tcomment_name": "refers to canvas zoom",
"displayed_name": "Zoom Level",
"hard_maximum": 4.15,
"hard_minimum": -2.77,
"id": "viewzoom",
"normal": 0.0,
"soft_maximum": 4.15,
"soft_minimum": -2.77,
"tooltip": "The current zoom level of the canvas view.\nLogarithmic: 0.0 is 100%, 0.69 is 200%, -1.38 is 25%\nFor the Radius setting, using a value of -4.15 makes the brush size roughly constant, relative to the level of zoom."
},
{
"displayed_name": "Barrel Rotation",
"hard_maximum": 180.0,
"hard_minimum": -180.0,
"id": "barrel_rotation",
"normal": 0.0,
"soft_maximum": 180.0,
"soft_minimum": -180.0,
"tooltip": "Barrel rotation of stylus.\n0 when not twisted\n+90 when twisted clockwise 90 degrees\n-90 when twisted counterclockwise 90 degrees"
},
{
"displayed_name": "Base Brush Radius",
"hard_maximum": 6.0,
"hard_minimum": -2.0,
"id": "brush_radius",
"normal": 0.0,
"soft_maximum": 6.0,
"soft_minimum": -2.0,
"tooltip": "The base brush radius allows you to change the behavior of a brush as you make it bigger or smaller.\nYou can even cancel out dab size increase and adjust something else to make a brush bigger.\nTake note of \"Dabs per basic radius\" and \"Dabs per actual radius\", which behave much differently."
}
],
"settings": [
{
"constant": false,
"default": 1.0,
"displayed_name": "Opacity",
"internal_name": "opaque",
"maximum": 2.0,
"minimum": 0.0,
"tooltip": "0 means brush is transparent, 1 fully visible\n(also known as alpha or opacity)"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Opacity multiply",
"internal_name": "opaque_multiply",
"maximum": 2.0,
"minimum": 0.0,
"tooltip": "This gets multiplied with opaque. You should only change the pressure input of this setting. Use 'opaque' instead to make opacity depend on speed.\nThis setting is responsible to stop painting when there is zero pressure. This is just a convention, the behaviour is identical to 'opaque'."
},
{
"constant": true,
"default": 0.9,
"displayed_name": "Opacity linearize",
"internal_name": "opaque_linearize",
"maximum": 2.0,
"minimum": 0.0,
"tooltip": "Correct the nonlinearity introduced by blending multiple dabs on top of each other. This correction should get you a linear (\"natural\") pressure response when pressure is mapped to opaque_multiply, as it is usually done. 0.9 is good for standard strokes, set it smaller if your brush scatters a lot, or higher if you use dabs_per_second.\n0.0 the opaque value above is for the individual dabs\n1.0 the opaque value above is for the final brush stroke, assuming each pixel gets (dabs_per_radius*2) brushdabs on average during a stroke"
},
{
"constant": false,
"default": 2.0,
"displayed_name": "Radius",
"internal_name": "radius_logarithmic",
"maximum": 6.0,
"minimum": -2.0,
"tooltip": "Basic brush radius (logarithmic)\n 0.7 means 2 pixels\n 3.0 means 20 pixels"
},
{
"constant": false,
"default": 0.8,
"displayed_name": "Hardness",
"internal_name": "hardness",
"maximum": 1.0,
"minimum": 0.0,
"tooltip": "Hard brush-circle borders (setting to zero will draw nothing). To reach the maximum hardness, you need to disable Pixel feather."
},
{
"constant": false,
"default": 1.0,
"displayed_name": "Pixel feather",
"internal_name": "anti_aliasing",
"maximum": 5.0,
"minimum": 0.0,
"tooltip": "This setting decreases the hardness when necessary to prevent a pixel staircase effect (aliasing) by making the dab more blurred.\n 0.0 disable (for very strong erasers and pixel brushes)\n 1.0 blur one pixel (good value)\n 5.0 notable blur, thin strokes will disappear"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Dabs per basic radius",
"internal_name": "dabs_per_basic_radius",
"maximum": 200.0,
"minimum": 0.0,
"tooltip": "How many dabs to draw while the pointer moves a distance of one brush radius (more precise: the base value of the radius)"
},
{
"constant": false,
"default": 2.0,
"displayed_name": "Dabs per actual radius",
"internal_name": "dabs_per_actual_radius",
"maximum": 200.0,
"minimum": 0.0,
"tooltip": "Same as above, but the radius actually drawn is used, which can change dynamically"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Dabs per second",
"internal_name": "dabs_per_second",
"maximum": 200.0,
"minimum": 0.0,
"tooltip": "Dabs to draw each second, no matter how far the pointer moves"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Radius by random",
"internal_name": "radius_by_random",
"maximum": 1.5,
"minimum": 0.0,
"tooltip": "Alter the radius randomly each dab. You can also do this with the by_random input on the radius setting. If you do it here, there are two differences:\n1) the opaque value will be corrected such that a big-radius dabs is more transparent\n2) it will not change the actual radius seen by dabs_per_actual_radius"
},
{
"constant": false,
"default": 0.04,
"displayed_name": "Fine speed filter",
"internal_name": "speed1_slowness",
"maximum": 0.2,
"minimum": 0.0,
"tooltip": "How slow the input fine speed is following the real speed\n0.0 change immediately as your speed changes (not recommended, but try it)"
},
{
"constant": false,
"default": 0.8,
"displayed_name": "Gross speed filter",
"internal_name": "speed2_slowness",
"maximum": 3.0,
"minimum": 0.0,
"tooltip": "Same as 'fine speed filter', but note that the range is different"
},
{
"constant": true,
"default": 4.0,
"displayed_name": "Fine speed gamma",
"internal_name": "speed1_gamma",
"maximum": 8.0,
"minimum": -8.0,
"tooltip": "This changes the reaction of the 'fine speed' input to extreme physical speed. You will see the difference best if 'fine speed' is mapped to the radius.\n-8.0 very fast speed does not increase 'fine speed' much more\n+8.0 very fast speed increases 'fine speed' a lot\nFor very slow speed the opposite happens."
},
{
"constant": true,
"default": 4.0,
"displayed_name": "Gross speed gamma",
"internal_name": "speed2_gamma",
"maximum": 8.0,
"minimum": -8.0,
"tooltip": "Same as 'fine speed gamma' for gross speed"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Jitter",
"internal_name": "offset_by_random",
"maximum": 25.0,
"minimum": 0.0,
"tooltip": "Add a random offset to the position where each dab is drawn\n 0.0 disabled\n 1.0 standard deviation is one basic radius away\n<0.0 negative values produce no jitter"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Offset by speed",
"internal_name": "offset_by_speed",
"maximum": 3.0,
"minimum": -3.0,
"tooltip": "Change position depending on pointer speed\n= 0 disable\n> 0 draw where the pointer moves to\n< 0 draw where the pointer comes from"
},
{
"constant": false,
"default": 1.0,
"displayed_name": "Offset by speed filter",
"internal_name": "offset_by_speed_slowness",
"maximum": 15.0,
"minimum": 0.0,
"tooltip": "How slow the offset goes back to zero when the cursor stops moving"
},
{
"constant": true,
"default": 0.0,
"displayed_name": "Slow position tracking",
"internal_name": "slow_tracking",
"maximum": 10.0,
"minimum": 0.0,
"tooltip": "Slowdown pointer tracking speed. 0 disables it, higher values remove more jitter in cursor movements. Useful for drawing smooth, comic-like outlines."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Slow tracking per dab",
"internal_name": "slow_tracking_per_dab",
"maximum": 10.0,
"minimum": 0.0,
"tooltip": "Similar as above but at brushdab level (ignoring how much time has passed if brushdabs do not depend on time)"
},
{
"constant": true,
"default": 0.0,
"displayed_name": "Tracking noise",
"internal_name": "tracking_noise",
"maximum": 12.0,
"minimum": 0.0,
"tooltip": "Add randomness to the mouse pointer; this usually generates many small lines in random directions; maybe try this together with 'slow tracking'"
},
{
"constant": true,
"default": 0.0,
"displayed_name": "Color hue",
"internal_name": "color_h",
"maximum": 1.0,
"minimum": 0.0,
"tooltip": "Color hue"
},
{
"constant": true,
"default": 0.0,
"displayed_name": "Color saturation",
"internal_name": "color_s",
"maximum": 1.5,
"minimum": -0.5,
"tooltip": "Color saturation"
},
{
"constant": true,
"default": 0.0,
"displayed_name": "Color value",
"internal_name": "color_v",
"maximum": 1.5,
"minimum": -0.5,
"tooltip": "Color value (brightness, intensity)"
},
{
"constant": true,
"default": 0.0,
"displayed_name": "Save color",
"internal_name": "restore_color",
"maximum": 1.0,
"minimum": 0.0,
"tooltip": "When selecting a brush, the color can be restored to the color that the brush was saved with.\n 0.0 do not modify the active color when selecting this brush\n 0.5 change active color towards brush color\n 1.0 set the active color to the brush color when selected"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Change color hue",
"internal_name": "change_color_h",
"maximum": 2.0,
"minimum": -2.0,
"tooltip": "Change color hue.\n-0.1 small clockwise color hue shift\n 0.0 disable\n 0.5 counterclockwise hue shift by 180 degrees"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Change color lightness (HSL)",
"internal_name": "change_color_l",
"maximum": 2.0,
"minimum": -2.0,
"tooltip": "Change the color lightness using the HSL color model.\n-1.0 blacker\n 0.0 disable\n 1.0 whiter"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Change color satur. (HSL)",
"internal_name": "change_color_hsl_s",
"maximum": 2.0,
"minimum": -2.0,
"tooltip": "Change the color saturation using the HSL color model.\n-1.0 more grayish\n 0.0 disable\n 1.0 more saturated"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Change color value (HSV)",
"internal_name": "change_color_v",
"maximum": 2.0,
"minimum": -2.0,
"tooltip": "Change the color value (brightness, intensity) using the HSV color model. HSV changes are applied before HSL.\n-1.0 darker\n 0.0 disable\n 1.0 brigher"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Change color satur. (HSV)",
"internal_name": "change_color_hsv_s",
"maximum": 2.0,
"minimum": -2.0,
"tooltip": "Change the color saturation using the HSV color model. HSV changes are applied before HSL.\n-1.0 more grayish\n 0.0 disable\n 1.0 more saturated"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Smudge",
"internal_name": "smudge",
"maximum": 1.0,
"minimum": 0.0,
"tooltip": "Paint with the smudge color instead of the brush color. The smudge color is slowly changed to the color you are painting on.\n 0.0 do not use the smudge color\n 0.5 mix the smudge color with the brush color\n 1.0 use only the smudge color"
},
{
"constant": false,
"default": 0.5,
"displayed_name": "Smudge length",
"internal_name": "smudge_length",
"maximum": 1.0,
"minimum": 0.0,
"tooltip": "This controls how fast the smudge color becomes the color you are painting on.\n0.0 immediately update the smudge color (requires more CPU cycles because of the frequent color checks)\n0.5 change the smudge color steadily towards the canvas color\n1.0 never change the smudge color"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Smudge radius",
"internal_name": "smudge_radius_log",
"maximum": 1.6,
"minimum": -1.6,
"tooltip": "This modifies the radius of the circle where color is picked up for smudging.\n 0.0 use the brush radius\n-0.7 half the brush radius (fast, but not always intuitive)\n+0.7 twice the brush radius\n+1.6 five times the brush radius (slow performance)"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Eraser",
"internal_name": "eraser",
"maximum": 1.0,
"minimum": 0.0,
"tooltip": "how much this tool behaves like an eraser\n 0.0 normal painting\n 1.0 standard eraser\n 0.5 pixels go towards 50% transparency"
},
{
"constant": true,
"default": 0.0,
"displayed_name": "Stroke threshold",
"internal_name": "stroke_threshold",
"maximum": 0.5,
"minimum": 0.0,
"tooltip": "How much pressure is needed to start a stroke. This affects the stroke input only. MyPaint does not need a minimum pressure to start drawing."
},
{
"constant": false,
"default": 4.0,
"displayed_name": "Stroke duration",
"internal_name": "stroke_duration_logarithmic",
"maximum": 14.0,
"minimum": -1.0,
"tooltip": "How far you have to move until the stroke input reaches 1.0. This value is logarithmic (negative values will not invert the process)."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Stroke hold time",
"internal_name": "stroke_holdtime",
"maximum": 10.0,
"minimum": 0.0,
"tooltip": "This defines how long the stroke input stays at 1.0. After that it will reset to 0.0 and start growing again, even if the stroke is not yet finished.\n2.0 means twice as long as it takes to go from 0.0 to 1.0\n9.9 or higher stands for infinite"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Custom input",
"internal_name": "custom_input",
"maximum": 5.0,
"minimum": -5.0,
"tooltip": "Set the custom input to this value. If it is slowed down, move it towards this value (see below). The idea is that you make this input depend on a mixture of pressure/speed/whatever, and then make other settings depend on this 'custom input' instead of repeating this combination everywhere you need it.\nIf you make it change 'by random' you can generate a slow (smooth) random input."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Custom input filter",
"internal_name": "custom_input_slowness",
"maximum": 10.0,
"minimum": 0.0,
"tooltip": "How slow the custom input actually follows the desired value (the one above). This happens at brushdab level (ignoring how much time has passed, if brushdabs do not depend on time).\n0.0 no slowdown (changes apply instantly)"
},
{
"constant": false,
"default": 1.0,
"displayed_name": "Elliptical dab: ratio",
"internal_name": "elliptical_dab_ratio",
"maximum": 10.0,
"minimum": 1.0,
"tooltip": "Aspect ratio of the dabs; must be >= 1.0, where 1.0 means a perfectly round dab."
},
{
"constant": false,
"default": 90.0,
"displayed_name": "Elliptical dab: angle",
"internal_name": "elliptical_dab_angle",
"maximum": 180.0,
"minimum": 0.0,
"tooltip": "Angle by which elliptical dabs are tilted\n 0.0 horizontal dabs\n 45.0 45 degrees, turned clockwise\n 180.0 horizontal again"
},
{
"constant": false,
"default": 2.0,
"displayed_name": "Direction filter",
"internal_name": "direction_filter",
"maximum": 10.0,
"minimum": 0.0,
"tooltip": "A low value will make the direction input adapt more quickly, a high value will make it smoother"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Lock alpha",
"internal_name": "lock_alpha",
"maximum": 1.0,
"minimum": 0.0,
"tooltip": "Do not modify the alpha channel of the layer (paint only where there is paint already)\n 0.0 normal painting\n 0.5 half of the paint gets applied normally\n 1.0 alpha channel fully locked"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Colorize",
"internal_name": "colorize",
"maximum": 1.0,
"minimum": 0.0,
"tooltip": "Colorize the target layer, setting its hue and saturation from the active brush color while retaining its value and alpha."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Snap to pixel",
"internal_name": "snap_to_pixel",
"maximum": 1.0,
"minimum": 0.0,
"tooltip": "Snap brush dab's center and its radius to pixels. Set this to 1.0 for a thin pixel brush."
},
{
"constant": true,
"default": 0.0,
"displayed_name": "Pressure gain",
"internal_name": "pressure_gain_log",
"maximum": 1.8,
"minimum": -1.8,
"tooltip": "This changes how hard you have to press. It multiplies tablet pressure by a constant factor."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "GridMap Scale",
"internal_name": "gridmap_scale",
"maximum": 10.0,
"minimum": -10.0,
"tooltip": "Changes the overall scale that the GridMap brush input operates on.\nLogarithmic (same scale as brush radius).\nA scale of 0 will make the grid 256x256 pixels."
},
{
"constant": false,
"default": 1.0,
"displayed_name": "GridMap Scale X",
"internal_name": "gridmap_scale_x",
"maximum": 10.0,
"minimum": 0.0,
"tooltip": "Changes the scale that the GridMap brush input operates on - affects X axis only.\nThe range is 0-5x.\nThis allows you to stretch or compress the GridMap pattern."
},
{
"constant": false,
"default": 1.0,
"displayed_name": "GridMap Scale Y",
"internal_name": "gridmap_scale_y",
"maximum": 10.0,
"minimum": 0.0,
"tooltip": "Changes the scale that the GridMap brush input operates on - affects Y axis only.\nThe range is 0-5x.\nThis allows you to stretch or compress the GridMap pattern."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Smudge length multiplier",
"internal_name": "smudge_length_log",
"maximum": 20.0,
"minimum": 0.0,
"tooltip": "Logarithmic multiplier for the \"Smudge length\" value.\nUseful to correct for high-definition/large brushes with lots of dabs.\nThe longer the smudge length the more a color will spread and will also boost performance dramatically, as the canvas is sampled less often"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Smudge bucket",
"internal_name": "smudge_bucket",
"maximum": 255.0,
"minimum": 0.0,
"tooltip": "There are 256 buckets that each can hold a color picked up from the canvas.\nYou can control which bucket to use to improve variability and realism of the brush.\nEspecially useful with the \"Custom input\" setting to correlate buckets with other settings such as offsets."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Smudge transparency",
"internal_name": "smudge_transparency",
"maximum": 1.0,
"minimum": -1.0,
"tooltip": "Control how much transparency is picked up and smudged, similar to lock alpha.\n1.0 will not move any transparency.\n0.5 will move only 50% transparency and above.\n0.0 will have no effect.\nNegative values do the reverse"
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Offset Y",
"internal_name": "offset_y",
"maximum": 40.0,
"minimum": -40.0,
"tooltip": "Moves the dabs up or down based on canvas coordinates."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Offset X",
"internal_name": "offset_x",
"maximum": 40.0,
"minimum": -40.0,
"tooltip": "Moves the dabs left or right based on canvas coordinates."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Angular Offset: Direction",
"internal_name": "offset_angle",
"maximum": 40.0,
"minimum": -40.0,
"tooltip": "Follows the stroke direction to offset the dabs to one side."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Angular Offset: Ascension",
"internal_name": "offset_angle_asc",
"maximum": 40.0,
"minimum": -40.0,
"tooltip": "Follows the tilt direction to offset the dabs to one side. Requires Tilt."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Angular Offset: View",
"internal_name": "offset_angle_view",
"maximum": 40.0,
"minimum": -40.0,
"tooltip": "Follows the view orientation to offset the dabs to one side."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Angular Offset Mirrored: Direction",
"internal_name": "offset_angle_2",
"maximum": 40.0,
"minimum": 0.0,
"tooltip": "Follows the stroke direction to offset the dabs, but to both sides of the stroke."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Angular Offset Mirrored: Ascension",
"internal_name": "offset_angle_2_asc",
"maximum": 40.0,
"minimum": 0.0,
"tooltip": "Follows the tilt direction to offset the dabs, but to both sides of the stroke. Requires Tilt."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Angular Offset Mirrored: View",
"internal_name": "offset_angle_2_view",
"maximum": 40.0,
"minimum": 0.0,
"tooltip": "Follows the view orientation to offset the dabs, but to both sides of the stroke."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Angular Offsets Adjustment",
"internal_name": "offset_angle_adj",
"maximum": 180.0,
"minimum": -180.0,
"tooltip": "Change the Angular Offset angle from the default, which is 90 degrees."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Offsets Multiplier",
"internal_name": "offset_multiplier",
"maximum": 3.0,
"minimum": -2.0,
"tooltip": "Logarithmic multiplier for X, Y, and Angular Offset settings."
},
{
"constant": false,
"default": 0.0,
"displayed_name": "Posterize",
"internal_name": "posterize",
"maximum": 1.0,
"minimum": 0.0,
"tooltip": "Strength of posterization, reducing number of colors based on the \"Posterization levels\" setting, while retaining alpha."
},
{
"constant": false,
"default": 0.05,
"displayed_name": "Posterization levels",
"internal_name": "posterize_num",
"maximum": 1.28,
"minimum": 0.01,
"tooltip": "Number of posterization levels (divided by 100).\n0.05 = 5 levels, 0.2 = 20 levels, etc.\nValues above 0.5 may not be noticeable."
},
{
"tcomment_name": "The name Pigment refers to the fact that this kind of color mixing is more similar to how colors mix in physical paint.",
"constant": false,
"default": 1.0,
"displayed_name": "Pigment",
"internal_name": "paint_mode",
"maximum": 1.0,
"minimum": 0.0,
"tcomment_tooltip": "If this string is difficult to translate, feel free to change it to something more descriptive. Just try to be succinct and consistent.",
"tooltip": "Subtractive spectral color mixing mode.\n0.0 no spectral mixing\n1.0 only spectral mixing"
}
],
"states__comment": "# WARNING: only append to this list, for compatibility of replay files (brush.get_state() in stroke.py)",
"states": [
"x",
"y",
"pressure",
"partial_dabs",
"actual_radius",
"smudge_ra",
"smudge_ga",
"smudge_ba",
"smudge_a",
"last_getcolor_r",
"last_getcolor_g",
"last_getcolor_b",
"last_getcolor_a",
"last_getcolor_recentness",
"actual_x",
"actual_y",
"norm_dx_slow",
"norm_dy_slow",
"norm_speed1_slow",
"norm_speed2_slow",
"stroke",
"stroke_started",
"custom_input",
"rng_seed",
"actual_elliptical_dab_ratio",
"actual_elliptical_dab_angle",
"direction_dx",
"direction_dy",
"declination",
"ascension",
"viewzoom",
"viewrotation",
"direction_angle_dx",
"direction_angle_dy",
"attack_angle",
"flip",
"gridmap_x",
"gridmap_y",
"declinationx",
"declinationy",
"dabs_per_basic_radius",
"dabs_per_actual_radius",
"dabs_per_second",
"barrel_rotation"
]
}