在计算机视觉库中,基类DescriptorExtractor(用于从一个图像中的关键点提取描述符)编写如下:
class DescriptorExtractor
{
public:
virtual ~DescriptorExtractor();
void compute( const Mat& image, vector<KeyPoint>& keypoints, Mat& descriptors ) const;
protected:
virtual void computeImpl(const Mat& image, vector<KeyPoint>& keypoints, Mat& descriptors ) const = 0;
};
对于不同类型的描述符,比如Surf of Sift,我们派生自基类:
class SurfDescriptorExtractor : public DescriptorExtractor
{
public:
SurfDescriptorExtractor(..){..}
protected:
virtual void computeImpl(const Mat& image, vector<KeyPoint>& keypoints, Mat& descriptors ) const;
SURF surf;
};
受保护的方法computeImpl被(重新)实现。
我写了一个新的描述符提取器MyDescriptorExtractor
,它需要当前的图像(如opencv中的其他图像)和之前的图像(?):
class MyDescriptorExtractor: public DescriptorExtractor
{
public:
...
protected:
virtual void computeImpl(const Mat& image, const Mat& prev_image, vector<KeyPoint>& keypoints, Mat& descriptors ) const;
}
我希望这个新类与使用DescriptorExtractor
作为参数的opencv方法兼容。做这个的最好方式是什么 ?问题是基类方法compute
不会有相同的签名......
由于
答案 0 :(得分:0)
请注意,子类仍应遵循Liskov substitution principle。
仍然,解决方案是在MyDescriptorExtractor
的构造函数中传递您需要的参数,这允许您保持相同的签名。