Overview
Examples
Screenshots
Comparisons
Applications
Download
Documentation
Tutorials
Bazaar
Status & Roadmap
FAQ
Authors & License
Forums
Funding Ultimate++
Search on this site
Search in forums












SourceForge.net Logo
Home » U++ Library support » Look and Chameleon Technology » Switch skin
Switch skin [message #41897] Tue, 04 February 2014 23:18 Go to next message
galious is currently offline  galious
Messages: 28
Registered: March 2008
Promising Member
Hi,

is there any interest to have the 'Switch'-pusher skinned (CH_STYLEd)? If so, I'm willing to write patch.

Best regards,
--Martin
Re: Switch skin [message #42006 is a reply to message #41897] Mon, 10 February 2014 19:55 Go to previous messageGo to next message
mirek is currently offline  mirek
Messages: 14162
Registered: November 2005
Ultimate Member
Actually, not a bad idea. Option too is lacking Style.

In practice, for host based skin, we are simply overwriting Images. But I can imagine someone would like to have specially skinned Switches and Options...
Re: Switch skin [message #42971 is a reply to message #41897] Fri, 18 April 2014 21:42 Go to previous messageGo to next message
galious is currently offline  galious
Messages: 28
Registered: March 2008
Promising Member
Sorry for being late with the patch. Work, personal activities and some deep thoughts about backwards compatibility are to be blamed...

Nevertheless I've created the following class OptionCh(ameleon) which should be a 100% drop-in replacement of the Option class.

OptionCh.h
#ifndef _CtrlLibExt_OptionCh_h_
#define _CtrlLibExt_OptionCh_h_

class OptionCh : public Option {
public:
	virtual void   Paint(Draw& draw);

public:
	struct Style : ChStyle<Style> {
		Value look[3][4];
		Size  size;
		Color textcolor[3][4];
		Value facecolor;
		Font  font;
	};

public:
	enum { UNCHECKED = 0, CHECKED = 1, UNDETERMINED = 2 };

protected:
	virtual void  RefreshPush();
	const Style *St() const;

private:
	const Style *style;
	const Style *styleSwitch;

public:
	static const Style& StyleDefault();
	static const Style& StyleSwitch();
	OptionCh&  SetStyle(const Style& s);
	OptionCh&  SetSwitchStyle(const Style& s);
};

#endif


OptionCh.cpp
#include "CtrlLibExt.h"

namespace CtrlLibExt
{

CH_STYLE(OptionCh, Style, StyleDefault)
{
	CtrlsImageLook(look[OptionCh::UNCHECKED], CtrlsImg::I_O0);
	CtrlsImageLook(look[OptionCh::CHECKED], CtrlsImg::I_O1);
	CtrlsImageLook(look[OptionCh::UNDETERMINED], CtrlsImg::I_O2);
	size = Null;

	textcolor[OptionCh::UNCHECKED][CTRL_NORMAL] =
	textcolor[OptionCh::CHECKED][CTRL_NORMAL] =
	textcolor[OptionCh::UNDETERMINED][CTRL_NORMAL] =
	textcolor[OptionCh::UNCHECKED][CTRL_HOT] =
	textcolor[OptionCh::CHECKED][CTRL_HOT] =
	textcolor[OptionCh::UNDETERMINED][CTRL_HOT] =
	textcolor[OptionCh::UNCHECKED][CTRL_PRESSED] =
	textcolor[OptionCh::CHECKED][CTRL_PRESSED] =
	textcolor[OptionCh::UNDETERMINED][CTRL_PRESSED] = SColorLabel();

	textcolor[OptionCh::UNCHECKED][CTRL_DISABLED] =
	textcolor[OptionCh::CHECKED][CTRL_DISABLED] =
	textcolor[OptionCh::UNDETERMINED][CTRL_DISABLED] = SColorDisabled();

	facecolor = SColorFace();
	font = StdFont();
}

CH_STYLE(OptionCh, Style, StyleSwitch)
{
	CtrlsImageLook(look[OptionCh::UNCHECKED], CtrlsImg::I_S0);
	CtrlsImageLook(look[OptionCh::CHECKED], CtrlsImg::I_S1);
	size = Null;

	textcolor[OptionCh::UNCHECKED][CTRL_NORMAL] =
	textcolor[OptionCh::CHECKED][CTRL_NORMAL] =
	textcolor[OptionCh::UNCHECKED][CTRL_HOT] =
	textcolor[OptionCh::CHECKED][CTRL_HOT] =
	textcolor[OptionCh::UNCHECKED][CTRL_PRESSED] =
	textcolor[OptionCh::CHECKED][CTRL_PRESSED] = SColorLabel();

	textcolor[OptionCh::UNCHECKED][CTRL_DISABLED] =
	textcolor[OptionCh::CHECKED][CTRL_DISABLED] = SColorDisabled();

	facecolor = SColorFace();
	font = StdFont();
}

OptionCh& OptionCh::SetStyle(const OptionCh::Style& s)
{
	if(style != &s) {
		style = &s;
		RefreshLayout();
		Refresh();
	}
	return *this;
}

OptionCh& OptionCh::SetSwitchStyle(const OptionCh::Style& s)
{
	if(styleSwitch != &s) {
		styleSwitch = &s;
		RefreshLayout();
		Refresh();
	}
	return *this;
}

void OptionCh::RefreshPush() {
	Pusher::RefreshPush();
}

const OptionCh::Style *OptionCh::St() const
{
	const Style *st;
	if(switchimage) {
		st = styleSwitch ? styleSwitch : &StyleSwitch();
	} else {
		st = style ? style : &StyleDefault();
	}

	return st;
}

void OptionCh::Paint(Draw& w) {
	const OptionCh::Style *st = St();
	Size sz = GetSize();
	
	if(!IsTransparent())
		ChPaint(w, 0, 0, sz.cx, sz.cy, st->facecolor);

	Size isz = st->size;
	if(IsNull(isz) && st->look[0][0].Is<Image>()) {
		isz = st->look[0][0].To<Image>().GetSize();
	}
	if(IsNull(isz)) {
		int h = GetSmartTextHeight("M", INT_MAX);
		isz = Size(h, h);
	}
	
	Size tsz(0, 0);
	int ix = 0, iy = 0, ty = 0;
	
	if(showlabel) {
		tsz = GetSmartTextSize(label, st->font);
		ty = (sz.cy - tsz.cy) / 2;
		iy = (tsz.cy - isz.cy) / 2 + ty;
	} else {
		ix = (sz.cx - isz.cx) / 2;
		iy = (sz.cy - isz.cy) / 2;
	}
	
	int q = GetVisualState();
	int r = !switchimage && (!notnull || threestate) && IsNull(option)
				? OptionCh::UNDETERMINED
				: option == 1 ? OptionCh::CHECKED
				              : OptionCh::UNCHECKED;
	
	ChPaint(w, ix, iy, isz.cx, isz.cy, st->look[r][q]);
	
	if(showlabel) {
		bool ds = !IsShowEnabled();
		DrawSmartText(w, isz.cx + 4, ty, tsz.cx, label, st->font,
		              st->textcolor[r][q],
		              VisibleAccessKeys() ? accesskey : 0);
		if(HasFocus())
			DrawFocus(w, RectC(isz.cx + 2, ty - 1, tsz.cx + 3, tsz.cy + 2) & sz);
	}
}
}


CtrlLibExt.h
#ifndef _CtrlLibExt_CtrlLibExt_h
#define _CtrlLibExt_CtrlLibExt_h

#include <CtrlLib/CtrlLib.h>

using namespace Upp;

namespace CtrlLibExt
{

#include "OptionCh.h"
// After cleaning these up these will be published as well
//#include "RichTextScroll.h"
//#include "Splash.h"

} // namespace CtrlLibExt

#endif


Hopefully this can serve as a solid base to include skinning to the default Option control.

Best regards,
--Martin
Re: Switch skin [message #43180 is a reply to message #42971] Thu, 29 May 2014 12:54 Go to previous messageGo to next message
bushman is currently offline  bushman
Messages: 134
Registered: February 2009
Experienced Member

Ok, great, that's for Option.

Have you done the same for Switch already?

tks!
Re: Switch skin [message #43323 is a reply to message #43180] Mon, 30 June 2014 12:06 Go to previous message
galious is currently offline  galious
Messages: 28
Registered: March 2008
Promising Member
I'll do the same for Switcher once I've the need for it myself. However as you can see it is not to much code to do it yourself.

@Mirek: any chance the code above (and if I do it for Switcher for the new code as well) it gets included in UPP? Maybe replacing the current controls?

Best regards,
Martin
Previous Topic: How to chameleonize DockableCtrl tab button when in AutoHide mode?
Next Topic: help with ToolButton style
Goto Forum:
  


Current Time: Sat Dec 14 14:12:02 CET 2024

Total time taken to generate the page: 0.04349 seconds