运行本地代码的AIR

一、简介

 

    一提到AIR,大家可能都会联想到那些丰富多彩、绚丽的界面,令人激动的互联网桌面应用能力。但是AIR贫乏的本地代码(Native Code)调用能力,使得它把大多数本地应用都拒之门外。

 

    FluorineFx Aperture framework作为Fluorine的子项目,为我们提供了一个对本地OS支持的框架(windows only)。它以非侵入性的方式为AIR应用提供了对本地代码的扩展能力。在运行时期间,框架也会自动与您的AIR应用挂钩,而不需要额外安装和配置任何东西。

 

    Aperture framework提供了一个AIR应用软件和自动化对象交互的桥梁。同时框架使用后期绑定访问自动化对象。

 

二、Hello World

 

    1、建立本地代码:

 

         1) 首先,我们新建一个ATL应用——airexec

 

         2) 然后,选择创建DLL项目,并完成向导

 

 

 

   3) 配置项目

 

        a )  使用静态链接

        

        b) 运行时库配置:DEBUG —— /MTd     RELEASE —— /MT

 

 

        c)  由于AIR需要向导安装,同时不需要人工干预,故本地DLL也不要进行注册表登记:

 

    4)  构建我们自己的本地实现类——MyClass

 

 

 

    5)修改IDispatchImpl的参数wMajor 和 wMinor,改为 0xFFFF:

 

        指定的值0xFFFFF告诉IDispatchImpl直接从您的模块的资源和类型库加载类型库,而这些类型库根本不需要被注册。

 

    6) 好了,现在可以添加我们的自定义方法了,在IMyClass接口上添加方法Test:

 

    7) 实现代码:

 

STDMETHODIMP CMyClass::Test(BSTR Something, BSTR* Result)
{
	_bstr_t b = Something;
	char* ch = b;
	char ch2[256] = "已显示";
	::MessageBoxA(NULL,ch,"",0);  // 直接在Window下执行	
	strcat(ch2,ch);
	*Result =  _bstr_t(ch2); // 返回给Flex
	return S_OK;
}

 

    8) 编译程序

 

    9)  打开本类型对应的.rgs文件,记下CLSID的值:

 

    2、实现我们的AIR应用:

 

    制作AIR的过程很简单,具体的步骤如下:

   

    a) 导入相关DLL和AS文件,ATL项目生成的airexec.dll也同样导入:

                   

 

     b) 引入Aperture控件,并实现对本地DLL的CLSID的访问:

 

           注意source属性,格式为——ATL项目名:CLASID

<?xml version="1.0" encoding="utf-8"?>
<mx:WindowedApplication xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" 
	xmlns:aperture="com.fluorinefx.aperture.*" creationComplete="init()">
	<mx:Script>
		<![CDATA[
			import mx.controls.Alert;
			import mx.rpc.events.ResultEvent;
			import mx.rpc.events.FaultEvent;
			
			private function init() : void {
				lc.Test("Hello World");  // 访问Test方法
			}
			
			private function onTest(event : ResultEvent) : void {
				Alert.show(event.result.toString()); // 打印返回值
			}
		]]>
	</mx:Script>
	<aperture:LocalObject id="lc" showBusyCursor="true" source="airexec:3657D1C6-0D94-4CC3-8976-37E813C49B63">
		<aperture:methods>
			<aperture:method name="Test" result="onTest(event)"/>
		</aperture:methods> 
	</aperture:LocalObject>	
</mx:WindowedApplication>

 

    c) 测试这个AIR:

 

         先将Console.exe拷贝到big-debug目录下,并运行这个EXE:

 

      用FLEX BUILDER运行这个AIR,运行结果如下:

 

   

 

  此时的Hello World为C++的MessageBoxA所产生,也就是说已经调用本地代码了。点击确定后,结果如下:

 

    此时的结果为C++返回给FLEX的结果,也就是返回的BSTR*指针的内容。

 

 

三、部署,最终验收

 

    测试期间,我们用额外的Console.exe进行测试,而部署就不再需要了。我们只是把相关的dll参与部署:

 

   

 

    直接生成AIR文件,然后再最终客户机器直接安装,并测试,结果与测试结果相同。

 

    除了客户点击TestExec.air进行安装外,我们并没有额外干预客户机,也没有进行任何其他的操作。

 

    这说明这个AIR跟正常的AIR没有区别,却可以直接调用本地DLL或EXE代码。

 

 

四、内建的基本操作

 

    除了自定义本地代码外,Aperture framework也把常用的本地调用封装成了DLL,目前Documented的部分有3个DLL中的5个方法(参见官方文档aperture.chm),当然UnDocumented的方法就需要开发人员自己去发掘了。

 

  

 

 

你可能感兴趣的:(框架,互联网,Flex,软件测试,AIR)