认识soui4js(第5篇):使用扩展控件
无论内置控件多么丰富,也不可能满足用户所有需求。总有时候用户需要自己扩展控件。
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篇):使用扩展控件的更多相关文章
- 多年前写的文本框扩展控件(有ValueChanging事件等),已放github
本文版权归mephisto和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作. 文章是哥(mephisto)写的,SourceLink 阅读目录 介绍 起因 代码 使用 GitHub ...
- JavaFX的扩展控件库ControlsFX介绍
声明: 本博客文章原创类别的均为个人原创,版权所有.转载请注明出处: http://blog.csdn.net/ml3947,另外本人的个人博客:http://www.wjfxgame.com. ...
- WPF自定义控件(三)の扩展控件
扩展控件,顾名思义就是对已有的控件进行扩展,一般继承于已有的原生控件,不排除继承于自定义的控件,不过这样做意义不大,因为既然都自定义了,为什么不一步到位呢,有些不同的需求也可以通过此来完成,不过类似于 ...
- 2.C#Panel扩展控件
1.解决方案下添加新建项目新建类库 2. 在项目下添加新建项选择新建组件类 3.先引用,然后导入两个命名空间 4.因为是扩展控件,把继承自Component改成继承自Panel using Syste ...
- Cesium应用篇:3控件(4)Geocoder
Geocoder是一个非常简单的控件,但也是非常常用且实用的控件,顾名思义,Geocoder就是地理编码的意思,而平常我们经常会查询一些地物,也就是常用的POI搜索,就是Geocoder的功劳. 首先 ...
- Cesium应用篇:3控件(2)BaseLayerPicker
所有范例均在github中搜索:ExamplesforCesium BaseLayerPicker控件非常简单,似乎没什么可说的,确实非常的简单,但作为一个底图选择控件,可以说是最基本的一个控件. C ...
- Cesium应用篇:3控件(3)SelectionIndicator& InfoBox
假设这样一个场景,用户在Cesium球上加载了一个GeoJson文件(DataSource),里面是全美国所有州的Geometry信息(Entity),叠加到球面后,你自然会有一种冲动,点击某一个州, ...
- Cesium应用篇:3控件(5)CesiumInspector
CesiumInspector控件并不是带来太多功能上的,但对开发人员来说,对于了解Cesium的渲染效果以及性能调优,还是一个很有价值的控件,特别是一些渲染状态下的问题,采用该控件,应该还是会有很多 ...
- iOS开发UI篇—手写控件,frame,center和bounds属性
iOS开发UI基础—手写控件,frame,center和bounds属性 一.手写控件 1.手写控件的步骤 (1)使用相应的控件类创建控件对象 (2)设置该控件的各种属性 (3)添加控件到视图中 (4 ...
- 验证控件插图扩展控件ValidatorCalloutExtender(用于扩展验证控件)和TextBoxWatermarkExtender
<asp:ScriptManager ID="ScriptManager1" runat="server"> </asp:ScriptMan ...
随机推荐
- HTTP请求与响应格式解析
HTTP是Web浏览器与Web服务器之间通信的标准协议,HTTP指明了客户端如何与服务器建立连接,如果从服务器请求数据,服务器如何响应请求,关闭连接.HTTP是使用TCP/IP协议进行传输数据的,也 ...
- 优化简历的开源工具「GitHub 热点速览」
有读者留言问我是不是"跑路"了,上周没发「GitHub 热点速览」是因为在忙于编写<HelloGitHub 月刊>.这不,我带着诚意满满的开源项目又回来啦!首先要分享一 ...
- S2P医药营销智能管理平台特点和优势
S2P医药营销智能管理平台是正也科技打造的一个专为医药行业设计的综合性营销解决方案,旨在通过智能化.数据驱动的方式提升医药企业的营销效率和效果.以下是关于S2P医药营销智能管理平台的一些主要特点和优势 ...
- 使用AES加密时,结果不一样
使用AES加密时,发现得到的结果不一致. python示例 from Crypto.Cipher import AES from Crypto.Util.Padding import pad from ...
- 【CLS数据淘金第四期】网络流日志-云联网日志分析
导语 云联网(Cloud Connect Network,CCN)云联网覆盖全球 20+ 地域,提供云上私有网络间(VPC).VPC 与本地数据中心间(IDC)内网互联的服务,具备全网多点互联.路由自 ...
- Nuget Reference 丢失问题
现象 在 Visual Studio 2017 中创建一个控制台项目.创建出来的项目如下所示. 通过 NuGet 管理器,添加 Newtonsoft.Json 的 NuGet 包,安装之后,项目中添加 ...
- 中电金信通过KCSP认证 云原生能力获权威认可
中电金信通过KCSP(Kubernetes Certified Service Provider)认证,正式成为CNCF(云原生计算基金会)官方认证的 Kubernetes 服务提供商. Ku ...
- Spark面试题汇总及答案(推荐收藏)
一.面试题 Spark 通常来说,Spark与MapReduce相比,Spark运行效率更高.请说明效率更高来源于Spark内置的哪些机制? hadoop和spark使用场景? spark如何保证宕机 ...
- Qt/C++地图雷达扫描/动态扇形区域/标记线实时移动/轮船货轮动态轨迹/雷达模拟/跟随地图缩放
一.前言说明 地图雷达扫描的需求场景也不少,很多人的做法是直接搞个覆盖层widget,在widget上绘制雷达,优缺点很明显,优点是性能高,毕竟直接在widget上绘制性能明显比js中绘制要高,缺点是 ...
- Qt/C++动态启用地图功能/地图拖曳/键盘操作/滚轮缩放/双击放大/连续缩放等
一.前言说明 地图组件为了方便用户的操作,一般会满足各种需求场景,比如用鼠标拖曳地图,实体键盘按键上下左右移动,鼠标滚轮缩放地图大小,双击放大地图,这些常规的操作可以极大的方便用户操作,问题是,有时候 ...