/*
* Copyright 2018 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can
* be found in the LICENSE file.
*
*/
//
//
//
#include <stdio.h>
#include <stdlib.h>
#include "color/color.h"
#include "ts/transform_stack.h"
#include "groups.h"
/*
Group {
children: [
Layer {
rasters: [
SkcRaster {
private: 2147745810
}
],
cmds: [
CoverNonzero,
CoverWipMoveToMask
]
},
Layer {
rasters: [
SkcRaster {
private: 2147745805
}
],
cmds: [
CoverNonzero,
CoverMask,
FillColor(
[
1.0,
1.0,
1.0,
1.0
]
),
BlendOver
]
}
],
enter_cmds: [
CoverMaskZero
],
leave_cmds: []
}
*/
static bool is_mask_invertible = false;
void
groups_toggle()
{
is_mask_invertible = !is_mask_invertible;
}
//
//
//
skc_path_t *
groups_paths_decode(skc_path_builder_t pb)
{
skc_path_t * paths = malloc(sizeof(*paths) * 6);
for (uint32_t ii=0; ii<3; ii++)
{
float const xy = (float)ii * 2.0f + 2.0f;
skc_path_begin(pb);
skc_path_ellipse(pb,xy,xy,0.5f,1.5f);
skc_path_end(pb,paths+ii*2);
skc_path_begin(pb);
skc_path_ellipse(pb,xy,xy,1.0f,1.0f);
skc_path_end(pb,paths+ii*2+1);
}
return paths;
}
void
groups_paths_release(skc_context_t context,
skc_path_t * const paths)
{
skc_path_release(context,paths,6);
free(paths);
}
//
//
//
skc_raster_t *
groups_rasters_decode(struct ts_transform_stack * const ts,
skc_path_t const * const paths,
skc_raster_builder_t rb)
{
static float const raster_clip[] = { 0.0f, 0.0f, 0.0f, 0.0f };
skc_raster_t * rasters = malloc(sizeof(*rasters) * 6);
uint32_t const ts_restore = ts_transform_stack_save(ts);
ts_transform_stack_push_translate(ts,800,800);
ts_transform_stack_concat(ts);
for (uint32_t ii=0; ii<6; ii++)
{
skc_raster_begin(rb);
skc_raster_add_filled(rb,
paths[ii],
ts_transform_stack_top_weakref(ts),
ts_transform_stack_top_transform(ts),
NULL,
raster_clip);
skc_raster_end(rb,rasters+ii);
}
// restore stack depth
ts_transform_stack_restore(ts,ts_restore);
return rasters;
}
void
groups_rasters_release(skc_context_t context,
skc_raster_t * const rasters)
{
skc_raster_release(context,rasters,6);
free(rasters);
}
//
//
//
void
groups_rewind()
{
;
}
//
//
//
uint32_t
groups_layer_count()
{
return 6;
}
void
groups_layers_decode(skc_raster_t const * const rasters,
skc_composition_t composition,
skc_styling_t styling,
bool const is_srgb)
{
skc_group_id group_ids[2];
{
skc_styling_group_alloc(styling,group_ids+0);
// this is the root group
skc_styling_group_parents(styling,group_ids[0],0,NULL);
// the range of the root group is maximal
skc_styling_group_range_lo(styling,group_ids[0],0);
skc_styling_group_range_hi(styling,group_ids[0],5);
skc_styling_group_enter(styling,
group_ids[0],
1,
(skc_styling_cmd_t[])
{ SKC_STYLING_OPCODE_COLOR_ACC_ZERO |
SKC_STYLING_OPCODE_IS_FINAL });
skc_styling_cmd_t cmds[3 + 1];
float background[4] = { 1.0f, 1.0f, 1.0f, 1.0f };
skc_styling_background_over_encoder(cmds,background);
cmds[3] = SKC_STYLING_OPCODE_SURFACE_COMPOSITE | SKC_STYLING_OPCODE_IS_FINAL;
skc_styling_group_leave(styling,
group_ids[0],
SKC_STYLING_CMDS(cmds));
}
//
// for all layers...
//
for (uint32_t ii=0; ii<3; ii++)
{
skc_styling_group_alloc(styling,group_ids+1);
// this is the root group
skc_styling_group_parents(styling,group_ids[1],1,group_ids);
// the range of the root group is maximal
skc_styling_group_range_lo(styling,group_ids[1],ii*2);
skc_styling_group_range_hi(styling,group_ids[1],ii*2+1);
skc_styling_group_enter(styling,
group_ids[1],
1,
(skc_styling_cmd_t[])
{ is_mask_invertible
? (SKC_STYLING_OPCODE_COVER_MASK_ONE | SKC_STYLING_OPCODE_IS_FINAL)
: (SKC_STYLING_OPCODE_COVER_MASK_ZERO | SKC_STYLING_OPCODE_IS_FINAL) });
skc_styling_group_leave(styling,
group_ids[1],
1,
(skc_styling_cmd_t[])
{ SKC_STYLING_OPCODE_NOOP |
SKC_STYLING_OPCODE_IS_FINAL });
//
//
//
{
float const rgba[4] = { 0.0f, 0.0f, 0.0f, 1.0f };
skc_styling_cmd_t cmds[1 + 1 + 1];
cmds[0] = SKC_STYLING_OPCODE_COVER_NONZERO;
if (is_mask_invertible)
{
cmds[1] = SKC_STYLING_OPCODE_COVER_WIP_MOVE_TO_MASK;
cmds[2] = SKC_STYLING_OPCODE_COVER_MASK_INVERT | SKC_STYLING_OPCODE_IS_FINAL;
}
else
{
cmds[1] = SKC_STYLING_OPCODE_COVER_WIP_MOVE_TO_MASK | SKC_STYLING_OPCODE_IS_FINAL;
}
skc_styling_group_layer(styling,
group_ids[1],
ii*2,
_countof(cmds),cmds);
}
{
float rgba[4];
color_rgb32_to_rgba_f32(rgba,0xFF<<ii*8,1.0f);
skc_styling_cmd_t cmds[1 + 1 + 3 + 1];
cmds[0] = SKC_STYLING_OPCODE_COVER_NONZERO;
cmds[1] = SKC_STYLING_OPCODE_COVER_MASK;
skc_styling_layer_fill_rgba_encoder(cmds+2,rgba);
cmds[_countof(cmds)-1] = SKC_STYLING_OPCODE_BLEND_OVER | SKC_STYLING_OPCODE_IS_FINAL;
skc_styling_group_layer(styling,
group_ids[1],
ii*2+1,
_countof(cmds),cmds);
}
}
//
// for all rasters...
//
for (uint32_t ii=0; ii<6; ii++)
{
skc_composition_place(composition,
rasters+ii,
&ii,
NULL, // &cmd->place.tx,
NULL, // &cmd->place.ty,
1);
}
}
//
//
//