zoukankan      html  css  js  c++  java
  • duilib将xml和图片合并到exe资源中或者dll中

    直接上demo的编写步骤了。

    1.创建一个win32的空的工程用作demo工程。从其他工程复制stdafx.h、stdafx.cpp、testmain.cpp、mainwnd.h、mainwnd.cpp文件过来使用。我是从TestAlphaWindow工程中复制过来的。

    2.添加现有文件,改写代码等,使之正常编译通过。具体的改写就略过了。主要是删除无用的代码。预编译头等工程设置自己也设置好。

    3.这里我们是要将xml和图片等从exe的资源中加载,duilib已经考虑并提供了相关的接口。

    1)在WinMain函数中设置duilib的资源路径。

    [cpp] view plain copy

    1. CPaintManagerUI::SetInstance(hInstance);  
    2. CPaintManagerUI::SetResourceDll(hInstance);  

    SetResourceDll就是设置资源的dll的,意思是资源也可以放到其他dll中。这里我们是将资源放到了exe中,所以直接就设置当前的实例句柄即可,当然了,也可以省略,因为默认就是使用当前exe的实例句柄。最好还是显式的写出来。

    2)添加xml到资源文件中。首先看到资源文件那里是空的,也没有resource.h等,我们先右键资源文件-添加-资源-Version双击。现在有resource.h了。也有了rc文件。此时在源代码目录下新建一个文件夹叫res。将事先准备好的xml和图片放进去。右键VS里面的资源文件,然后选择添加-资源-导入-选择图片导入。然后再次右键VS里面的资源文件,然后选择添加-现有项-选择xml添加进去。

    3)图片和xml都添加进去之后,双击打开resource.h会发现,图片有对应的资源ID,然而xml却没有,不要紧,我们自己添加。右键VS资源文件下面的PackagingResToExeDemo.rc,然后查看代码,复制

    [plain] view plain copy

    1. /////////////////////////////////////////////////////////////////////////////  
    2. //  
    3. // PNG  
    4. //  
    5.     
    6. IDB_PNG1                PNG                     "res\close.png"  
    7. IDB_PNG2                PNG                     "res\min.png"  
    8. #endif    // 中文(中华人民共和国) resources  
    9. /////////////////////////////////////////////////////////////////////////////  

    这里代码到它下面,然后改写。最终为(注意删掉了PNG下面的)#endif    // 中文(中华人民共和国) resources

    [plain] view plain copy

    1. /////////////////////////////////////////////////////////////////////////////  
    2. //  
    3. // PNG  
    4. //  
    5.     
    6. IDB_PNG1                PNG                     "res\close.png"  
    7. IDB_PNG2                PNG                     "res\min.png"  
    8.     
    9. /////////////////////////////////////////////////////////////////////////////  
    10.     
    11. /////////////////////////////////////////////////////////////////////////////  
    12. //  
    13. // XML  
    14. //  
    15.     
    16. IDF_XML1                 XML                     "res\MainWnd.xml"  
    17. #endif    // 中文(中华人民共和国) resources  
    18. /////////////////////////////////////////////////////////////////////////////  

    然后在双击打开resource.h,给这个xml的标识IDF_XML1分配一个资源ID,比如

    [cpp] view plain copy

    1. #define IDF_XML1                        500  

    在stdafx.h中添加  #include "resource.h",这样添加工作就完成了。

    4)在OnCreate函数中,builder.Create接口采用CControlUI* Create(STRINGorID xml, LPCTSTR type = NULL, IDialogBuilderCallback* pCallback = NULL, CPaintManagerUI* pManager = NULL, CControlUI* pParent = NULL);这个接口即可。代码如下

    [cpp] view plain copy

    1. LRESULT CMainWnd::OnCreate(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled)  
    2. {  
    3.     LONG styleValue = ::GetWindowLong(*this, GWL_STYLE);  
    4.     styleValue &= ~WS_CAPTION;  //取消标题框  
    5.     styleValue &= ~WS_SIZEBOX;  //取消自动调整边框的风格,可以放置贴边自动最大化  
    6.     ::SetWindowLong(*this, GWL_STYLE, styleValue | WS_CLIPSIBLINGS | WS_CLIPCHILDREN);  
    7.     
    8.     m_PM.Init(m_hWnd);  
    9.     CDialogBuilder builder;   
    10.     CControlUI* pRoot = builder.Create(IDF_XML1, _T("xml"),  this, &m_PM);  
    11.     ASSERT(pRoot && "Failed to parse XML");  
    12.     m_PM.AttachDialog(pRoot);  
    13.     m_PM.AddNotifier(this);  
    14.     
    15.     return 0;  
    16. }  

    5)在xml中使用图片资源。首先查看PackagingResToExeDemo.rc的代码,发现close图片用的是IDB_PNG1,min用的IDB_PNG2;在双击打开resource.h查看IDB_PNG1对应的ID值是102,IDB_PNG2对应值是103。双击Mainwnd.xml在vs中打开(其他编辑器打开也行).写法如下

    [html] view plain copy

    1. <?xml version="1.0" encoding="utf-8" standalone="yes" ?>  
    2. <Window size="800,600" caption="0,0,0,45">  
    3.   <Font shared="true" id="0" name="微软雅黑" size="14" default="true"/>  
    4.   <VerticalLayout bordersize="1" bordercolor="#FF4B4B4B" inset="1,0,1,1" bkcolor="#FFFFFFFF">       
    5.     <HorizontalLayout height="45" bkcolor="#FF507ED3">  
    6.       <Control />  
    7.       <Button name="minBtn" tooltip="最小化" normalimage="res='103' restype='png' source='0,0,18,18'" hotimage="res='103' restype='png' source='18,0,36,18'" width="18" padding="40,13,0,14"/>       
    8.       <Button name="closeBtn" tooltip="关闭" normalimage="res='102' restype='png' source='0,0,18,18'" hotimage="res='102' restype='png' source='18,0,36,18'" width="18" padding="10,13,10,14"/>  
    9.     </HorizontalLayout>  
    10.   </VerticalLayout>  
    11. </Window>  

    不再写file='xxxx.png'了而是写res='103' restype='png'代替。

    至此,已经全部结束,编译运行看结果吧。这样就是exe和dll就行了。资源文件就不用带了。有的朋友连duilib_u.dll也不想带,也简单,使用静态库即可。

    静态库的使用也简单,在工程-C++-预处理器里面加上UILIB_STATIC,然后改写下stdafx.h中链接的duilib.lib为静态库的lib即可。不做细说了。具体可以去我的github代码仓库中看。我会把这个demo代码提交上去。地址:https://github.com/juhuaguai/duilib

  • 相关阅读:
    springdataJpa对无主键表或视图查询的支持
    Blynk系列随笔
    arduino系列文章
    Debezium系列随笔
    Kafka系列随笔
    SSAS 收藏
    Saiku 系列
    Mondrian系列
    数据仓库理论学习
    加密解密
  • 原文地址:https://www.cnblogs.com/skiing886/p/8081009.html
Copyright © 2011-2022 走看看