我正在尝试专门化一个 Color
类及其成员函数 to()
以便从一个颜色空间转换到另一个颜色空间并返回。这是我到目前为止所拥有的:
enum ColorSpace {
BGR, RGB, LAB, HSV, XYZ, YUV, HSL, CMY, YIQ, LUV, HLAB, LCH, OHTA
};
template<ColorSpace _CS, typename _Dtp> class Color;
template<typename _Dtp>
class Color<RGB, _Dtp> {
public:
Color(_Dtp R, _Dtp G, _Dtp B) : R(R), G(G), B(B) { ;; };
Color() : Color(0, 0, 0) { ;; };
~Color() { ;; };
_Dtp R, G, B;
template<ColorSpace _CS, typename _Dtp2 = _Dtp>
Color<_CS, _Dtp2> to<>();
template<typename _Dtp2 = _Dtp>
Color<HSV, _Dtp2> to<HSV, _Dtp2>() {
Color<HSV, _Dtp2> res;
rgb2hsv(R, G, B, res.H, res.S, res.V);
return res;
}
};
template<typename _Dtp = double>
class Color<HSV, _Dtp> {
public:
Color(_Dtp H, _Dtp S, _Dtp V) : H(H), S(S), V(V) { ;; };
Color() : Color(0, 0, 0) { ;; };
~Color() { ;; };
_Dtp H, S, V;
template<ColorSpace _CS, typename _Dtp2 = _Dtp>
Color<_CS, _Dtp2> to<>();
template<typename _Dtp2 = _Dtp>
Color<RGB, _Dtp2> to<RGB, _Dtp2>() {
Color<RGB, _Dtp2> res;
hsv2rgb(H, S, V, res.R, res.G, res.B);
return res;
}
};
每个色彩空间都有一个类别。每个类都有专门的函数 to()
用于每个可能的转换。但是,出于显而易见的原因,我只发布了其中的 2 个。所以,当我尝试使用转换函数时:
Color<RGB, double> c(255, 255, 125);
Color<HSV, double> c2 = c.to<HSV, double>();
我收到以下错误:
Error: class "Color" has no member "to"
当我尝试为类 Color
使用默认类型时,我遇到了最后一个问题:
template<typename _Dtp = double>
class Color<RGB, _Dtp> {
...
...
在那种情况下我什至不能写这个:
Color<RGB> c;
它给我这个错误:
Error: expected a declaration
最佳答案
你的代码应该是这样的:
enum ColorSpace {
BGR, RGB, LAB, HSV, XYZ, YUV, HSL, CMY, YIQ, LUV, HLAB, LCH, OHTA
};
template<ColorSpace _CS, typename _Dtp> class Color;
template<typename _Dtp>
class Color<RGB, _Dtp> {
public:
Color( _Dtp R, _Dtp G, _Dtp B ) : R( R ), G( G ), B( B ) { ;; };
Color() : Color( 0, 0, 0 ) { ;; };
~Color() { ;; };
_Dtp R, G, B;
template<ColorSpace _CSO, typename _Dtp2> struct STo;
template<typename _Dtp2> struct STo<HSV, _Dtp2>
{
Color<HSV, _Dtp2> to()
{
Color<HSV, _Dtp2> res;
rgb2hsv( R, G, B, res.H, res.S, res.V );
return res;
}
};
template<ColorSpace _CSO, typename _Dtp2>
Color<_CSO, _Dtp2> to()
{
STo<_CSO, _Dtp2> object;
return object.to();
}
};
template<typename _Dtp>
class Color<HSV, _Dtp> {
public:
Color( _DtpH, _DtpS, _DtpV ) : H( H ), S( S ), V( V ) { ;; };
Color() : Color( 0, 0, 0 ) { ;; };
~Color() { ;; };
_DtpH, S, V;
template<ColorSpace _CSO, typename _Dtp2> struct STo;
template<typename _Dtp2> struct STo<RGB, _Dtp2>
{
Color<RGB, _Dtp2> to()
{
Color<RGB, _Dtp2> res;
hsv2rgb( H, S, V, res.R, res.G, res.B );
return res;
}
};
template<ColorSpace _CSO, typename _Dtp2>
Color<_CSO, _Dtp2> to()
{
STo<_CSO, _Dtp2> object;
return object.to();
}
};
你不能只写函数特化而不定义。这就是为什么您应该从“to”函数中删除方括号 <>。但在这种情况下,我们遇到了另一个问题——我们不能对函数使用偏特化,但对类可以。在这种情况下,我使用“to”函数作为可能的结构特化“STo”的条目
关于c++ - 类和成员函数模板特化出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45694251/