NPAPI插件-传递xulrunner组件(nsCOMptr)的实例
NPAPI plugin - Pass instance of xulrunner component (nsCOMptr)
我在搜索后找不到解决方案,所以我不得不问!请原谅我的语言,因为我是NPAPI业务的新手。
我所拥有的,是一个现有的插件,它以大约100毫秒的周期从一个nsComponent (dataCreator)的本地运行的xulrunner应用程序中接收数据。结果看起来非常好,xul应用程序到目前为止是稳定的。但是,如果我增加数据的出现次数(我必须这样做),xul应用程序需要太长时间才能做出反应,这最终会导致xul崩溃。我认为XUL->插件I/O有点贵!?
到目前为止,我所学到的是,插件能够创建一个组件的新实例:
// inside myPlugin.cpp
nsresult rv;
nsCOMptr< myCompClass > _myComPtr ;
_myComPtr = do_CreateInstance( "@myDomain.org/DIR/MYCOMPONENT;1", &rv ) ;
函数
do_CreateInstance( ) ;
来自 nscomponentmanagerutiss .h,它是xulrunner SDK之外的,但它没有像
do_giveMeTheRunningInstanceOf( "@myDomain.org/DIR/MYDATACREATOR;1", &rv ) ;
我的直觉是使用
nsScriptablePeer::Invoke(NPIdentifier name, const NPVariant *args, uint32_t argCount, NPVariant *result )
方法将正在运行的dataCreator的nsCOMptr传递给插件,使直接通信成为可能,并将xul<-->插件I/O减少到最小。创建另一个dataCreator的实例绝对不是一个选项!
老实说:我不知道如何"转换"NPVariant (args[0])到所需的nsCOMptr,你呢?或者是否有另一种可能性来接收插件内部的指针?
谢谢你的帮助
我不知道如何直接从npapi插件与xulrunner sdk进行交互,因为它们使用完全不同的api。npvariables不能传递xulrunner对象或其他本地指针类型。
这是一个总的头脑风暴,我不知道它是否会工作,但如果你能以某种方式结合xulrunner扩展和npapi插件到同一个模块,你可能会使用全局映射和一个id从插件获得共享内存,但我不知道如果这是可能的或不。
你是正确的,与javascript接口有一个成本;实际上,单个调用的开销最大,因为它们最终是跨进程的。通常,您可以通过使用更有效的调用来最小化这个问题。
- 从C++实例化QML
- 在全局变量中保存类的实例以重新创建类(创建"backup")
- OpenGL - 在抛出"__gnu_cxx::recursive_init_error"实例后终止调用?
- 如何在c++中为模板函数实例创建快捷方式
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 设计一个只能由特定类实例化的类(如果可能的话,通过make_unique)
- 如何创建一个空的全局类并在启动时实例化它
- 无法创建抽象类的实例
- 多个文件的内存分配错误"在抛出 'std :: bad_alloc' what (): std :: bad_alloc 的实例后终止调用" [C++]
- 在两个类中共享相同的函数调用,并在不需要时避免空实例化
- 我收到以下错误:抛出'std::bad_alloc'实例后终止调用
- 建议在运行时将带有类实例的列表从c++导入qml
- 约束和显式模板实例化
- 通过实例理解std::move及其目的
- 为什么包含windows.h会产生语法错误,从而阻止类的实例化?(C2146,C2065)
- 有没有一种"cleaner"的方法可以在指向基的指针向量中找到派生类的第一个实例?
- 正在生成未知类实例
- 从DLL中删除类的实例
- 在std::vector上存储带有模板的类实例
- NPAPI插件-传递xulrunner组件(nsCOMptr)的实例