X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-core%2Ftrunk%2Fsrc%2Fmodules%2Flyr_std%2Fxorpattern.cpp;h=299a841380366f988de7ca7adf89d904e0b0aa96;hb=37600b4b217caa5e316984ec0b035c5e8f9698af;hp=7379be8b37a534d40269e8d9e74a1e0c5d4d27e4;hpb=65850038127c5cb49d09374b1776aa5dce11c674;p=synfig.git diff --git a/synfig-core/trunk/src/modules/lyr_std/xorpattern.cpp b/synfig-core/trunk/src/modules/lyr_std/xorpattern.cpp index 7379be8..299a841 100644 --- a/synfig-core/trunk/src/modules/lyr_std/xorpattern.cpp +++ b/synfig-core/trunk/src/modules/lyr_std/xorpattern.cpp @@ -6,6 +6,7 @@ ** ** \legal ** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley +** Copyright (c) 2007 Chris Moore ** ** This package is free software; you can redistribute it and/or ** modify it under the terms of the GNU General Public License as @@ -60,6 +61,7 @@ SYNFIG_LAYER_SET_CVS_ID(XORPattern,"$Id$"); /* === M E T H O D S ======================================================= */ XORPattern::XORPattern(): + Layer_Composite (1.0,Color::BLEND_STRAIGHT), pos(0.125,0.125), size(0.25,0.25) { @@ -70,7 +72,8 @@ XORPattern::set_param(const String & param, const ValueBase &value) { IMPORT(pos); IMPORT(size); - return false; + + return Layer_Composite::set_param(param,value); } ValueBase @@ -82,27 +85,36 @@ XORPattern::get_param(const String & param)const EXPORT_NAME(); EXPORT_VERSION(); - return ValueBase(); + return Layer_Composite::get_param(param); } Color XORPattern::get_color(Context context, const Point &point)const { - unsigned int a=(unsigned int)floor((point[0]+pos[0])/size[0]), b=(unsigned int)floor((point[1]+pos[1])/size[1]); + if(get_amount()==0.0) + return context.get_color(point); + + unsigned int a=(unsigned int)floor((point[0]-pos[0])/size[0]), b=(unsigned int)floor((point[1]-pos[1])/size[1]); unsigned char rindex=(a^b); unsigned char gindex=(a^(~b))*4; unsigned char bindex=~(a^b)*2; - return Color((Color::value_type)rindex/(Color::value_type)255.0, - (Color::value_type)gindex/(Color::value_type)255.0, - (Color::value_type)bindex/(Color::value_type)255.0, - 1.0); + Color color((Color::value_type)rindex/(Color::value_type)255.0, + (Color::value_type)gindex/(Color::value_type)255.0, + (Color::value_type)bindex/(Color::value_type)255.0, + 1.0); + + if(get_amount() == 1 && get_blend_method() == Color::BLEND_STRAIGHT) + return color; + else + return Color::blend(color,context.get_color(point),get_amount(),get_blend_method()); + } Layer::Vocab XORPattern::get_param_vocab()const { - Layer::Vocab ret; + Layer::Vocab ret(Layer_Composite::get_param_vocab()); ret.push_back(ParamDesc("pos") .set_local_name(_("Offset")) @@ -114,3 +126,26 @@ XORPattern::get_param_vocab()const return ret; } + +synfig::Layer::Handle +XORPattern::hit_check(synfig::Context context, const synfig::Point &getpos)const +{ + // if we have a zero amount + if(get_amount()==0.0) + // then the click passes down to our context + return context.hit_check(getpos); + + synfig::Layer::Handle tmp; + // if we are behind the context, and the click hits something in the context + if(get_blend_method()==Color::BLEND_BEHIND && (tmp=context.hit_check(getpos))) + // then return the thing it hit in the context + return tmp; + + // if we're using an 'onto' blend method and the click missed the context + if(Color::is_onto(get_blend_method()) && !(tmp=context.hit_check(getpos))) + // then it misses everything + return 0; + + // otherwise the click hit us, since we're the size of the whole plane + return const_cast(this); +}