diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/action.h | 2 | ||||
| -rw-r--r-- | src/canvas.c | 28 | ||||
| -rw-r--r-- | src/canvas.h | 1 | ||||
| -rw-r--r-- | src/ui.c | 65 | ||||
| -rw-r--r-- | src/user.c | 16 | 
5 files changed, 92 insertions, 20 deletions
| diff --git a/src/action.h b/src/action.h index d9b7698..825057f 100644 --- a/src/action.h +++ b/src/action.h @@ -12,7 +12,7 @@ struct action_pixcol {  struct ActionPixelsColors {  	long int cnt; -	struct actiton_pixcol *pix; +	struct action_pixcol *pix;  };  typedef union { diff --git a/src/canvas.c b/src/canvas.c index 47f9b92..3a016d7 100644 --- a/src/canvas.c +++ b/src/canvas.c @@ -483,22 +483,23 @@ canvas_set_proj_path(Canvas *c, const char *path)  static Layer *  layer_create(uint w, uint h)  { -    Layer *res; -    int i; +	Layer *res; +	int i;  	/* TODO: better error handling and maybe allocating together? */ -    res = malloc(sizeof *res); +	res = malloc(sizeof *res); -    res->pix = malloc(h * w * sizeof(* res->pix)); -    if (res->pix == NULL) { -        fprintf(stderr, "Error creating layer\n"); -        layer_destroy(res); -        return NULL; -    } +	res->visible = 1; +	res->pix = malloc(h * w * sizeof(* res->pix)); +	if (res->pix == NULL) { +		fprintf(stderr, "Error creating layer\n"); +		layer_destroy(res); +		return NULL; +	} -    for (i = 0; i < w*h; ++i) -        res->pix[i] = 0; +	for (i = 0; i < w*h; ++i) +		res->pix[i] = 0; -    return res; +	return res;  }  static void @@ -575,7 +576,8 @@ canvas_point_redraw(Canvas *c, long int x, long int y)  	c->pres_pix[COORD(x, y)] = 0;  	for (i = 0; i < c->layer_arr_cnt; i++) -		c->pres_pix[COORD(x, y)] = canvas_blend_color(c->pres_pix[COORD(x, y)], c->layers[i]->pix[COORD(x, y)]); +		if (c->layers[i]->visible) +			c->pres_pix[COORD(x, y)] = canvas_blend_color(c->pres_pix[COORD(x, y)], c->layers[i]->pix[COORD(x, y)]);  }  static void diff --git a/src/canvas.h b/src/canvas.h index bc96ab9..7595473 100644 --- a/src/canvas.h +++ b/src/canvas.h @@ -5,6 +5,7 @@  struct Layer {  	unsigned int *pix; +	unsigned int visible;  };  struct Canvas { @@ -40,6 +40,10 @@ static const SDL_Rect ui_buttons_rect[] = {  	{84, 82, 28, 28},  /* Undo */  	{84, 110, 28, 28}, /* Redo */  }; +static const SDL_Rect ui_timeline_rect[] = { +	{112, 0, 20, 20}, +	{112, 20, 20, 20}, +};  struct UIPanel {      uint8 type, redraw; @@ -136,7 +140,7 @@ ui_create(const char *path)  	/* ui_panel_divider_init(&main_ui->p_divs[0], 5, 10, 100, 1, &main_ui->p_canvas, &main_ui->p_timeline); */  	ui_panel_divider_init(&main_ui->p_divs[0], 5, 5, 120, 0, &main_ui->p_divs[1], &main_ui->p_divs[2]);  	ui_panel_divider_init(&main_ui->p_divs[1], 0, 8, 22+31*((tool_array_size()+2)/3), 3, &main_ui->p_palette, &main_ui->p_buttons); -	ui_panel_divider_init(&main_ui->p_divs[2], 0, 5, 70, 3, &main_ui->p_canvas, &main_ui->p_timeline); +	ui_panel_divider_init(&main_ui->p_divs[2], 0, 5, 120, 3, &main_ui->p_canvas, &main_ui->p_timeline);  	ui_resize();  } @@ -285,6 +289,19 @@ ui_mousel_down(int x, int y)  			break;  		}  		break; +	case UI_PANELTYPE_TIMELINE: +		if (cur_canvas == NULL) +			return; +		x = x - fpan->geom.x - 8; +		y = y - fpan->geom.y - 8; +		y /= 22; +		if (x > 22) break; +		if (y < 0 || y >= cur_canvas->layer_arr_cnt) break; +		cur_canvas->layers[cur_canvas->layer_arr_cnt-1-y]->visible ^= 1; +		canvas_refresh(cur_canvas); +		ui_redraw_panel(UI_PANELTYPE_TIMELINE); +		ui_redraw_panel(UI_PANELTYPE_CANVAS); +		break;  	}  } @@ -362,6 +379,11 @@ ui_focus_panel(int x, int y)          && x - r->x < r->w && y - r->y < r->h)          return &main_ui->p_canvas.head; +	r = &main_ui->p_timeline.head.geom; +	if (r->x <= x && r->y <= y +		&& x - r->x < r->w && y - r->y < r->h) +		return &main_ui->p_timeline.head; +      return NULL;  } @@ -455,7 +477,7 @@ ui_panel_redraw(UIPanel *p)  		ui_panel_buttons_redraw((UIPanelButtons *)p);  		break;  	case UI_PANELTYPE_TIMELINE: -		ui_panel_draw_frame(p); +		ui_panel_timeline_redraw((UIPanelTimeline *)p);  		break;  	default:  		fprintf(stderr, "%s:%d:ui_panel_redraw: No redraw fuction for %u\n", __FILE__, __LINE__, p->type); @@ -638,6 +660,45 @@ ui_panel_timeline_init(UIPanelTimeline *p)      return ui_panel_init((UIPanel *)p, UI_PANELTYPE_TIMELINE);  } +static uint8 +ui_panel_timeline_redraw(UIPanelTimeline *p) +{ +	SDL_Rect dest; +	int i; +	dest.x = 6; +	dest.y = 6; +	dest.w = p->head.geom.w - 12; +	dest.h = p->head.geom.h - 12; +	SDL_RenderSetViewport(ren, &dest); +	SDL_SetRenderDrawColor(ren, 199, 207, 221, 255); +	SDL_RenderClear(ren); +	if (cur_canvas != NULL) { +		dest.x = 2; +		dest.w = dest.h = 20; +		dest.y = (cur_canvas->layer_arr_cnt - 1 - cur_canvas->cur_layer) * 22 + 2; +		SDL_SetRenderDrawColor(ren, 101, 115, 146, 255); +		SDL_RenderFillRect(ren, &dest); +		SDL_SetRenderDrawColor(ren, 19, 19, 19, 255); +		for (i = 0; i < cur_canvas->layer_arr_cnt; i++) { +			dest.y = (cur_canvas->layer_arr_cnt - 1 - i) * 22 + 2; +			if (cur_canvas->layers[i]->visible) +				SDL_RenderCopy(ren, main_ui->theme, &ui_timeline_rect[0], &dest); +			else +				SDL_RenderCopy(ren, main_ui->theme, &ui_timeline_rect[1], &dest); +			SDL_RenderDrawLine(ren, 2, i*22, 21, i*22); +			SDL_RenderDrawLine(ren, 2, i*22+1, 21, i*22+1); +			SDL_RenderDrawLine(ren, 0, i*22+2, 0, i*22+21); +			SDL_RenderDrawLine(ren, 1, i*22+2, 1, i*22+21); +			SDL_RenderDrawLine(ren, 2, i*22+22, 21, i*22+22); +			SDL_RenderDrawLine(ren, 2, i*22+23, 21, i*22+23); +			SDL_RenderDrawLine(ren, 22, i*22+2, 22, i*22+21); +			SDL_RenderDrawLine(ren, 23, i*22+2, 23, i*22+21); +		} +	} +	SDL_RenderSetViewport(ren, NULL); +	ui_panel_draw_frame(&p->head); +} +  /* Panel divider functions */  static uint8  ui_panel_divider_init(UIPanelDivider *p, int fw, int lw, int of, uint8 st, UIPanel *p1, UIPanel *p2) @@ -83,6 +83,7 @@ user_canvas_open(const Arg *x)  	if (cur_canvas == NULL)  		puts("Error opening file");  	ui_redraw_panel(UI_PANELTYPE_CANVAS); +	ui_redraw_panel(UI_PANELTYPE_TIMELINE);  }  void @@ -123,6 +124,7 @@ user_canvas_create_new(const Arg *x)  	cur_canvas = canvas_init(w, h, ren);  	ui_redraw_panel(UI_PANELTYPE_CANVAS); +	ui_redraw_panel(UI_PANELTYPE_TIMELINE);  }  void @@ -144,6 +146,7 @@ user_canvas_import_png(const Arg *x)  	if (cur_canvas == NULL)  		puts("Error opening file");  	ui_redraw_panel(UI_PANELTYPE_CANVAS); +	ui_redraw_panel(UI_PANELTYPE_TIMELINE);  }  void @@ -165,20 +168,25 @@ void  user_testing_layer_add(const Arg *x)  {  /* TODO: temp function */ -    canvas_add_layer(cur_canvas, -1); +	if (cur_canvas == NULL) return; +	canvas_add_layer(cur_canvas, -1);  	fprintf(stdout, "%s:%u: added layer\n", __FILE__, __LINE__); -    cur_canvas->cur_layer = cur_canvas->layer_arr_cnt-1; +	cur_canvas->cur_layer = cur_canvas->layer_arr_cnt-1; +	ui_redraw_panel(UI_PANELTYPE_CANVAS); +	ui_redraw_panel(UI_PANELTYPE_TIMELINE);  }  void  user_layer_chng(const Arg *x)  { +	if (cur_canvas == NULL) return;      cur_canvas->cur_layer += (unsigned int)cur_canvas->layer_arr_cnt; -    cur_canvas->cur_layer += x->i; +    cur_canvas->cur_layer += (x->i % cur_canvas->layer_arr_cnt);      cur_canvas->cur_layer %= cur_canvas->layer_arr_cnt;  	fprintf(stdout, "%s:%u: changed to layer %u\n", __FILE__, __LINE__, cur_canvas->cur_layer); -    ui_redraw_panel(UI_PANELTYPE_CANVAS); +	ui_redraw_panel(UI_PANELTYPE_CANVAS); +	ui_redraw_panel(UI_PANELTYPE_TIMELINE);  }  void | 
