qml实现rgb曲线调节功能

12 篇文章 3 订阅
该博客介绍了如何在Windows环境下使用Qt5.6.0和OpenCV3.4.2结合,通过自定义QAbstractListModel子类实现曲线编辑。曲线由256个点构成,动态生成并更新在QML界面中。博主分享了CCurvesModel和CCurveModel两个模型的实现细节,包括控制点的移动、计算256个点的值以及生成效果图的方法。此外,还提供了源码链接供读者参考和学习。
摘要由CSDN通过智能技术生成

环境:windows + qt5.6.0 + opencv342
效果图(注:该效果是项目中的截图,并非实际demo运行效果):
在这里插入图片描述

demo源码地址(附带opencv库,运行的时候请将dll文件拷贝到exe同目录):

demo源码地址

说明
曲线的实现方式是通过继承QAbstractListModel来实现自定义模型(CCurvesModelCCurveModel),在qml页面中则是通过InstantiatorCanvas控件来动态生成每条曲线的256个点,画曲线方式有多种,我这只是其中一种而已,最重要的还是如何通过控制点的移动和改变去计算256个点的值(相关算法我也是从其它地方扣来的,如果涉及到侵权,我会删除资源下载)。

CCurvesModel头文件代码:

class CCurvesModel : public QAbstractListModel
{
	Q_OBJECT

public:
	enum TitleRoles
	{

	};
	explicit CCurvesModel(QObject* parent = nullptr);
	~CCurvesModel() override;

	int length() { return m_datas.count(); }
	void append(CCurveModel* p);
	void clear();

public:
	Q_INVOKABLE QVariantMap get(int row) const;

	QVariant data(const QModelIndex& index, int role = Qt::DisplayRole) const override;
	bool setData(const QModelIndex& index, const QVariant& value, int role) override;
	Q_INVOKABLE int rowCount(const QModelIndex& parent = QModelIndex()) const override;
	int columnCount(const QModelIndex&/*parent*/) const override;

    //生成效果图,在calcCurve处理完之后调用
    Q_INVOKABLE void updateImg();
    Q_INVOKABLE CCurveModel* getCurveModel(int index);

protected:
	QHash<int, QByteArray> roleNames() const override;

private:
	QHash<int, QByteArray> m_role_names;
	QList<CCurveModel*> m_datas;
};

说明:该模型用于管理rgb,r,g,b四条曲线
updateImg:调节曲线后生成效果图,在calcCurve处理完之后调用

CCurveModel头文件代码:

struct MyStruct
{
	QPoint pt;
	bool bSelect;
	MyStruct()
	{
		bSelect = false;
	}
	MyStruct(int x, int y, bool bSel)
	{
		pt = QPoint(x, y);
		bSelect = bSel;
	}
};

class CCurveModel : public QAbstractListModel
{
	Q_OBJECT

public:
	enum TitleRoles
	{
		PointRole = Qt::UserRole + 1,
		SelectgRole
	};
	explicit CCurveModel(QObject* parent = nullptr);
	~CCurveModel() override;

	int length() { return m_datas.count(); }
	void append(MyStruct* p);
	QList<MyStruct*>::iterator insert(QList<MyStruct*>::iterator it, MyStruct* p);
	QList<MyStruct*>::iterator erase(QList<MyStruct*>::iterator it);
	void clear();

	inline QList<MyStruct*> getValueList() { return m_datas; }
	inline int getTolerance() { return tolerance; }
    inline uchar* getPts() { return m_pts; }
	void setOnlySelect();

	QList<MyStruct*>::iterator find(int x);
	QList<MyStruct*>::iterator find(int x, int y);
	QList<MyStruct*>::iterator add(int x, int y);

public:
	Q_INVOKABLE QVariantMap get(int row) const;

	QVariant data(const QModelIndex& index, int role = Qt::DisplayRole) const override;
	bool setData(const QModelIndex& index, const QVariant& value, int role) override;
	Q_INVOKABLE int rowCount(const QModelIndex& parent = QModelIndex()) const override;
	int columnCount(const QModelIndex&/*parent*/) const override;

	Q_INVOKABLE int calcCurve();
	Q_INVOKABLE double getValue(int index);
	Q_INVOKABLE void mouseDown(int x, int y);
	Q_INVOKABLE bool mouseMove(int x, int y);
	Q_INVOKABLE void mouseUp(int x, int y);

protected:
	QHash<int, QByteArray> roleNames() const override;

private:
    QList<MyStruct*>::iterator current;//当前的控制点
	QHash<int, QByteArray> m_role_names;
	QList<MyStruct*> m_datas;
	int tolerance; //鼠标按下或移动时,捕获曲线点的误差范围
    uchar m_pts[256];//曲线256个点的值
	bool is_mouse_down;
};

说明:该模型用于管理256个点和控制点集合。
calcCurve:计算256个点的值。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值