当前位置: 移动技术网 > IT编程>开发语言>.net > 用ASP+Flash实现电子地图的在线标注功能

用ASP+Flash实现电子地图的在线标注功能

2018年10月07日  | 移动技术网IT编程  | 我要评论

123065铁路上网导航,日批过程图,咏乐汇孙俪

    电子互动地图的信息量巨大,通过客户端的操作者共同完成海量的标注工作,必须实现在线标注的功能。而这样的功能单独依靠flash本身是无法实现的。在这里我们就使用asp+flash来实现在线标注的功能。

  1、基本的通信过程


图1 swf+xml(标准化越来越近了)与服务器的通信过程示意图
点击看大图

   图1展示的是本例中的通信过程示意。在 flash 和之间传递信息的服务器端脚本以 xml(标准化越来越近了) 格式读写数据。
  可用 actionscript 将 swf 文件中收集到的信息转换成一个 xml(标准化越来越近了) 对象,然后将数据作为 xml(标准化越来越近了) 文档发送到服务器端脚本。您还可以使用actionscript 将服务器返回的 xml(标准化越来越近了) 文档加载到 xml(标准化越来越近了) 对象中,以在 swf 文件中使用该文档。其中在本例中,保存相关的xml(标准化越来越近了)数据是由服务器的脚本程序来完成的,这也是本例的重点学习内容。

  2、flash与asp间的通信方法

  flash与asp通信之间可以使用多种通信方法,本例中使用了loadvars对象。
  loadvars可以通过使用post方法提供了一种向服务器输送变量。

  3、服务器脚本

   服务器脚本可以由多种程序编写,本例中以asp为例编写相关的脚本。
  microsoft active server pages (asp) 是服务器端脚本编写环境,使用它可以创建和运行动态、交互的 web服务器应用程序。
  编写脚本程序要使用相关的脚本语言;脚本语言是介于 html 和 java、c++ 和 visual basic 之类的语言 之间的语言。html 通常用于格式化文本和链接网页。编程语言通常用于向计算机发送一系列复杂指令。脚本语言也可用来向计算机发送指令,但它们的语法和规则没有可编译的编程语言那样严格和复杂。脚本语言主要用于格式化文本和使用以编程语言编写的已编译好的。

   asp使 web 开发商用多种脚本语言编写完整的过程成为可能。事实上,在单个 . 文件内部就可以使用多种脚本语言。

   我们可以使用任意一种其相应的脚本引擎已安装在 web 服务器上的脚本语言。通常使用vbscript和javascript这两种语言;其中,asp默认的脚本语言为vbscript。本例就用vbscript编写脚本。

  下面我们看看具体的实例制作。
  实例制作:

  1、flash端


  首先创建如下界面,捕捉标注点的代码在上一讲中已经提到,本例只是除了地名名称之外,再增加一些基本的信息,方法雷同,这里就不再重复;最终将需要保存的代码赋给字符串变量senddata_srt。


图2 swf文件界面1
点击看大图

图3 swf文件界面2

   以一个名为link的变量来接受来自服务器的消息。如果其值为1,表明与服务器端的通信连接成功。使用
loadvars,再使用sendandload方法将一个loadvars的实体下的数据发送出去。

   打开时间轴的动作面板,输入以下actionscript代码:

function senddata():void { //定义发送数据的函数

var senddata = new loadvars(); //构造一个新的loadvars对象

senddata.check = 1; //设定check的动作,用于服务器验证

senddata.data = senddata_srt; //将待发送的数据变量senddata_srt赋给data

output_txt.text = "请稍候……"; //状态文本显示为"请稍候……"

senddata.onload = function(success) { //验证和服务器连接的函数

if (success) { //如果和服务器成功连接

if (this.link== "1") { //如果验证动作成功

output_txt.text = "成功标注!审核后即可生效。"; //状态文本显示为成功

}

}

else {

output_txt.text = "服务器忙,请稍后再试!";

//如果和服务器连接不成功则返回失败消

}

};

senddata.sendandload("http://www.cncms.com.cn/xml(标准化越来越近了)data/save.asp", senddata, "post");

//以post方式发送待保存数据

}

  2、编写服务器脚本(asp)

   创建一个asp文件,其内容如下:

<%@language="vbscript"%>

<%

dim check ’定义check变量,用来验证来自swf文件的数据

dim link ’定义link变量,用来返回给swf文件,表明通信成功

dim data ’定义data变量,用来接收来自swf文件的待保存数据

set data = request.form("data") ’接收来自swf文件的待保存数据

set check = request.form("check") ’验证来自swf文件的数据

if check = 1 then ’如果swf文件身份正确

link = 1 ’将link值设为1,表明通信成功

end if ’结束if语句

set xml(标准化越来越近了)=server.createobject("microsoft.xml(标准化越来越近了)dom")
’创建一个对象用以操作xml(标准化越来越近了)文件

xml(标准化越来越近了).async=false

xml(标准化越来越近了).validateonparse=false

xml(标准化越来越近了).load(server.mappath("http://www.cncms.com.cn/xml(标准化越来越近了)data/data.xml(标准化越来越近了)"))
’加载xml(标准化越来越近了)文件

set newnode=mxml(标准化越来越近了).createnode ("element", "data", "")
’创建新节点newnode,并命为为data

root.appendchild(newnode)
’在上面得到的加载进来的xml(标准化越来越近了)文件的根节点后追加一个新建的节点newnode,

set objname = mxml(标准化越来越近了).createattribute("data")
’为新建的节点创建属性项objname.text = data ’为新建属性项添加属性值

xml(标准化越来越近了).save(server.mappath("http://www.cncms.com.cn/xml(标准化越来越近了)data/data.xml(标准化越来越近了)"))
’在指定的路径保存xml(标准化越来越近了)文件,

response.write"link"&link ’将link=1返回给swf文件

%>


   这样我们依次完成了对地图的操作、地名的标注等功能;而在地图的使用过程中,用地名名称进行查询及定位是也一个必不可少的常用功能。技术交流 永无止境

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网