重构SkinUI代码更新啦!

26 篇文章 0 订阅

本次抽了一点时间简单重构了一下SkinUI

先简单概述一下SkinUI,SkinUI是基于重绘MFC控件而开发的一套简单的MFC界面库,而非现在主流的DriectUI库,因为基于Windows的标准控件,所以限制性还是比较大的!因为库中不可能把每个控件做到面面俱到,只是实现目前大多数的功能而已,当遇到更新复杂的控件还是需要用户自己进行重绘!

上一版本的SkinUI,因为逻辑代码和界面没有分离,用户不得不需要在c++中去大量的书写关于控件的设置皮肤代码,为了让用户能更简单的使用SkinUI,本次将界面模块剥夺出来,用xml进行简单的描述来设置皮肤,基本上用户不需要在新建的MFC工程中添加什么代码,只需要做好控件的事件响应即可。

先看一下仿360的示例代码

SkinUI仿360

xml描述代码

Markup
<?xml version="1.0" encoding="UTF-8"?>
<Window size="910,610" mininfo="840,600" bkcolor="#c5c5c5">
	<Font name="微软雅黑" size="12"/>
	<Font name="微软雅黑" size="16"/>
	<Font name="微软雅黑" size="22"/>
  	<Font name="微软雅黑" size="30"/>
	<Image path="360\bg.png" pos="0,3,1,1,1,1" id="1"/>
	<Image path="360\medal.png" pos="1,1,190,1,164,30" id="2"/>
	<Image path="360\1.bmp" pos="0,3,1,121,1,1" id="3"/>
	<Image path="360\logo.png" pos="1,1,160,50,10,112" id="4"/>
	<Image path="360\register_bg.png" pos="1,1,250,132,5,265" id="5"/>	
	<Image path="360\fenge_line.png" pos="1,3,255,121,254,1" id="6"/>	
	<Image path="360\error.png" pos="0,0,51,168,197,286" id="7"/>
	
	<String text="360安全卫士9.2" font="1" color="#FFFFFF" pos="0,0,15,10,200,50" id="1"/>
	<String text="您的电脑已经" pos="0,0,250, 180, 350, 280" font="2" color="#1C1C1C" id="2"/>
	<String text="24" pos="0,0,360, 175, 400, 280" font="3" color="#0000FF" id="3"/>
	<String text="天没有体检,建议立即体检!" pos="0,0,400,180,680,280" font="2" color="#1C1C1C" id="4"/>
	<String text="系统可能已经存在大量风险,安全性和性能都在急速下降," pos="0,0,250, 220, 680, 270" font="1" color="#555555" id="5"/>
	<String text="建议您每天坚持电脑体检,提高电脑的安全和性能" pos="0,0,250, 240, 680, 280" font="1" color="#555555" id="6"/>
	<String text="执行电脑检查啥的" pos="0,0,250, 240, 680, 280" font="4" color="#0000FF" id="7" visible="false"/>
			
	<String text="控件自己放吧,不折腾了!so easy!" pos="3,3,240, 350, 1, 1" font="4" format="8208" color="#0000FF" id="8"/>
	
	<Button pos="1,1,35,0,8,22" type="push" id="5000" normalimage="360\close_normal.png" hotimage="360\close_hover.png" pushedimage="360\close_pressed.png" focusedimage="360\close_normal.png" size="27,22" trans="true"/>
	<Button pos="1,1,62,0,35,22" type="push" id="5001" normalimage="360\min_normal.png" hotimage="360\min_hover.png" pushedimage="360\min_pressed.png" focusedimage="360\min_normal.png" size="27,22" trans="true"/>
	<Button pos="1,1,89,0,62,22" type="push" id="5003" normalimage="360\menu_normal.png" hotimage="360\menu_hover.png" pushedimage="360\menu_pressed.png" focusedimage="360\menu_normal.png" size="27,22" trans="true"/>
	<Button pos="1,1,116,0,89,22" type="push" id="5004" normalimage="360\feedback_normal.png" hotimage="360\feedback_hover.png" pushedimage="360\feedback_pressed.png" focusedimage="360\feedback_normal.png" size="27,22" trans="true"/>
	<Button pos="1,1,143,0,116,22" type="push" id="5005" normalimage="360\skin_normal.png" hotimage="360\skin_hover.png" pushedimage="360\skin_pressed.png" focusedimage="360\skin_normal.png" size="27,22" trans="true"/>
	
	<TabCtrl pos="0,0,10,40,670,120" paddingtext="17,65" fontnormalcolor="#FFFFFF" trans="true" id="5900">
		<item text="电脑体检" iconimage="360\ico_Examine.png" selimage="360\ico_Examine.png"/>
		<item text="木马查杀" iconimage="360\ico_dsmain.png" selimage="360\ico_dsmain.png"/>
		<item text="系统修复" iconimage="360\ico_SysRepair.png" selimage="360\ico_SysRepair.png"/>
		<item text="电脑清理" iconimage="360\ico_TraceCleaner.png" selimage="360\ico_TraceCleaner.png"/>
		<item text="优化加速" iconimage="360\ico_SpeedupOpt.png" selimage="360\ico_SpeedupOpt.png"/>
		<item text="电脑专家" iconimage="360\ico_expert.png" selimage="360\ico_expert.png"/>
		<item text="电脑门诊" iconimage="360\ico_diannaomenzhen.png" selimage="360\ico_diannaomenzhen.png"/>
		<item text="软件管家" iconimage="360\ico_softmgr.png" selimage="360\ico_softmgr.png"/>
	
		<itemimage highlight="360\toolbar_hover.png" down="360\toolbar_hover.png" ninepart="2,2,2,2"/>
		<itemsize size="80,80"/>
	</TabCtrl>
	
	<Button pos="0,0,230,350,396,416" type="push" id="5006" normalimage="360\check_normal.png" hotimage="360\check_hover.png" pushedimage="360\check_pressed.png" focusedimage="360\check_normal.png" size="27,22" trans="true"/>
	
	
</Window>	

简单说一下使用SkinUI的步骤 新建mfc对话框工程,取名360Safe,

打开Stdafx.h文件,添加SkinUI需要的头文件和库文件,添加如下代码

C++
#include "../SkinUI/SkinUI.h"
//库文件
#ifdef _DEBUG
#ifdef _UNICODE
#pragma comment (lib,"../Lib/SkinUI_ud.lib")
#else
#pragma comment (lib,"../Lib/SkinUI_d.lib")
#endif
#else
#ifdef _UNICODE
#pragma comment (lib,"../Lib/SkinUI_u.lib")
#else
#pragma comment (lib,"../Lib/SkinUI.lib")
#endif
#endif

打开360SafeDlg.h文件,修改对话框基类,改成class CMy360SafeDlg : public CSkinDialog

将原来的CDialog改成CSkinDialog即可

打开360SafeDlg.cpp文件 将本文档所有CDialog字符串替换成CSkinDialog 即可

加载xml文件,在CMy360SafeDlg的构造函数的成员初始化列表中增加一个参数

C++
CMy360SafeDlg::CMy360SafeDlg(CWnd* pParent /*=NULL*/)
: CSkinDialog(CMy360SafeDlg::IDD,TEXT("360Safe.xml"), pParent)
{
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

编译该工程,在生成的exe所在目录下,新建360Safe.xml文件,将上面的xml源码复制进去,保存即可

这段时间在抽空写一下xml标签的帮助文档,希望对使用SkinUI工程的朋友一点帮助吧!

现在你就可以使用SkinUI做你的mfc开发了

说了这么多,SkinUI源码地址

svn更新地址:http://code.taobao.org/svn/MFC_CODE/课程补充 

百度网盘地址:http://pan.baidu.com/s/1nu42zgd

### 回答1: JS报uncaught syntaxerror: unexpected token <错误通常是因为在HTML页面中引入JS脚本的链接出现了问题。这个错误提示显示出了JS脚本引入的标签遭遇了一个不期望的"<"符号。 解决这个问题的方法是检查HTML页面中引用的JS脚本链接是否正确且完整。可以使用浏览器开发者工具找到报错的具体行号,并检查该行的链接是否正确。如果链接正确,可以尝试将JS代码复制到一个单独的JS文件中,然后再通过链接方式引用。如果仍然存在错误,可能是JS代码本身的问题,需要检查JS代码语法和逻辑是否正确。如果仍然无法解决问题,建议寻求更专业的技术支持或寻找更多相关教程和资料进行学习。 ### 回答2: 在使用JavaScript开发网站时,我们常常会遇到“Uncaught SyntaxError: Unexpected token <”这个错误。这个错误通常出现在我们的JavaScript代码中出现了“<”符号。这个符号在HTML代码中被广泛使用来表示标签的开头,但在JavaScript代码中,这个符号是一个特殊的字符,它表示字符串或表达式的小于(比较)运算符。因此,当我们在JavaScript代码中使用了“<”符号时,浏览器会认为这是一个意外的符号,从而引发了这个错误。 解决这个错误的方法有以下几种: 1. 检查JavaScript代码是否正确:首先,我们应该检查我们的JavaScript代码是否有任何语法错误或拼写错误。这通常可以通过使用浏览器的控制台来完成,控制台会显示JavaScript代码中的错误信息和行号。 2. 使用转义字符:如果我们必须在JavaScript代码中使用“<”符号,我们可以使用转义字符“\”来转义它。例如,我们可以使用“<”符号代替“\<”符号。 3. 将JavaScript代码放在正确的位置:有时,当我们将JavaScript代码放在错误的位置时,例如在HTML标签中间或在<script>标签之外,浏览器会将其解释为HTML代码,从而引发这个错误。因此,我们应该确保我们的JavaScript代码放在正确的位置,例如在<script>标签内或外部的JavaScript文件中。 4. 检查文件路径:在引用外部JavaScript文件时,我们应该确保文件路径是正确的。如果文件路径不正确,浏览器将无法加载JavaScript文件,从而导致这个错误。 5. 确保服务器已正确配置:如果我们的网站使用了服务器端脚本语言(例如PHP或ASP),我们应该确保服务器已正确配置,以便正确解释JavaScript代码。否则,浏览器将尝试在客户端解释服务器端的JavaScript代码,并引发这个错误。 总之,我们可以通过检查代码的语法及结构、使用转义字符、放置代码的位置和检查文件路径以及确保服务器已正确配置等方法来解决JavaScript中的“Uncaught SyntaxError: Unexpected token <”错误。 ### 回答3: JS在页面中报错时,返回的错误信息通常都很晦涩难懂,容易让人不知所措。uncaught syntaxerror: unexpected token <错误通常表示代码语法错误,通常是由于代码中缺少某个符号或引号、拼写错误等原因导致的。 首先,检查代码中是否有缺省的分号、括号、引号等未闭合。这些都是常见的语法错误,检查并及时修复可以大大缩短解决问题的时间。 其次,如果确定代码本身没有问题,则需要检查引入的外部文件,例如CSS、JS等文件。如果其中有文件错误,那么可能会导致JS也无法正常执行,所以要对所有文件进行检查。 另外,如果代码中使用了特殊字符、HTML标签等,也可能会引发这种错误。此时可以将这些内容用escape()函数进行转义处理,避免出现这种错误。 最后,可以使用开发者工具中的console.log()对代码进行逐行调试,定位出错误出现的位置。这种方法比较耗时,但可以有效地解决问题。 总之,解决uncaught syntaxerror: unexpected token <错误需要耐心,仔细地检查代码,尝试各种可能的解决方法。同时,建议平时写代码时注意细节,避免出现常见的语法错误。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值