由于最近换工作的原因,也没啥事,就简单学习了一下cef3和duilib,楼主之前是做MFC框架下的windows开发的,对界面库和新的客户端开发模式也有所了解,现在的大部分客户端都是基本的客户端框架下组合一个web 容器,web容器当然要看google的开源引擎cef3了,像Qt最近的版本好像也集成了,钉钉,微信、这些桌面应用都是基于web的客户端来开发的。

  所以楼主就也想学习一下,学习东西最快的方式就是做项目!!!所以我选择了duilib做界面,因为这个库是基于win32的,也是开源的,我也比较熟悉,然后web引擎当然是cef3了,开源的。花了一个星期吧话不多说,先放图

  主界面:

    

  动态图演示:

程序实现简单介绍:

  软件包括部分:界面绘图+容器填充。

  一开始我是先在Github上面下载了开源的duilib,然后看了看,模仿了里面的几个Demo例子,就开始动手。

Duilib界面设计,一部分是手写xml,这个我相信大家看了几个Demo之后就可以上手写了,然后再看一下网上的几篇布局的教程,Redrain写的,就可以了,界面控件与XML文件控件的对应关系要理解,实现的时候我是使用了 WindowImplBase这个类,所有与界面相关的操作只需要继承这个即可完成,实现简单的功能无非就是按钮的响应,按钮的选择等等,这些只需要到Notify(TNotifyUI& msg);函数中去处理,细节不多说,Duilib是可以根据xml中的控件名字去映射到控件类,

 CTabLayoutUI*pTabTest=static_cast<CTabLayoutUI*>(m_PaintManager.FindControl(_T("tabTest")));

  以上语句就是通过xml中的tabTest去定位到pTabTest,所有的控件都可以这样定位,定位到控件就简单了,剩下的控件操作看duilib提供的API文档即可。

  下面是界面的主界面类,包含web容器窗口的调整,主界面控件响应的操作实现,相信看过两次duilib的人都能看懂,这下面的WindowImplBase的虚函数接口是自己要实现的,

 class CMainFrame : public WindowImplBase
{
public:
CMainFrame();
virtual ~CMainFrame();
public:
LPCTSTR GetWindowClassName() const;
virtual void OnFinalMessage(HWND hWnd);
virtual void InitWindow();
virtual LRESULT ResponseDefaultKeyEvent(WPARAM wParam);
virtual UILIB_RESOURCETYPE GetResourceType() const;
virtual CDuiString GetSkinFile();
virtual CDuiString GetSkinFolder();
virtual CControlUI* CreateControl(LPCTSTR pstrClass);
virtual LRESULT HandleMessage(UINT uMsg, WPARAM wParam, LPARAM lParam);
virtual LRESULT OnSysCommand(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled);
virtual LRESULT HandleCustomMessage(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled);
virtual LRESULT OnSize(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled);
void FirstLoadCef();
void HideCefWindow();
HWND GetMainWnd(){ return this->m_hWnd; }
protected:
void Notify(TNotifyUI& msg);
void OnPrepare(TNotifyUI& msg);
void OnExit(TNotifyUI& msg);
void OnTimer(TNotifyUI& msg);
//
void OnSelChanged(CControlUI* pSender);
void OnClick(CControlUI * pSender);
//cef
void AdjustCefWindow();
void UpdateTransString(int nNum);
//create wnd
void ShowTransSelectFrame();
void ShowWordClassifyFrame();
void ShowWordSortFrame();
void ShowWordManagerFrame();
void HideLayoutFrame();
void ShowMiniModeFrame();
private:
BOOL m_bIsInit;
CTransSelectWnd *m_pTransSelectFrame;
CWordClassifyWnd *m_pWordClassifyFrame;
CWordSortWnd *m_pWordSortFrame;
CWordManagerWnd *m_pWordManagerFrame;
CMiniModeWnd *m_pMiniModeFrame;
};

  界面实现就不写了,源码会分享给大家的。

  容器填充,就是通过cef3内核加载web界面了,这个也不难,复杂的功能我没用到,只是简单启动了一个cef3的浏览器渲染进程,

  这里只实现了两个类,就满足了要求:cef进程实例类和和维护具体浏览器句柄类,

 class SimpleApp
: public CefApp
, public CefBrowserProcessHandler
{
public:
SimpleApp();
virtual CefRefPtr<CefBrowserProcessHandler> GetBrowserProcessHandler()
OVERRIDE{ return this; }
virtual void OnContextInitialized() OVERRIDE;
private:
IMPLEMENT_REFCOUNTING(SimpleApp);
}; class SimpleHandler
: public CefClient
, public CefDisplayHandler
, public CefLifeSpanHandler
{
public:
SimpleHandler();
virtual ~SimpleHandler();
virtual CefRefPtr<CefDisplayHandler> GetDisplayHandler() OVERRIDE
{
return this;
}
virtual CefRefPtr<CefLifeSpanHandler> GetLifeSpanHandler() OVERRIDE
{
return this;
} virtual void OnTitleChange(CefRefPtr<CefBrowser> browser,const CefString& title) OVERRIDE;
virtual void OnAfterCreated(CefRefPtr<CefBrowser> browser) OVERRIDE;
virtual void OnBeforeClose(CefRefPtr<CefBrowser> browser) OVERRIDE;
CefRefPtr<CefBrowser> GetCurrentBrowser();
private:
typedef std::list<CefRefPtr<CefBrowser> > BrowserList;
BrowserList browser_list_; private:
IMPLEMENT_REFCOUNTING(SimpleHandler);
};

  两个类足够了,主函数启动的代码,

 CPaintManagerUI::SetInstance(hInstance);
#if defined(WIN32) && !defined(UNDER_CE)
HRESULT Hr = ::CoInitialize(NULL);
#else
HRESULT Hr = ::CoInitializeEx(NULL, COINIT_MULTITHREADED);
#endif
if( FAILED(Hr) ) return ;
CefMainArgs args(hInstance);
//创建CefApp实例
CefRefPtr<SimpleApp> app(new SimpleApp);
int exitCode = CefExecuteProcess(args, app, NULL);
if (exitCode >= )
{
return exitCode;
}
//填充这个结构体,定制CEF的行为。
CefSettings settings;
//初始化CEF
CefInitialize(args, settings, app, NULL);
CMainFrame* pFrame = new CMainFrame();
if( pFrame == NULL ) return ;
#if defined(WIN32) && !defined(UNDER_CE)
pFrame->Create(NULL, _T("PLApp"), UI_WNDSTYLE_FRAME, WS_EX_STATICEDGE | WS_EX_APPWINDOW, , , , );
#else
pFrame->Create(NULL, _T("PLApp"), UI_WNDSTYLE_DIALOG, WS_EX_TOPMOST, , , GetSystemMetrics(SM_CXSCREEN), GetSystemMetrics(SM_CYSCREEN));
#endif
HICON hIcon = ::LoadIcon(hInstance, MAKEINTRESOURCE(IDI_ICON1));
::SendMessage(*pFrame, STM_SETICON, IMAGE_ICON, (LPARAM)(UINT)hIcon); pFrame->CenterWindow();
::ShowWindow(*pFrame, SW_SHOW);
//执行消息循环,此时会堵塞,直到CefQuitMessageLoop()函数被调用。
CefRunMessageLoop();
// 关闭CEF,释放资源
CefShutdown();

  加载浏览器的关键实现,使用g_handler句柄来操作,

 CefRefPtr<SimpleHandler> g_handler(new SimpleHandler());
CefBrowserSettings browser_settings;
CefWindowInfo window_info;
window_info.SetAsChild(m_hWnd, rt);
BOOL bSucced = CefBrowserHost::CreateBrowser(window_info
, g_handler
, _T("http://dict.youdao.com/?keyfrom=cidian")
, browser_settings
, NULL);

  关于以上代码的具体的功能解释我也不多说了,最近工作太累,博客也是刚更新的,希望这个我自己学习的代码对大家有点帮助,开放给大家,对cef3和duilib学习起到参考入门的作用,代码放在这里了,github : https://github.com/karllen/cef3-duilib-YDDemo  。

好了,博客完事,睡觉,明天看勇士和骑士的第四场比赛。

  对了:有道词典的一切资源文件归有道所有,禁止大家使用于商业用途,这个项目,仅供新手学习参考,如有侵权,联系我删除吧。

                                                                               邮箱 :1160113606@qq.com

cef3和duilib简单仿有道词典学习的更多相关文章

  1. 仿有道词典App开发

    最近在学习HCoder提供的仿有道词典App项目,该项目采用MUI为前端框架,服务端采用PHP,底层采用了H5+.

  2. python学习笔记:"爬虫+有道词典"实现一个简单的英译汉程序

    1.有道的翻译 网页:www.youdao.com Fig1 Fig2 Fig3 Fig4 再次点击"自动翻译"->选中'Network'->选中'第一项',如下: F ...

  3. python "爬虫+有道词典"实现一个简单翻译程序

    抓包软件使用的是Fiddler4 新版的查询接口 比较负责,引入了salt和sign http://fanyi.youdao.com/translate?smartresult=dict&sm ...

  4. 基于pygtk的linux有道词典

    基于pygtk的linux有道词典 一.桌面词典设计 想把Linux用作桌面系统,其中一部分障碍就是Linux上没有像有道一样简单易用的词典.其实我们完全可以自己开发一款桌面词典, 而且开发一款桌面词 ...

  5. Mac上的欧路词典单词本迁移到有道词典 #node.js

    摘要 有道词典提供了柯林斯和朗文辞典,加上最近在背单词且Mac版的屏幕取词也够用了,为了云单词本的同步,决定抛弃Mac上的欧路词典.单词欧路上的单词本也存了一百多个单词.怎样迁移到有道呢? 关键词:n ...

  6. bing词典vs有道词典对比测试报告——功能篇之细节与用户体验

    之所以将细节与用户体验放在一起讨论,是因为两者是那么的密不可分.所谓“细节决定成败”,在细节上让用户感受方便.舒适.不费心而且温馨,多一些人文理念,多一些情怀,做出来的产品自然比其他呆板的产品更受欢迎 ...

  7. Bing词典vs有道词典比对测试报告——功能篇之核心功能

    必应词典vs有道词典 核心功能对比 从应用的UI布局来看,这两款软件的功能如下: 相同 不同 必应词典 词典.例句.翻译 百科 有道词典 词典.例句.翻译 应用 就词典类软件来说,词典是最核心的功能. ...

  8. 必应词典手机版(IOS版)与有道词典(IOS版)之软件分析【功能篇】【用户体验篇】

    1.序言: 随着手机功能的不断更新和推广,手机应用市场的竞争变得愈发激烈.这次我们选择必应词典和有道词典的苹果客户端作对比,进一步分析这两款词典的客户端在功能和用户体验方面的利弊.这次测评的主要评测人 ...

  9. 有道词典for mac不能取词解决方案

    在mac上装了有道词典,发现在Chrome上不能取词,网上也没有搜到合适的解决方案,后来发现解决这个问题很简单,打开有道词典,点击设置, 再点击软件更新,就会发现有chrome取词插件,安装就OK了. ...

随机推荐

  1. PHP array_filter() 函数

    定义和用法 array_filter() 函数用回调函数过滤数组中的元素,如果自定义过滤函数返回 true,则被操作的数组的当前值就会被包含在返回的结果数组中, 并将结果组成一个新的数组.如果原数组是 ...

  2. 不同浏览器的margin值与padding值

    IE-7: 有默认外边距margin样式的元素: dd,menu, ol, ul, blockquote, body, dd, dl, form, h1-6, ul 有默认内边距padding样式的元 ...

  3. Oracle解析复杂json的方法

    问题背景: 当前在Oracle数据库(11G之前的版本)解析json没有可以直接使用的系统方法,网上流传的PLSQL脚本大多也只可以解析结构较单一的json串,对于结构复杂的json串还无法解析.如此 ...

  4. Linux 零拷贝技术

    简介 零拷贝(zero-copy)技术可以减少数据拷贝和共享总线操作的次数,消除通信数据在存储器之间不必要的中间拷贝过程,有效地提高通信效率,是设计高速接口通道.实现高速服务器和路由器的关键技术之一. ...

  5. pdf.js实现在HTML下直接浏览pdf文档,无需插件即可实现

    近期,有一个朋友做B端,服务器存了大量的金融类数据,很多都是pdf文档,他现在的做法是,先将pdf文档转换成flash,再放到浏览器上给用户浏览,但是他告诉我,这种体验太差了,而且很好资源,空间已经快 ...

  6. 简单五子棋,没有电脑AI

    刚学了C#委托,做了个五子棋练习,把前台绘制和后台逻辑分开,前台绘制方法用委托传给后台逻辑. 界面好简单... 先看类图 控制类控制整个游戏的逻辑,包括调用棋盘类的属性初始化棋盘.初始化两个棋手.轮流 ...

  7. 关于cisco ccp 或sdm管理gns3中思科路由器的成功分享

    本来工作环境中有一台c1841,闲来无事,升级了最新的IOS=c1841-adventerprisek9-mz.151-4.M6.bin,在xp虚拟机中安装sdm(新windows系统不支持)和在wi ...

  8. Java过滤敏感词语/词汇---DFA算法

    最近网站需要在评论.投稿等地方过滤敏感词汇,于是在网上查找了相关教程,特此整理分享. 关于DFA算法,详细的可以去http://blog.csdn.net/u013378306/article/det ...

  9. 20155212 实验四 《Android程序设计》 实验报告

    20155212 实验四 <Android程序设计> 实验报告 (一)Android Stuidio的安装测试 参考<Java和Android开发学习指南(第二版)(EPUBIT,J ...

  10. Day2-文件操作

    文件操作流程: 1.打开文件,得到文件句柄并赋值给一个变量: 2.通过句柄对文件进行操作: 3.关闭文件 ################################33 1.打开文件方法: a. ...