颜色迁移Reinhard算法代码


算法流程大体为: 首先,将源图像和目标图像由rgb空间转为lab空间; 其次,分别计算源图像和目标图像均值及标准差; 然后,在lab空间,遍历每个像素点,分别对每个像素点计算各个通道值,计算方法为:将源图像减去自身均值后乘以标准差比值,再将相乘结果加上目标图像均值后赋值给输出图像; 最后,将输出图像由lab空间转为rgb空间。至此,算法执行完毕。
资源截图
代码片段和文件信息

// ColorTransfer.cpp : 定义应用程序的类行为。
//

#include “stdafx.h“
#include “ColorTransfer.h“
#include “ColorTransferDlg.h“

#ifdef _DEBUG
#define new DEBUG_NEW
#endif


// CColorTransferApp

BEGIN_MESSAGE_MAP(CColorTransferApp CWinApp)
ON_COMMAND(ID_HELP &CWinApp::onhelp)
END_MESSAGE_MAP()


// CColorTransferApp 构造

CColorTransferApp::CColorTransferApp()
{
// 支持重新启动管理器
m_dwRestartManagerSupportFlags = AFX_RESTART_MANAGER_SUPPORT_RESTART;

// TODO:  在此处添加构造代码,
// 将所有重要的初始化放置在 InitInstance 中
}


// 唯一的一个 CColorTransferApp 对象

CColorTransferApp theApp;


// CColorTransferApp 初始化

BOOL CColorTransferApp::InitInstance()
{
// 如果一个运行在 Windows XP 上的应用程序清单指定要
// 使用 ComCtl32.dll 版本 6 或更高版本来启用可视化方式,
//则需要 InitCommonControlsEx()。  否则,将无法创建窗口。
INITCOMMONCONTROLSEX InitCtrls;
InitCtrls.dwSize = sizeof(InitCtrls);
// 将它设置为包括所有要在应用程序中使用的
// 公共控件类。
InitCtrls.dwICC = ICC_WIN95_CLASSES;
InitCommonControlsEx(&InitCtrls);

CWinApp::InitInstance();


AfxEnableControlContainer();

// 创建 shell 管理器,以防对话框包含
// 任何 shell 树视图控件或 shell 列表视图控件。
CShellManager *pShellManager = new CShellManager;

// 激活“Windows Native”视觉管理器,以便在 MFC 控件中启用主题
CMFCVisualManager::SetDefaultManager(RUNTIME_CLASS(CMFCVisualManagerWindows));

// 标准初始化
// 如果未使用这些功能并希望减小
// 最终可执行文件的大小,则应移除下列
// 不需要的特定初始化例程
// 更改用于存储设置的注册表项
// TODO:  应适当修改该字符串,
// 例如修改为公司或组织名
SetRegistryKey(_T(“应用程序向导生成的本地应用程序“));

CColorTransferDlg dlg;
m_pMainWnd = &dlg;
INT_PTR nResponse = dlg.DoModal();
if (nResponse == IDOK)
{
// TODO:  在此放置处理何时用
//  “确定”来关闭对话框的代码
}
else if (nResponse == IDCANCEL)
{
// TODO:  在此放置处理何时用
//  “取消”来关闭对话框的代码
}
else if (nResponse == -1)
{
TRACE(traceAppMsg 0 “警告: 对话框创建失败,应用程序将意外终止。
“);
TRACE(traceAppMsg 0 “警告: 如果您在对话框上使用 MFC 控件,则无法 #define _AFX_NO_MFC_CONTROLS_IN_DIALOGS。
“);
}

// 删除上面创建的 shell 管理器。
if (pShellManager != NULL)
{
delete pShellManager;
}

// 由于对话框已关闭,所以将返回 FALSE 以便退出应用程序,
//  而不是启动应用程序的消息泵。
return FALSE;
}


 属性            大小     日期    时间   名称
----------- ---------  ---------- -----  ----
     目录           0  2018-07-19 15:20  color
     目录           0  2018-07-17 19:47  colorColorTransfer
     文件          60  2013-07-22 01:18  colorColorTransferClassDiagram.cd
     文件          60  2013-07-22 01:18  colorColorTransferClassDiagram1.cd
     文件       91356  2018-07-17 18:14  colorColorTransferColorTransfer.aps
     文件        2465  2018-07-03 15:50  colorColorTransferColorTransfer.cpp
     文件         485  2018-07-03 15:50  colorColorTransferColorTransfer.h
     文件       10852  2018-07-03 16:15  colorColorTransferColorTransfer.rc
     文件       11306  2018-07-17 13:26  colorColorTransferColorTransfer.vcxproj
     文件        2556  2018-07-15 14:01  colorColorTransferColorTransfer.vcxproj.filters
     文件         165  2018-07-17 13:25  colorColorTransferColorTransfer.vcxproj.user
     文件        5457  2018-07-15 21:08  colorColorTransferColorTransferDlg.cpp
     文件         873  2018-07-03 16:15  colorColorTransferColorTransferDlg.h
     文件        4648  2018-07-17 13:25  colorColorTransferFastTransfer.cpp
     文件         717  2018-07-15 20:06  colorColorTransferFastTransfer.h
     文件        2828  2018-07-17 13:26  colorColorTransferGDALProcess.cpp
     文件         834  2018-07-17 19:47  colorColorTransferGDALProcess.h
     文件           0  2018-07-09 15:56  colorColorTransferGetVldArea.cpp
     文件           0  2018-07-09 15:56  colorColorTransferGetVldArea.h
     文件        4150  2018-07-03 15:50  colorColorTransferReadMe.txt
     目录           0  2018-07-17 18:08  colorColorTransfer
es
     文件       67777  2013-07-22 01:18  colorColorTransfer
esColorTransfer.ico
     文件         682  2018-07-03 15:50  colorColorTransfer
esColorTransfer.rc2
     文件        1704  2018-07-03 16:08  colorColorTransfer
esource.h
     文件         146  2018-07-03 15:50  colorColorTransferstdafx.cpp
     文件        1578  2018-07-03 15:50  colorColorTransferstdafx.h
     文件         234  2018-07-03 15:50  colorColorTransfer argetver.h
     目录           0  2018-07-17 18:08  colorColorTransferx64
     目录           0  2018-07-17 19:47  colorColorTransferx64Debug
     文件        2069  2018-07-17 19:47  colorColorTransferx64DebugColorTransfer.log
     文件     1372784  2018-07-17 19:47  colorColorTransferx64DebugColorTransfer.obj
............此处省略120个文件信息

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件举报,一经查实,本站将立刻删除。

发表评论

评论列表(条)