SkinSharp功能强大,该皮肤库支持完全多种颜色改变等。

下面是静态链接库时的SkinH.h头文件:

/*在Stdafx.h文件中加入如下语句
#include "SkinH.h"
#pragma comment(lib, "Detours.lib")
#pragma comment(lib, "SkinH_ST.lib") **************** 根据编译选项在链接选项中做如下设置 ***********
下表显示根据要使用的运行时库应忽略的库。
若要使用第一行运行时库 请忽略第2行的这些库
单线程 (libc.lib)
libcmt.lib、msvcrt.lib、libcd.lib、libcmtd.lib、msvcrtd.lib
多线程 (libcmt.lib)
libc.lib、msvcrt.lib、libcd.lib、libcmtd.lib、msvcrtd.lib
使用 DLL 的多线程 (msvcrt.lib)
libc.lib、libcmt.lib、libcd.lib、libcmtd.lib、msvcrtd.lib
调试单线程 (libcd.lib)
libc.lib、libcmt.lib、msvcrt.lib、libcmtd.lib、msvcrtd.lib
调试多线程 (libcmtd.lib)
libc.lib、libcmt.lib、msvcrt.lib、libcd.lib、msvcrtd.lib
使用 DLL 的调试多线程 (msvcrtd.lib)
libc.lib、libcmt.lib、msvcrt.lib、libcd.lib、libcmtd.lib
**************************************************************/
#ifndef SKIN_H
#define SKIN_H ///ERROR CODE////////////////////////
#define SRET_OK 0
#define SRET_ERROR 1
#define SRET_ERROR_FILE 2
#define SRET_ERROR_PARAM 3
#define SRET_ERROR_CREATE 4
#define SRET_ERROR_FORMAT 5
#define SRET_ERROR_VERSION 6
#define SRET_ERROR_PASSWORD 7
#define SRET_ERROR_INVALID 8
////////////////////////////////////// //接口列表
extern "C"
{
/*
功能: 静态库初始化
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_Init(HINSTANCE hInstance); /*
功能: 静态库卸载
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_Free(); /*
功能: 加载程序当前目录下的文件名skinh.she皮肤进行换肤
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_Attach(); /*
功能: 加载指定路径的皮肤进行换肤
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_AttachEx(
LPCTSTR strSkinFile, //皮肤文件路径
LPCTSTR strPassword //皮肤密钥
); /*
功能: 加载指定路径的皮肤进行换肤并指定相应的色调,饱和度,亮度
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_AttachExt(
LPCTSTR strSkinFile, //皮肤文件路径
LPCTSTR strPassword, //皮肤密钥
int nHue, //色调, 取值范围0-360, 默认值0
int nSat, //饱和度, 取值范围0-256, 默认值0
int nBri //亮度, 取值范围0-256, 默认值0
); /*
功能: 加载指定资源进行换肤并指定相应的色调,饱和度,亮度
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_AttachRes(
LPBYTE pShe, //资源皮肤数据指针
DWORD dwSize, //资源皮肤数据长度
LPCTSTR strPassword, //皮肤密钥
int nHue, //色调, 取值范围0-360, 默认值0
int nSat, //饱和度, 取值范围0-256, 默认值0
int nBri //亮度, 取值范围0-256, 默认值0
); /*
功能: 加载指定皮肤资源进行换肤并指定相应的色调,饱和度,亮度
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_AttachResEx(
LPCTSTR lpName, //资源名
LPCTSTR lpType, //资源类型
LPCTSTR strPassword, //皮肤密钥
int nHue, //色调, 取值范围0-360, 默认值0
int nSat, //饱和度, 取值范围0-256, 默认值0
int nBri //亮度, 取值范围0-256, 默认值0
); /*
功能: 卸载换肤
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_Detach(); /*
功能: 卸载指定句柄的窗体或者控件的皮肤
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_DetachEx(
HWND hWnd //指定卸载皮肤的窗体或控件的句柄
); /*
功能: 设置指定窗体的透明度
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_SetWindowAlpha(
HWND hWnd, //窗体的句柄
int nAlpha //透明度
); /*
功能: 调整当前皮肤的色调,饱和度,亮度
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_AdjustHSV(
int nHue, //色调, 取值范围0-360, 默认值0
int nSat, //饱和度, 取值范围0-256, 默认值0
int nBri //亮度, 取值范围0-256, 默认值0
); /*
功能: 获取指定窗口或控件在nX,nY处的颜色值
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_GetColor(
HWND hWnd, //指定窗体或控件的句柄
int nX, //横坐标
int nY //纵坐标
); /*
功能: 指定窗体和控件的换肤类型
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_Map(
HWND hWnd, //指定窗体或控件的句柄
int nType //换肤类型
); //换肤类型
#define TYPE_UNKNOWN 0 //未知类型
#define TYPE_ANIMATE 1001 //动画控件
#define TYPE_CHECKBOX 1002 //复选框
#define TYPE_COMBOBOX 1003 //组合框
#define TYPE_COMBOLBOX 1004 //组合下拉框
#define TYPE_CONTROLBAR 1005 //控件栏
#define TYPE_DATETIME 1006 //日期控件
#define TYPE_EDITBOX 1007 //文本框
#define TYPE_GROUPBOX 1008 //分组框
#define TYPE_HEADERCTRL 1009 //列头控件
#define TYPE_HOTKEY 1010 //热键控件
#define TYPE_IPADDRESS 1011 //IP地址控件
#define TYPE_LABEL 1012 //标签控件
#define TYPE_LISTBOX 1013 //列表框
#define TYPE_LISTVIEW 1014 //列表视图
#define TYPE_MDICLIENT 1015 //MDI客户区
#define TYPE_MENU 1016 //菜单
#define TYPE_MONTHCAL 1017 //月历控件
#define TYPE_PICTURE 1018 //图片框
#define TYPE_PROGRESS 1019 //进度条
#define TYPE_PUSHBUTTON 1020 //普通按钮
#define TYPE_RADIOBUTTON 1021 //单选框
#define TYPE_REBAR 1022 //重组栏
#define TYPE_RICHEDIT 1023 //富文本框
#define TYPE_SCROLLBAR 1024 //滚动条
#define TYPE_SCROLLCTRL 1025 //内置滚动条的控件
#define TYPE_SPINCTRL 1026 //调节器
#define TYPE_STATUSBAR 1027 //状态栏
#define TYPE_TABCTRL 1028 //选择夹
#define TYPE_TOOLBAR 1029 //工具栏
#define TYPE_TOOLBARWND 1030 //MFC工具栏窗体
#define TYPE_TRACKBAR 1031 //滑条控件
#define TYPE_TREEVIEW 1032 //树形视图
#define TYPE_WINDOW 1034 //标准窗体
#define TYPE_COMCTRL 1036 //通用换肤
#define TYPE_PAINTCTRL 1037 //通用换肤 /*
功能: 设置Aero特效
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_SetAero(
int bAero //1为开启特效,0为关闭特效
); /*
功能: 设置Aero特效参数
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_AdjustAero(
int nAlpha, //透明度, 0-255, 默认值0
int nShwDark, //亮度, 0-255, 默认值0
int nShwSharp, //锐度, 0-255, 默认值0
int nShwSize, //阴影大小, 2-19, 默认值2
int nX, //水平偏移, 0-25, 默认值0 (目前不支持)
int nY, //垂直偏移, 0-25, 默认值0 (目前不支持)
int nRed, //红色分量, 0-255, 默认值 -1
int nGreen, //绿色分量, 0-255, 默认值 -1
int nBlue //蓝色分量, 0-255, 默认值 -1
); /*
功能: 设置窗体是否可以移动
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_SetWindowMovable(
HWND hWnd, //窗口句柄
BOOL bMovable //0为不可移动, 1为可移动
); /*
功能: 设置控件的背景色(目前仅对单选框, 复选框, 分组框有效)
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_SetBackColor(
HWND hWnd, //控件句柄
int nRed, //红色分量
int nGreen, //绿色分量
int nBlue //蓝色分量
); /*
功能: 设置控件的文本颜色色(目前仅对单选框,复选框,分组框有效)
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_SetForeColor(
HWND hWnd, //控件句柄
int nRed, //红色分量
int nGreen, //绿色分量
int nBlue //蓝色分量
); /*
功能: 用于填充表格或者列表控件数据时,重复绘制影响执行效率问题
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_LockUpdate(
HWND hWnd, //指定窗体或控件的句柄
int bUpdate //1为锁定绘制,0为解锁绘制
); /*
功能: 设置菜单透明度
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_SetMenuAlpha(
int nAlpha //菜单透明度,取值范围 0 - 255
); /*
功能: 绘制指定设备上下文的元素
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_NineBlt(
HDC hDtDC, //目标设备上下文
int left, //左上角水平坐标
int top, //左上角垂直坐标
int right, //右下角水平坐标
int bottom, //右下角垂直坐标
int nMRect //元素id
); /*
功能: 设置标题菜单栏
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_SetTitleMenuBar(
HWND hWnd, //窗口句柄
BOOL bEnable, //是否设置 1为设置, 0 为取消
int nTMenuY, //菜单栏高度
int nTopOffs, //顶部偏移
int nRightOffs //右部偏移
); /*
功能: 设置控件的字体
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_SetFont(
HWND hWnd, //控件的句柄
HFONT hFont //字体句柄
); /*
功能: 设置控件的字体
返回值: 成功返回0, 失败返回非0
*/
int __stdcall SkinH_SetFontEx(
HWND hWnd, //控件的句柄
LPCTSTR szFace, //字体名称
int nHeight, //字体高度
int nWidth, //字体宽度
int nWeight, //字体磅数
int nItalic, //是否斜体
int nUnderline, //是否下划线
int nStrikeOut //是否删除线
); }
#endif

[MFC美化] SkinSharp使用详解2-SkinH.h函数介绍的更多相关文章

  1. [MFC美化] SkinSharp使用详解1-使用方法

    需要注意的是: 加载换肤后,程序关闭时,无需调用卸载皮肤接口,SkinSharp换肤库会自己完成清理工作.换肤时无需卸载皮肤,直接调用即可. 其DLL使用方法与前面几种皮肤库用法类似.如下: 1. 将 ...

  2. [MFC美化] SkinMagic使用详解3- 常见使用问题解答

    在SkinMagic使用过程中,经常遇到以下几个问题: 1. 静态加载皮肤文件时,资源文件IDR_SKIN_CORONA可能会报错:未声明的标识符 解决方法:添加头文件"Resource.h ...

  3. [MFC美化] Skin++使用详解-使用方法及注意事项

    主要分为以下几个方面: 1.Skin++使用方法 2.使用中注意事项 一. Skin++使用方法 SkinPPWTL.dll.SkinPPWTL.lib.SkinPPWTL.h ,将三个文件及相应皮肤 ...

  4. [MFC美化] USkin使用详解-使用方法

    该种皮肤库资料很少,用法与前面几种类似. 它主要有:USkin.dll ,USkin.lib,USkin.h和Sakura.msstyles这四个文件.皮肤格式是.u3.SkinBuilder是USk ...

  5. [MFC美化] SkinMagic使用详解2- SkinMagic常用函数介绍

    SkinMagic常用函数介绍 (1)InitSkinMagicLib函数:初始化SkinMagic int InitSkinMagicLib( //初始化SkinMagic工具库 HINSTANCE ...

  6. [MFC美化] SkinMagic使用详解1- SkinMagic使用流程

    [SkinMagic使用流程] 1.工程配置SkinMagic相关文件 2.初始化SkinMagic皮肤文件,窗体加载皮肤 3.释放皮肤资源 特别声明,SkinMagic要是破解版的,如果不是,可能需 ...

  7. MFC下CSocket编程详解(转)

    原文转自 http://blog.csdn.net/yejiansnake/article/details/2175778 MFC下CSocket编程详解: 1. 常用的函数和注意事项(详细的函数接口 ...

  8. IIS负载均衡-Application Request Route详解第一篇: ARR介绍(转载)

    IIS负载均衡-Application Request Route详解第一篇: ARR介绍 说到负载均衡,相信大家已经不再陌生了,本系列主要介绍在IIS中可以采用的负载均衡的软件:微软的Applica ...

  9. 淘宝JAVA中间件Diamond详解(2)-原理介绍

    淘宝JAVA中间件Diamond详解(二)---原理介绍 大家好,通过第一篇的快速使用,大家已经对diamond有了一个基本的了解.本次为大家带来的是diamond核心原理的介绍,主要包括server ...

随机推荐

  1. Extjs表单控件入门

    ExtJs表单控件用formPanel来做为表单元素的容器.默认情况下,是使用Ajax异步提交. 大家知道要使用Extjs必须引入他的库,所以我们要引入以下几个文件: ext-all.css ext- ...

  2. MVVM框架avalon在兼容旧式IE

    迷你MVVM框架avalon在兼容旧式IE做的努力 当前标签: avalon 共3页: 1 2 3 下一页  迷你MVVM框架avalon在兼容旧式IE做的努力 司徒正美 2014-03-13 11: ...

  3. LInux 2.6 编译内核出现Question

    问:在make menuconfig配置完之后(选的默认配置),然后就make出现如下错误:root@org:/usr/src/linux-2.6.32.27# make CHK include/li ...

  4. 自由的Debian

    原文:http://www.debian.org/intro/free 许多人在刚开始接触自由软件时都会很困惑,原因是自由软件中的自由一词并不是他们所期望的那样.对他们而言自由意味着免费.一本英文字典 ...

  5. Changing the working directory of VIM

    Sometimes we want to open another file in the same folder with current editing file, what we can do ...

  6. 跨平台C/C++集成开发环境-Code::Blocks-内置GCC

    Code::Blocks 是一个开放源码的全功能的跨平台C/C++集成开发环境. 相比于基于Delphi的Dev-C++共享C++IDE,Code::Blocks是开放源码软件.Code::Block ...

  7. WCF引用方式

    WCF之各种WCF引用方式 写在开头:本文内容来自 WCF全面解析中的一个经典例子,如果你已经看过了,那么可以忽略本文,本文旨在和大家分享不一样的WCF使用方法. 准备工作: 1.创建解决方案WCFS ...

  8. BCP导入导出MsSql

    BCP导入导出MsSql 1.导出数据 (1).在Sql Server Management Studio中: --导出数据到tset1.txt,并指定本地数据库的用户名和密码 --这里需要指定数据库 ...

  9. lua脚本中字符串分割split

    function split( s, c ) for item in string.gmatch( s, "(.-)"..c) do print(item); end end s ...

  10. 初识B/S结构编程技术

    B/S结构编程语言 ASP(Active Server Page 动态服务器页面)技术 微软早期推出的B/S编程技术,出现在JSP和ASP.NET之前,PHP当时也很不稳定.ASP之前,动态网站使用G ...