无论内置控件多么丰富,也不可能满足用户所有需求。总有时候用户需要自己扩展控件。

soui4js推荐使用C++来扩展控件,然后通过实现一个js模块来提供js使用。

扩展控件通常涉及到图形上下文的频繁交互,如果使用js来实现,效率上会大打折扣。使用C++,没了C++和js的相互调用。使用起来就和C++版本没有区别了。

相对于浏览器中全部使用js来操作cavas, soui4js提供的这种方案即有C++的高效又有js的灵活。

如果用户了解soui中如何扩展控件,就会知道使用C++实现好一个控件后,需要将这个新控件注册到soui系统中。

如何开发js扩展模块参见:认识soui4js(第3篇):使用C/C++开发扩展模块

同样的,由于js的扩展模块的init,uninit方法获取不到soui4的IApplication对象,我们需要给这个扩展模块导出两个方法到js,示例代码如下:

using namespace SOUI;
void RegisterCtrls(IApplication* pApp) {
pApp->RegisterObjFactory(&TplSObjectFactory<SProgressRing>());
pApp->RegisterObjFactory(&TplSObjectFactory<SRatingBar>());
pApp->RegisterObjFactory(&TplSObjectFactory<SAniWindow>());
pApp->RegisterObjFactory(&TplSObjectFactory<SChatEdit>());
pApp->RegisterObjFactory(&TplSObjectFactory<SCheckBox2>());
pApp->RegisterObjFactory(&TplSObjectFactory<SGroupList>());
pApp->RegisterObjFactory(&TplSObjectFactory<SHexEdit>());
pApp->RegisterObjFactory(&TplSObjectFactory<SRoundWnd>());
pApp->RegisterObjFactory(&TplSObjectFactory<SScrollText>());
pApp->RegisterObjFactory(&TplSObjectFactory<SPropertyGrid>());
pApp->RegisterObjFactory(&TplSObjectFactory<SScrollSubtitles>());
pApp->RegisterObjFactory(&TplSObjectFactory<SVText>());
pApp->RegisterObjFactory(&TplSObjectFactory<SIECtrl>());
} void UnregisterCtrls(IApplication* pApp) {
pApp->UnregisterObjFactory(&TplSObjectFactory<SProgressRing>());
pApp->UnregisterObjFactory(&TplSObjectFactory<SRatingBar>());
pApp->UnregisterObjFactory(&TplSObjectFactory<SAniWindow>());
pApp->UnregisterObjFactory(&TplSObjectFactory<SChatEdit>());
pApp->UnregisterObjFactory(&TplSObjectFactory<SCheckBox2>());
pApp->UnregisterObjFactory(&TplSObjectFactory<SGroupList>());
pApp->UnregisterObjFactory(&TplSObjectFactory<SHexEdit>());
pApp->UnregisterObjFactory(&TplSObjectFactory<SRoundWnd>());
pApp->UnregisterObjFactory(&TplSObjectFactory<SScrollText>());
pApp->UnregisterObjFactory(&TplSObjectFactory<SPropertyGrid>());
pApp->UnregisterObjFactory(&TplSObjectFactory<SScrollSubtitles>());
pApp->UnregisterObjFactory(&TplSObjectFactory<SVText>());
pApp->UnregisterObjFactory(&TplSObjectFactory<SIECtrl>());
} extern "C"
__declspec(dllexport) JSModuleDef* js_init_module(JSContext* ctx, const char* module_name)
{
qjsbind::Context* context = qjsbind::Context::get(ctx);
qjsbind::Module *module = context->NewModule(module_name);
module->ExportFunc("RegisterCtrls", RegisterCtrls);
module->ExportFunc("UnregisterCtrls", UnregisterCtrls);
Exp_Ctrls(module);
return module->module();
}

上述代码来自xliveplayer的扩展控件模块。

该模块导出了两个方法:

RegisterCtrls,UnregisterCtrls

这样,在导入该模块后,在main函数中调用这两个方法。就可以在xml中使用这些扩展控件了。

import * as extctrl from "extctrl.dll";

//...

var g_WordDir;
function main(inst,workDir,args)
{
soui4.log(workDir);
g_WordDir = workDir;
let theApp = soui4.GetApp();
let souiFac = soui4.CreateSouiFactory();
let trMgr = soui4.CreateTranslatorMgr();
if(trMgr!=0){
theApp.SetTranslator(trMgr);
trMgr.Release();
}
let logMgr = soui4.CreateLogMgr();
if(logMgr != 0){
theApp.SetLogManager(logMgr);
logMgr.setLoggerName("xliveplayer");
logMgr.start();
}
let resProvider = souiFac.CreateResProvider(1);
soui4.InitFileResProvider(resProvider,workDir + "\\uires");
extctrl.RegisterCtrls(theApp);
let resMgr = theApp.GetResProviderMgr();
resMgr.AddResProvider(resProvider,"uidef:xml_init");
resProvider.Release();
let hwnd = soui4.GetActiveWindow();
let hostWnd = new CMainDlg("xml\\dlg_main.xml");
hostWnd.Create(hwnd,0,0,0,0);
hostWnd.SendMessage(0x110,0,0);//send init dialog message.
hostWnd.ShowWindow(1); //1==SW_SHOWNORMAL
souiFac.Release();
let ret= theApp.Run(hostWnd.GetHwnd());
extctrl.UnregisterCtrls(theApp);
soui4.log("js quit");
if(logMgr!=0){
logMgr.stop();
logMgr.Release();
}
return ret;
}

完整代码参见 soui4js-app/xliveplayer: 基于soui4js实现的在线直播视频播放器 (github.com)

认识soui4js(第5篇):使用扩展控件的更多相关文章

  1. 多年前写的文本框扩展控件(有ValueChanging事件等),已放github

    本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 阅读目录 介绍 起因 代码 使用 GitHub ...

  2. JavaFX的扩展控件库ControlsFX介绍

    声明:   本博客文章原创类别的均为个人原创,版权所有.转载请注明出处: http://blog.csdn.net/ml3947,另外本人的个人博客:http://www.wjfxgame.com. ...

  3. WPF自定义控件(三)の扩展控件

    扩展控件,顾名思义就是对已有的控件进行扩展,一般继承于已有的原生控件,不排除继承于自定义的控件,不过这样做意义不大,因为既然都自定义了,为什么不一步到位呢,有些不同的需求也可以通过此来完成,不过类似于 ...

  4. 2.C#Panel扩展控件

    1.解决方案下添加新建项目新建类库 2. 在项目下添加新建项选择新建组件类 3.先引用,然后导入两个命名空间 4.因为是扩展控件,把继承自Component改成继承自Panel using Syste ...

  5. Cesium应用篇:3控件(4)Geocoder

    Geocoder是一个非常简单的控件,但也是非常常用且实用的控件,顾名思义,Geocoder就是地理编码的意思,而平常我们经常会查询一些地物,也就是常用的POI搜索,就是Geocoder的功劳. 首先 ...

  6. Cesium应用篇:3控件(2)BaseLayerPicker

    所有范例均在github中搜索:ExamplesforCesium BaseLayerPicker控件非常简单,似乎没什么可说的,确实非常的简单,但作为一个底图选择控件,可以说是最基本的一个控件. C ...

  7. Cesium应用篇:3控件(3)SelectionIndicator& InfoBox

    假设这样一个场景,用户在Cesium球上加载了一个GeoJson文件(DataSource),里面是全美国所有州的Geometry信息(Entity),叠加到球面后,你自然会有一种冲动,点击某一个州, ...

  8. Cesium应用篇:3控件(5)CesiumInspector

    CesiumInspector控件并不是带来太多功能上的,但对开发人员来说,对于了解Cesium的渲染效果以及性能调优,还是一个很有价值的控件,特别是一些渲染状态下的问题,采用该控件,应该还是会有很多 ...

  9. iOS开发UI篇—手写控件,frame,center和bounds属性

    iOS开发UI基础—手写控件,frame,center和bounds属性 一.手写控件 1.手写控件的步骤 (1)使用相应的控件类创建控件对象 (2)设置该控件的各种属性 (3)添加控件到视图中 (4 ...

  10. 验证控件插图扩展控件ValidatorCalloutExtender(用于扩展验证控件)和TextBoxWatermarkExtender

    <asp:ScriptManager ID="ScriptManager1" runat="server">  </asp:ScriptMan ...

随机推荐

  1. 点击Popover外区域自动关闭Popover (popover close when click outside)

    $(document).on('click', function (e) { $('[data-toggle="popover"],[data-original-title]'). ...

  2. 迁移到 Eclipse: Eclipse 对 IntelliJ IDEAA 评估开发指南

    为何考虑 Eclipse 以及它与 IntelliJ IDEA 有什么不同 Eclipse 是一个免费的.正日益流行起来的 Java 集成开发环境,最新版本的 Eclipse 中提供了很多特性,这些特 ...

  3. Python 爬虫必备杀器,xpath 解析 HTML

    最近工作上写了个爬虫,要爬取国家标准网上的一些信息,这自然离不了 Python,而在解析 HTML 方面,xpath 则可当仁不让的成为兵器谱第一. 你可能之前听说或用过其它的解析方式,像 Beaut ...

  4. HUAWEI SECURITY 2023 山东大学专场 WP

    Crypto by Smera1d0 1.ezrsa 题干如下: from Crypto.Util.number import getPrime from secret import flag p = ...

  5. shp转featureclass

    public void ConvertShapefileToFeatureClass() { // Create a name object for the source (shapefile) wo ...

  6. webpack-dev-server配置https

    前情 最近在做一个浏览器通知的交互需求,但是查阅官方文挡,浏览器通知需要在https环境下才能工作,于是就研究怎么在开发环境下配置一个https服务器 STEP1 安装Chocolatey Choco ...

  7. powershell禁止系统运行脚本

    错误信息: set-executionpolicy remotesigned set-executionpolicy : Windows PowerShell 已成功更新你的执行策略,但在更具体的作业 ...

  8. 【MyBatis】学习笔记05:获取参数值的两种方式

    [Mybatis]学习笔记01:连接数据库,实现增删改 [Mybatis]学习笔记02:实现简单的查 [MyBatis]学习笔记03:配置文件进一步解读(非常重要) [MyBatis]学习笔记04:配 ...

  9. 4.4 服务器上的 Git - 配置服务器

    配置服务器 我们来看看如何配置服务器端的 SSH 访问. 本例中,我们将使用 authorized_keys 方法来对用户进行认证. 同时我们假设你使用的操作系统是标准的 Linux 发行版,比如 U ...

  10. bouncycastle(BC) 实现SM2国密加解密、签名、验签

    https://www.cnblogs.com/dashou/p/14656458.html SM2国密加解密一个类就够了 <dependency> <groupId>org. ...