Duilib使用wke显示echarts

  不得不说wke是个简洁好用的浏览器内核。网上很多大神已经把wke嵌入到duilib中了,先感谢他们辛勤的工作。这里通过wke吧C++的数据在ECharts上美观的显示出来。借鉴前人,将ECharts进行了二次封装,接口在C++中容易使用了。如果觉得那里不够好大家可以修改。水平有限,希望大家多多指正。先上图看看效果:

封装好的接口都在interface.js这个文件里面了,我们来看看interface.js中的接口。

绘制饼图:

function DrawPie(data, containerId, name, theme) {}

组折线图形:

function DrawLines(data, containerId, name, is_stack, theme) {}

组柱状图形:

function DrawBars(data, containerId, name, is_stack, theme) {}

单一形图:

//type 类型 'line'或者'bar'
function DrawSingleChart(data, containerId, name, order, type, theme) {}

C++中使用这些接口很简单,只要调用CWkeWebkitUI的ExecuteJS(LPCTSTR lpJS)函数就好了。

我们显示个简单的折线图只要这样就好,

 1     CDuiString jsData = _T("var data = [\
 2                         { name: '2014-01', value: 20, group: '品牌A' },\
 3                         { name: '2014-01', value: 40, group: '品牌B' },\
 4                         { name: '2014-02', value: 30, group: '品牌A' },\
 5                         { name: '2014-02', value: 10, group: '品牌B' },\
 6                         { name: '2014-03', value: 200, group: '品牌A' },\
 7                         { name: '2014-03', value: 60, group: '品牌B' },\
 8                         { name: '2014-04', value: 50, group: '品牌A' },\
 9                         { name: '2014-04', value: 45, group: '品牌B' },\
10                         { name: '2014-05', value: 110, group: '品牌A' },\
11                         { name: '2014-05', value: 80, group: '品牌B' },\
12                         { name: '2014-06', value: 90, group: '品牌A' },\
13                         { name: '2014-06', value: 60, group: '品牌B' }];");
14 
15     m_pWkeWebkit->ExecuteJS(jsData);
16 
17     CDuiString jsStr = _T("DrawSingleChart(data, 'main', {xName:'日期', yName:'销量'}, '', 'line');");
18 
19     m_pWkeWebkit->ExecuteJS(jsData);

使用比较简单,代码写很清楚了,大家看代码就好。想了解更多echarts的使用可以网上查查。

转载请注明出处:http://www.cnblogs.com/fyluyg/p/6150545.html

下载

 

转载于:https://www.cnblogs.com/fyluyg/p/6150545.html

duilib 是一个开源的界面库,它提供了丰富的界面控件和布局管理功能,非常适合用于开发Windows桌面软件。而MFC(Microsoft Foundation Class)是微软开发的用于Windows平台的C++类库,提供了大量的封装好的功能和控件,方便开发人员进行Windows应用程序的开发。 在duilib使用MFC的PictureControl控件,需要先在项目中引入MFC库,并创建一个MFC应用程序。然后,在duilib的界面布局文件中使用窗口控件,并设置控件类型为"Pic",通过name属性给控件命名。 接下来,在MFC应用程序中,创建一个继承自duilib::CPaintManagerUI的类,重写其中的虚函数Notify,用于监听控件的消息事件。在Notify函数中,通过duilib的API获取到PictureControl控件的指针,并调用MFC的相关函数,实现图片的加载和显示。 具体代码如下所示: 在duilib界面布局文件(XML)中添加如下代码: ```xml <Control name="picControl" type="Pic" pos="10, 10, 100, 100" /> ``` 在MFC应用程序的窗口类中添加如下代码: ```cpp class CMainWnd : public CDialogEx { public: CMainWnd(CWnd* pParent = nullptr) : CDialogEx(IDD_MAIN_DIALOG, pParent) { } protected: virtual void DoDataExchange(CDataExchange* pDX) override { CDialogEx::DoDataExchange(pDX); } afx_msg void OnPaint() { CPaintDC dc(this); // 获取duilib的PictureControl控件指针 duilib::CPictureUI* pPicControl = (duilib::CPictureUI*)GetDlgItem(IDC_DUI_PIC); if (pPicControl == nullptr) return; // 获取MFC的CDC对象 CDC* pDC = CDC::FromHandle(dc.GetSafeHdc()); // 加载图片 CImage image; image.Load(_T("path_to_your_image")); // 绘制图片 image.Draw(pDC->GetSafeHdc(), pPicControl->GetPos().left, pPicControl->GetPos().top, pPicControl->GetPos().Width(), pPicControl->GetPos().Height()); } DECLARE_MESSAGE_MAP() }; BEGIN_MESSAGE_MAP(CMainWnd, CDialogEx) ON_WM_PAINT() END_MESSAGE_MAP() ``` 以上就是在duilib使用MFC的PictureControl控件的步骤,通过上述代码,可以实现在duilib界面中显示MFC加载的图片。当然,在实际的项目中,可能还需要添加图片缩放、鼠标事件等处理逻辑,具体根据实际需求进行扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值