`
silenceisall
  • 浏览: 31438 次
  • 性别: Icon_minigender_1
  • 来自: 湖北
社区版块
存档分类
最新评论

Alchemy文档:开发Alchemy 、C API(as3与C交互转换)

阅读更多

1 Alchemy C/C++ API

1.1 Managing ActionScript objects:管理ActionScript对象

1.1.1 AS3_Val:AS3值对象

1.1.2 void AS3_Acquire(AS3_Val obj):增加obj的引用计数

1.1.3 void AS3_Release(AS3_Val obj):减小obj的引用计数

1.1.4 AS3_Val AS3_New(AS3_Val constr, AS3_Val params):

把constr构造函数(用AS3_NSGet获取)应用到非null(可以是空的)的Array型变量params上。

1.1.5 AS3_Malloced_Str AS3_TypeOf(AS3_Val obj):

获取obj的类型的malloc字符串(返回值需要free)

1.1.6 int AS3_InstanceOf(AS3_Val val, AS3_Val type):

判断val是否属于type(用NSGet获取)类型,如果是返回非0,否返回0。

1.1.7 AS3_Val AS3_NSGet(AS3_Val ns, AS3_Val prop):

运行时通过ns(AS3_String,例如"flash.utils")

和prop(AS3_String,例如"ByteArray")查找类。

1.1.8 AS3_Val AS3_NSGetS(AS3_Val ns, const char *prop):

同AS3_NSGet,只不过prop是C风格常数值,不需要AS3_Release。

1.2 Converting C/C++ Values to ActionScript objects

C/C++到AS的值转换。

1.2.1 AS3_Val AS3_String(const char* str):

const char[](C风格)转String,需要AS3_Release释放。

1.2.2 AS3_Val AS3_StringN(const char* str, int len):

void *转String,需要AS3_Release释放。

1.2.3 AS3_Val AS3_Int(int):

int转AS3的int,需要AS3_Release释放。

1.2.4 AS3_Val AS3_Ptr(void* ptr):

void *转ByteArray(用uint读写),需要AS3_Release释放。

1.2.5 AS3_Val AS3_Number(double d):

double转Number,需要AS3_Release释放。

1.2.6 AS3_Val AS3_True():

获取true,需要AS3_Release释放。

1.2.7 AS3_Val AS3_False():

获取false,需要AS3_Release释放。

1.2.8 AS3_Val AS3_Null():

获取null,无需释放。

1.2.9 AS3_Val AS3_Undefined()

获取undefined,无需释放。

1.2.10 AS3_Val AS3_Array(const char *tt, ...):

printf风格的Array构造式,例如:

AS3_Val point = AS3_Array("IntType, IntType", x, y);

支持"IntType"(int),"PtrType"(void*),

"DoubleType"(double),"StrType"(char *),

"AS3ValType"(AS3_Val)。

需要AS3_Release释放。

1.2.11 AS3_Val AS3_Object(const char *tt, ...)

同上,但是构造Object对象,需要AS3_Release释放。

1.3 Converting ActionScript objects to C/C++ Values

AS3到C/C++的值转换

1.3.1 AS3_Malloced_Str AS3_StringValue(AS3_Val obj)

String转char[](malloc,需要free)

1.3.2 int AS3_IntValue(AS3_Val obj)

AS3的int转int。

1.3.3 void* AS3_PtrValue(AS3_Val obj)

Object转void *。

1.3.4 double AS3_NumberValue(AS3_Val obj)

Number转double。

1.3.5 void AS3_ArrayValue(AS3_Val arr, const char *tt, ...)

scanf风格的Array分解。例如:

int arg0 = 0;

char* arg1 = NULL;

double arg2 = 0.0;

AS3_ArrayValue(arr, "IntType, StrType, DoubleType", &arg0, &arg1, &arg2)

1.3.6 void AS3_ObjectValue(AS3_Val arr, const char *tt, ...)

同上,但是对Object的分解

1.4 Calling ActionScript methods from C/C++

从C/C++中调用AS3方法

1.4.1 AS3_Val AS3_Get(AS3_Val obj, AS3_Val prop)

对obj执行prop(例如AS3_String("length"))的属性读取,

1.4.2 AS3_Val AS3_GetS(AS3_Val obj, const char *prop)

同AS3_Get,不过prop是C风格常数字符串,不需要AS3_Release。

1.4.3 AS3_Val AS3_Set(AS3_Val obj, AS3_Val prop, AS3_Val val)

对obj的prop执行属性设置,值为val。

1.4.4 AS3_Val AS3_SetS(AS3_Val obj, const char *prop, AS3_Val val)

同AS3_Set,不过prop是C风格常数字符串,不需要AS3_Release。

1.4.5 AS3_Val AS3_Call(AS3_Val func, AS3_Val thiz, AS3_Val params)

对thiz(如果是AS3_Undefined()则为顶级调用)

执行func(可以是NSGet/NSGetS的名字空间(常规函数)或Get/GetS的对象(闭包))

函数调用,传入Array型的params(例如AS3_Array("IntType", strlen(buf)))作为参数。

1.4.6 AS3_Val AS3_CallS(const char *func, AS3_Val thiz, AS3_Val params)

同AS3_Call,不过func是C风格常数字符串,不需要AS3_Release。

1.4.7 AS3_Val AS3_CallT(AS3_Val func, AS3_Val thiz, const char *tt, ...)

同AS3_Call,不过params换成变长参数tt。

1.4.8 AS3_Val AS3_CallTS(const char *func, AS3_Val thiz, const char *tt, ...)

同AS3_CallS,不过params换成变长参数tt。

1.4.9 void *AS3_Shim(AS3_Val func, AS3_Val thiz, const char *rt, const char *tt, int varargs)

获取永久的函数指针,但实际上没有调用它(就像AS3的闭包)。例如:

int (*myfunc)(const char *s, double n) =?

AS3_Shim(someFunc, someThiz, "IntType, StrType, NumberType", false);

1.4.10 AS3_Val AS3_Proxy()

创建AS3的Proxy对象,以代理flash_delegate名字空间下的函数

例如flash_delegate::callProperty而非public::callProperty

(注:这里怀疑是用来针对Proxy派生类对象的属性和方法访问,

因为用flash_delegate限定而非public限定,所以需要单独处理)

1.5 Calling C/C++ methods from ActionScript methods

从AS3中调用C/C++方法

1.5.1 AS3_ThunkProc

用typedef定义回调函数的一般形式。

typedef AS3_Val (*AS3_ThunkProc)(void *data, AS3_Val params);

1.5.2 AS3_Val AS3_Function(void *data, AS3_ThunkProc proc)

注册同步回调函数proc,data是用户数据,作为第一参数传给proc的第一参数。

1.5.3 AS3_Val AS3_FunctionAsync(void *data, AS3_ThunkProc proc)

注册异步回调函数proc,data是用户数据,作为第一参数传给proc的第一参数。

1.5.4 AS3_Val AS3_FunctionT(void *data, void *proc, const char *rt, const char *tt, int varargs):

同AS3_Function,不过proc的参数表是不规则的(不同于AS3_ThunkProc)

1.5.5 AS3_Val AS3_FunctionAsyncT(void *data, void *proc, const char *rt, const char *tt, int varargs):

同AS3_FunctionAsync,不过proc的参数表是不规则的(不同于AS3_ThunkProc)

1.6 Miscellaneous

杂项

1.6.1 void AS3_LibInit(AS3_Val libData)

初始化用户定义的libData库对象,永不返回的函数。

1.6.2 AS3_Val AS3_Stage()

获取运行时舞台对象(例如ConSprite),然后操作它。

1.6.3 AS3_Val AS3_Ram()

获取存放C程序中使用的所有RAM的ByteArray变量。

 

1.6.4 void flyield()

放弃当前时间分片,在下次时间分片时返回以继续下面的语句。

1.6.5 void sztrace(char* msg)

用FlexBuilder的话相当于trace(),用swfbridge的话则相当于STDOUT输出。

1.6.6 void AS3_Trace(AS3_Val val)

同sztrace,不过参数是需要AS3_Release的String值

1.6.7 int AS3_ByteArray_readBytes(void *dst, AS3_Val src, int len)

从ByteArray型的src中读取len长度的字节到dst中

1.6.8 int AS3_ByteArray_writeBytes(AS3_Val dst, void *src, int len)

把len字节长度的src写入ByteArray型的dst中。

1.6.9 int AS3_ByteArray_seek(AS3_Val dst, int offs, int whence)

调整ByteArray型dst的游标位置,类似lseek的用法。

-----------------------------

Alchemy:Documentation:Developing with Alchemy:AS3 API

1 Manipulating the Alchemy state machine

操作Alchemy状态机

1.1 CLibInit

CLibInit用于暴露C代码给AS3使用。

init():*:?

初始化,返回导出C函数(一般名称和C函数是相同的)的对象。

setSprite(sprite:Sprite):void:?

设置一个Sprite对象给Alchemy,Alchemy会创建一个TextField然后把STDOUT, STDERR输出内容输出到这个文本域上。

也用于STDIN。

putEnv(key:String, value:String:?

设置环境变量,供C代码的getenv()读取

supplyFile(path:String, data:ByteArray):?

提供文件系统。以避免运行时由于安全限制而无法访问的情况。

gstate:

全局变量,保存Alchemy的状态机。

1.2 GLEByteArrayProvider

这个类允许直接访问C库的RAM(如同操作ByteArray型变量)

get:?

返回当前的领域内存,不存在的话开辟数字低位在前(little endian)的新RAM。

1.3 MemUser

直接操作C库的RAM,以addr偏移的形式访问(如同C代码一样)。

读取RAM:

_mr32(addr:int):int: 32位整型

_mru16(addr:int):int: 16位无符号整型

_mrs16(addr:int):int: 16位有符号整型

_mru8(addr:int):int: 8位无符号整型

_mrs8(addr:int):int: 16位有符号整型

_mrf(addr:int):Number: 浮点型

_mrd(addr:int):Number: 双精度

写入RAM:

_mw32(addr:int, val:int):void: 32位整型

_mw16(addr:int, val:int):void: 16位整型

_mw8(addr:int, val:int):void: 8位整型

_mwf(addr:int, val:Number):void: 浮点型

_mwd(addr:int, val:Number):void: 双精型

2 Calling Functions Exported from C

在AS3中调用C导出函数

在flash工程加入swc库

导入名字空间

import cmodule.<your_lib_name>;

创建CLibInit实例

调用init()

例如:

import cmodule.example.CLibInit;

const libInitializer:CLibInit = new CLibInit();

const lib:Object = libInitializer.init();

lib.myExportedFunc("param1", 1234);

文档中没提到的其它非用户导出函数最好不要调用。

0
1
分享到:
评论
发表评论

文章已被作者锁定,不允许评论。

相关推荐

    Laravel开发-alchemy-api

    1. **安装依赖**:首先,你需要通过Composer安装一个Laravel包装库,如`kriswallsmith/alchemy-api`,这是一个PHP客户端库,简化了与Alchemy API的交互。在终端中运行以下命令: ``` composer require ...

    flash alchemy api 翻译

    #### 部分内容:Alchemy C/C++ API ##### 1.1 Managing ActionScript objects: 管理ActionScript对象 这一部分详细介绍了如何在C/C++环境中管理ActionScript对象。主要包括对象的引用计数、类型查询、实例判断以及...

    Alchemy教程教你将c转成swc由flash as3调用

    这里的 `CLibInit` 类是 AS3 中与 C 代码交互的接口,`echo` 方法就是 C 代码中实现的功能。 通过这种方式,我们能够利用 C/C++ 的高效计算能力,同时保持 Flash AS3 的灵活性和交互性。这对于需要高性能计算的 AIR...

    Alchemy3D——Flash3D引擎

    ActionScript是Flash的编程语言,它提供了丰富的API,用于处理3D对象、动画、用户输入和与其他Flash组件的交互。这使得开发者能够实现高度定制的3D体验,比如游戏、虚拟现实环境或数据可视化工具。 Alchemy3D还支持...

    Alchemy简单入门教程

    Alchemy 是 Adobe 开发的一款工具,可以将 C/C++ 的代码转换为 AS3 可以调用的格式,从而提高 AS3 的效率。Alchemy 可以将复杂的计算量大的代码转换为高效的 AS3 代码,解决了 AS3 在计算方面的不足。 Alchemy 的...

    Flash页游未来新技术:Adobe Alchemy

    - **调试支持**:Alchemy 提供基于 GDB 的调试工具,支持设置断点、单步调试、数据注入和修改等功能,还支持远程调试和与 CDTC/++ 开发环境的兼容性。 #### Alchemy Memory Opcodes Alchemy 引入了一种新的内存...

    shineMP3_alchemy

    编辑-》首选参数-》actionscript-》actionscript 3.0设置-》库路径-》浏览到swc文件,然后选择那个shineMP3_alchemy.swc 另外,在“发布设置”的flash选项里,也要勾选“发布swc” 不需要通过后台或者fms,直接在...

    c++与flash交互例程,包含as源码

    在IT领域,C++与Flash的交互是一种常见的技术实践,特别是在开发富互联网应用程序(Rich Internet Applications,RIAs)时。本教程重点讲解如何利用C++和Flash ActionScript(AS)进行交互,帮助开发者实现跨平台的...

    Alchemy OS:手机开发发行平台-开源

    Alchemy OS 是一个针对Java支持的手机的特殊软件开发和应用发行平台。它并不是一个完整的操作系统,而是一个增强的环境,让开发者能够在手机设备上直接进行应用程序的开发、编译和执行,极大地简化了移动应用的生命...

    es-alchemy:Elasticsearch交互的简化

    简化Elasticsearch交互 安装 npm i --save es-alchemy 设置 概述如何使用 : 定义数据模型 根据数据模型定义索引 为索引生成(版本化)模式,在Elasticsearch中创建它们,并对它们进行别名以进行查询 获取索引的源...

    alchemy:只是另一个机器学习API

    Alchemy可能内置了与环境交互的接口,支持Q-learning、Deep Q-Networks (DQN) 或者Proximal Policy Optimization (PPO)等算法,这些算法在游戏AI、机器人控制等领域有广泛应用。 至于Jupyter Notebook的提及,表明...

    alchemy-annotations-1.4.zip

    《炼金术注解库:alchemy-annotations-1.4深度解析》 Alchemy-annotations,作为炼金术(Alchemy)框架的一部分,是一个开源项目,它提供了丰富的编程注解,旨在帮助开发者更高效、更优雅地编写Java代码。在这个...

    马尔科夫逻辑网系统alchemy

    3. **学习算法**:Alchemy包含了多种参数学习算法,如在线学习、批量学习和基于采样的方法。这些算法允许用户根据数据调整公式权重,以优化模型的性能。 4. **推理服务**:工具包提供推理引擎,可以进行精确推理或...

    行业文档-设计装置-C和C++代码在支持FLASH的WEB平台上运行的方法.zip

    综上所述,这个文档可能详细介绍了如何使用过时的Alchemy技术或者现代的WebAssembly技术将C和C++代码部署到支持Flash的Web平台上,以及如何处理与JavaScript的交互、性能优化和安全性问题。对于那些希望在Web环境中...

    3alchemy:在 TriCity (3city) Ruby 用户组 (http

    3炼金术(FreeAlchemy) 录制在进行的自由式即兴交互式现场暴民编程 Elixir 会议。 3Alchemy代表自由/自由式炼金术。 Alchemy代表使用进行编程。 目标: 学习, 教学, 自由创意。会话日志第 0 节 (2015-04-15) 持续...

    马尔可夫逻辑网络工具包alchemy

    2. **学习算法**:Alchemy包含了多种权重学习算法,如Maximum-Marginal Likelihood(MML)、Annealed Importance Sampling(AIS)等,这些算法用于从数据中学习逻辑规则的权重,以最大化模型与观测数据的拟合度。...

    alchemy database

    #### 三、解决方案:Alchemy Alchemy数据库是一种开源的混合型关系数据库管理系统(RDBMS)/非关系型数据库管理系统(NoSQL),它支持基于Redis的SQL查询,这使得开发者可以在不牺牲性能的情况下使用SQL来查询非...

    炼金术:基于DAO堆栈的协作网络(DAO)应用程序

    或 ://alchemy.daostack.io-主网和xdai上的alchemy v1 ://rinkeby.v1.alchemy.do-rinkeby上的alchemy v1 ://kovan.v1.alchemy.do-kovan上的alchemy v1 炼金术2.0 :fire: 可以在找到Alchemy 2.0源代码。 ://...

    [转]quicklz的flash移植版本

    3. **编译和链接**:使用Alchemy或类似工具将C代码编译为AS3可以调用的库,Alchemy是一个开源工具,可以将C和C++代码转换为AS3代码。 4. **测试与优化**:移植后,需要在AS3环境中进行详尽的测试,确保所有功能正常...

Global site tag (gtag.js) - Google Analytics