Xor Colors: Support sizes

This commit is contained in:
Bill Kendrick 2023-04-22 12:16:49 -07:00
parent b85e47cf60
commit d4db61b084
2 changed files with 38 additions and 13 deletions

View file

@ -63,6 +63,7 @@ https://tuxpaint.org/
+ Tint, Color & White + Tint, Color & White
+ Toothpaste + Toothpaste
+ TV + TV
+ Xor Colors
+ WIP... more! + WIP... more!
Bill Kendrick <bill@newbreedsoftware.com> Bill Kendrick <bill@newbreedsoftware.com>

View file

@ -23,7 +23,7 @@
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
(See COPYING.txt) (See COPYING.txt)
Last updated: February 12, 2023 Last updated: April 22, 2023
*/ */
#include <stdio.h> #include <stdio.h>
@ -33,9 +33,10 @@
#include "SDL_mixer.h" #include "SDL_mixer.h"
static Mix_Chunk *xor_snd; static Mix_Chunk *xor_snd;
static int xor_radius = 16;
Uint32 xor_api_version(void); Uint32 xor_api_version(void);
int xor_init(magic_api * api); int xor_init(magic_api * api, Uint32 disabled_features);
int xor_get_tool_count(magic_api * api); int xor_get_tool_count(magic_api * api);
SDL_Surface *xor_get_icon(magic_api * api, int which); SDL_Surface *xor_get_icon(magic_api * api, int which);
char *xor_get_name(magic_api * api, int which); char *xor_get_name(magic_api * api, int which);
@ -62,13 +63,17 @@ void xor_switchin(magic_api * api, int which, int mode, SDL_Surface * canvas);
void xor_switchout(magic_api * api, int which, int mode, void xor_switchout(magic_api * api, int which, int mode,
SDL_Surface * canvas); SDL_Surface * canvas);
int xor_modes(magic_api * api, int which); int xor_modes(magic_api * api, int which);
Uint8 xor_accepted_sizes(magic_api * api, int which, int mode);
Uint8 xor_default_size(magic_api * api, int which, int mode);
void xor_set_size(magic_api * api, int which, int mode, SDL_Surface * canvas, SDL_Surface * last, Uint8 size, SDL_Rect * update_rect);
Uint32 xor_api_version(void) Uint32 xor_api_version(void)
{ {
return (TP_MAGIC_API_VERSION); return (TP_MAGIC_API_VERSION);
} }
int xor_init(magic_api * api) int xor_init(magic_api * api, Uint32 disabled_features ATTRIBUTE_UNUSED)
{ {
char fname[1024]; char fname[1024];
@ -144,11 +149,11 @@ static void do_xor_circle(void *ptr, int which ATTRIBUTE_UNUSED,
magic_api *api = (magic_api *) ptr; magic_api *api = (magic_api *) ptr;
int xx, yy; int xx, yy;
for (yy = -16; yy < 16; yy++) for (yy = -xor_radius; yy < xor_radius; yy++)
{ {
for (xx = -16; xx < 16; xx++) for (xx = -xor_radius; xx < xor_radius; xx++)
{ {
if (api->in_circle(xx, yy, 16)) if (api->in_circle(xx, yy, xor_radius))
{ {
if (!api->touched(xx + x, yy + y)) if (!api->touched(xx + x, yy + y))
do_xor(api, which, canvas, last, x + xx, y + yy); do_xor(api, which, canvas, last, x + xx, y + yy);
@ -179,10 +184,10 @@ void xor_drag(magic_api * api, int which, SDL_Surface * canvas,
y = tmp; y = tmp;
} }
update_rect->x = ox - 16; update_rect->x = ox - xor_radius;
update_rect->y = oy - 16; update_rect->y = oy - xor_radius;
update_rect->w = (x + 16) - update_rect->x; update_rect->w = (x + xor_radius) - update_rect->x;
update_rect->h = (y + 16) - update_rect->y; update_rect->h = (y + xor_radius) - update_rect->y;
api->playsound(xor_snd, (x * 255) / canvas->w, 255); api->playsound(xor_snd, (x * 255) / canvas->w, 255);
} }
@ -250,3 +255,22 @@ int xor_modes(magic_api * api ATTRIBUTE_UNUSED, int which ATTRIBUTE_UNUSED)
{ {
return (MODE_PAINT | MODE_FULLSCREEN); return (MODE_PAINT | MODE_FULLSCREEN);
} }
Uint8 xor_accepted_sizes(magic_api * api ATTRIBUTE_UNUSED, int which ATTRIBUTE_UNUSED, int mode)
{
if (mode == MODE_PAINT)
return 8;
else
return 0;
}
Uint8 xor_default_size(magic_api * api ATTRIBUTE_UNUSED, int which ATTRIBUTE_UNUSED, int mode ATTRIBUTE_UNUSED)
{
return 4;
}
void xor_set_size(magic_api * api ATTRIBUTE_UNUSED, int which ATTRIBUTE_UNUSED, int mode ATTRIBUTE_UNUSED, SDL_Surface * canvas ATTRIBUTE_UNUSED, SDL_Surface * last ATTRIBUTE_UNUSED, Uint8 size ATTRIBUTE_UNUSED, SDL_Rect * update_rect ATTRIBUTE_UNUSED)
{
xor_radius = size * 4;
}