颜色迁移Reinhard算法代码
算法流程大体为:
首先,将源图像和目标图像由rgb空间转为lab空间;
其次,分别计算源图像和目标图像均值及标准差;
然后,在lab空间,遍历每个像素点,分别对每个像素点计算各个通道值,计算方法为:将源图像减去自身均值后乘以标准差比值,再将相乘结果加上目标图像均值后赋值给输出图像;
最后,将输出图像由lab空间转为rgb空间。至此,算法执行完毕。
代码片段和文件信息
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
目录 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个文件信息
// 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个文件信息
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件举报,一经查实,本站将立刻删除。
评论列表(条)