在Authorware中用目录树操作数据库

来源 :硅谷 | 被引量 : 0次 | 上传用户:jiguoqiang
下载到本地 , 更方便阅读
声明 : 本文档内容版权归属内容提供方 , 如果您对本文有版权争议 , 可与客服联系进行内容授权或下架
论文部分内容阅读
  [摘要]设学生管理数据库中有两个表:班级简况,学生情况。在Authorware中可以把班级简况表中的班级名称字段的值做树型树目录中的一级目录,把学生情况表的学生姓名做成二级目录。且用这个树型目录来操作数据库的中的记录非常方便,如果只有二级目录,设计详细页时只有两个页面,班级一个页面,学生一个页面,如果页面上的信息要详细,查询语句多一点内容罢了,与页面设计没有多大关系,且在详细页面还可以增加你所要的功能,如修改,删除,插入记录等。
  [关键词]树型目录 数据库 查询
  中图分类号:TP3 文献标识码:A 文章编号:1671-7597(2008)0820046-02
  
  一、引言
  
  在vb,javascritp都可以有树型目录来操作数据库中的记录,在Authorware中可不可以呢?书上没有介绍,Authorware帮助也没有谈及,论坛上高手也说不能,但我脑海隐隐约约有能解决这个问题的思路,通过一个晚上的努力,终于把想法变成现实,写出来让同行分享。为了论述方便,功能不求全,只求能实现,只要知道了原理,做强做大不是问题。
  
  二、设计思想
  
  (一)用winctrls.u32库函数中WcDisplaycontrol()来确定目录的位置,大小,形状,监视器。
  (二)用WcSetproPertyValue添加目录树中的条目,并设置图标和文字字号。我们研究的重点就在这里目录树中的条目。用数据库主表中主键的值做一级条目,子表中外键的所有值提取出来做目录树的二级条目。首先,载入tmsdns.u32库函数中的tmsdbregister函数,使数据库能自动注册,然后载入odbc.u32库函数中的odbcclose,odbcopen,odbcexecute三个函数实现对数据库及表的操作,当然,这较复杂,请参照后的程序。
  (三)wcgetpropertyvalue()返回目录树中的文件,然后根据文本的类型,用goto()函数跳转到相应的页面,事实上,我们只设有两种类型:一个是班级,一个是学生,不管有多少班级,多少个学生,只用两个页,都能把他们的信息显示出来,这就是数据库的好处之一。
  
  三、数据库设计
  
  选用Access作数据库,数据库名:学生管理.mdb,其中有两个表,班级简况与学生情况,班级简况中有两个字段:班级代号,班级名称;先输入一些记录,班级代号是主键。学生情况表中有字:学号,班级代号,姓名,性别,
  出生年月,家庭所在地等,班级代号是外键,学号是主键,也在每个班中添加一些记录。
  
  四、程序设计
  
  (一)在Authorware7.0中新建一个文件,保存为freeview.a7p,在函数窗口类型中选中freeview.a7p,分别点载入winctrls.u32中的wcdisplayc
  ontrol(),wcsetpropertyvalue(),wcgetpropertyvalue;
  tmsdns.u32中的tmsdbregister();odbc.u32中的odbcclose(),odbcopen(),odbcexecute.
  (二)在流程线上添加一个计算图标,并命名为数据库注册。打开它,输入如下语句。
  --数据库注册
  dblist:="dsn=std;"
  dblist:=dblist^"description=学生管理;"
  dblist:=dblist^"fil=ms access;"
  dblist:=dblist^"dbq="^FileLocation^"学生管理.mdb;"
  result:=tMsDBRegister(4,"microsoft access driver (*.mdb)", dblist)
  dn:="std"
  de:=""
  --把数据库“学生管理.mdb”打开
  dc:=ODBCOpen(WindowHandle, de, dn, "","")
  --从数据库的表班级简况提取记录,放入一个字符串变量DD中
  sql:="select 班级代号,班级名称 from 班级简况 order by 班级名称"
  dd:=ODBCExecute(dc, sql)
  ODBCClose(dc)
  Initialize(dc)
  --计算DD的行数放入numline中
  count1:=CharCount(dd)
  newline:=GetLine(dd,1)
  count2:=CharCount(newline)
  numline:=INT(count1/count2)+1
  i:=1
  mcc:=""
  --逐行读取班级简况的记录
  repeat while i<=8
  newline:=GetLine(dd,i)
  --如果到了最后空行,退出循环
  if newline="" then
  exit repeat
  end if
  把一行中的各字段提取出,由于班级名称既有汉字,又有数字,AW把它分成两部分,这里花了我很多时间。A2^a3是班级名称。
  a1:=GetWord(1,newline)
  a2:=GetWord(2,newline)
  a3:=GetWord(3,newline)
  mc:=a2^a3
  --把各记录的班级名称累加起来作为一级条目(目录树的)
  mcc:=mcc^mc^"\r"
  --把相对应的学生情况表的学生信息查出来。
  exec:="select 姓名,学号,家庭所在地 from 学生情况 where 班级代号='"^a1^"'"
  dc:=ODBCOpen(WindowHandle, de, dn, "","")
  xsqk:=ODBCExecute(dc,exec)
  ODBCClose(dc)
  Initialize(dc)
  count1:=CharCount(xsqk)
  newline:=GetLine(xsqk,1)
  count2:=CharCount(newline)
  Numxs:=INT(count1/count2)+1
   j:=1
  --每一个班级有多名学生,把学生的姓名查出来作为二级条目
   repeat while j<=numxs
   xsline:=GetLine(xsqk,j)
   if xsline="" then
   exit repeat
   end if
  xm:=GetWord(1,xsline)
  --下面哪个空格很关键,很让我费了一些神。
  mcc:=mcc^" "^xm^"\r”
   j:=j+1
  end repeat
  i:=i+1
  end repeat
  (三)在流程线上再加一个计算图标,命名为treeview,加入以下语句。
  --第5个参数一定要是”treeview”,第6个参数是监视器,作用很大啊,它的值只有两种0,1
  treeid:=wcDisplayControl(10, 5, 200, 400, "treeview", "cen")
  --设置目录中字体大小为10号,你可以变。
  wcSetPropertyValue(treeid, "fontsize", "10")
  --设置目录树中的条目,参数mcc就是前面计算图标中花大力气算出来的,就是目录树中的条目,再强调一次,班级简况表的班级名称为一级条目,学生情况表中的姓名为二级条目。为了使大家明了看下图:
  


  在计算图标cen中输入如下语句:
  获取用户单击目录树条目的文本。
  tt:=wcGetPropertyValue(treeid, "text")
  判断tt是班级名称还是学生的姓名,如是单击了班级名称,就跳转到框架右边的班级页,否则跳转到学生页面。
  if SubStr(tt,1,1)="计" | SubStr(tt,1,1)="会"then
  exec:="select 学号,姓名,性别,家庭所在地 from 学生情况 inner join 班级简况 on 学生情况.班级代号=班级简况.班级代号 where 班级名称='"^tt^"'"
  dc:=ODBCOpen(WindowHandle, de, dn, "","")
  bj:=ODBCExecute(dc,exec)
  ODBCClose(dc)
  Initialize(dc)
  GoTo(IconID@"班级")
   else
  exec:="select 学号,姓名,性别,家庭所在地 from 学生情况 inner join 班级简况 on 学生情况.班级代号=班级简况.班级代号 where 姓名='"^tt^"'"
  dc:=ODBCOpen(WindowHandle, de, dn, "","")
  xscj:=ODBCExecute(dc,exec)
  ODBCClose(dc)
  Initialize(dc)
  GoTo(IconID@"学生成绩")
  end if
  在班级群组与学生成绩群组中分别放入两个显示图标,并在适当位置分别输入{bj},{xscj},两个显示图标的属性的要选更新变量显示。到这里整个程序设计完成。
  
  参考文献:
  [1]张斌,《Authorware 7 多媒体体制作》,卓越科技,2004.12.
  [2]黎明,《Authorware 6.5 多媒制作基础教程》,零点工作室.
其他文献
[摘要]在FPGA设计复杂性不断增加,先进的生产工艺不断引入新的设计实现挑战的情况下,设计人员最关心的问题是设计工具的吞吐能力、易用性和生产力、时序收敛和设计反复能力以及解决时序和功率等问题等能力。作为业界最佳解决方案之一的赛灵思ISE设计套件也在不断推陈出新,讨论ISE Design Suite10.1版的先进性。  [关键词]ISE Design Suite10.1版 SmartXplorer
期刊
[摘要]Visual Basic在实现图形动画方面,有其独到之处,简述使用VB专业版实现图形动画及利用Move实现动画效果的方法,为进一步理解编程思想,更好的掌握编程原理,学好VB程序设计提供参考。  [关键词]控制的移动 动画按钮 图片剪切换 Move方法  中图分类号:TP3 文献标识码:A 文章编号:1671-7597(2008)0820039-01    在教学中,学生总是对移动的图形画面
期刊
[摘要]介绍湛江发电厂脱硫增压风机CT饱和引起各种电流继电器误动的原因,分析电流互感器饱和对电磁式电流继电器、晶体管或集成电路构成的模拟式电流继电器和微处理机构成的数字式电流继电器动作行为的影响。论述几种防止和抗御电流互感器饱和的方法和对策,如在较高一级的电压等级中的供电侧采取分列运行的方式以减少短路电流等。给出选择合适的保护装置和在新建系统中选择电流互感器的一些原则。   [关键词]继电保护 电
期刊
[摘要]随着我国乡村游向纵深发展,游客对于真实性的要求越来越高。如何塑造乡村旅游的真实性,给旅游产品打上个性化标签,是摆在景区经营者面前得一个重要课题。从客观主义、建构主义、后现代主义和存在主义四个角度阐述旅游体验的真实性的含义,并且以阳朔为例,阐述如何创建乡村旅游体验真实性的若干建议。  [关键词]乡村旅游 真实 体验  中图分类号:F59 文献标识码:A 文章编号:1671-7597(2008
期刊
[摘要]本测控仪的参数测量采用专用的电能计量芯片ATT7026,该芯片是一个高精度的三相电能计量芯片,避免了复杂的参数计算,简化了系统结构,缩短了开发周期,且价格低廉,工作可靠,有较高的实用价值。  [关键词]电流互感器 数据采集 无功补偿  中图分类号:TP2文献标识码:B文章编号:1671-7597(2008)0820042-01    本测控仪的参数测量采用专用的电能计量芯片ATT7026,
期刊
[摘要]随着计算机技术的发展,多媒体成为计算机技术应用的重要领域。对于多媒体播放软件,我们再熟悉不过了,如我们平常用的MediaPlayer和豪杰超级解霸等娱乐软件。它们虽然在界面风格上各有特色,但实现原理大同小异。Visual Basic 提供了多种简单快速开发多媒体的方法,我们可以利用VB编写出功能类似的多媒体播放软件。  [关键词]Visual Basic 多媒体 程序设计  中图分类号:T
期刊
[摘要]任播技术是一种新的网络应用。任播通信是支持导向服务地址的,但是目前IPv6中它的很多定义是模糊的,并且在控制路由方面没有达成一致的协议标准,因此节点间任播通信仍然无法实现。   [关键词]IPv6任播通信任播地址解析  中图分类号:TP2 文献标识码:A 文章编号:1671-7597(2008)0820051-01    一、IPv6地址类型的概述     IPv6地址长度为128比特,地
期刊
[摘要]随着ERP系统和自动化系统建设的逐步完善,企业对于生产现场的组织管理提出了需求,各企业开始实施MES系统的建设。介绍烟草企业在易地技改新厂区的MES系统建设情况。MES系统实施实现了生产过程的信息化管理,使得从定单到成品入库全过程实现自动化。  [关键词]SOA .netWonderware  中图分类号:C94 文献标识码:A 文章编号:1671-7597(2008)0820061-01
期刊
[摘要]随着J2EE技术平台的逐渐成熟和完善,基于J2EE的Web应用开发也日益增加,表现层作为Web应用开发架构中的重要一层,好的表现层框架对加快开发周期以及简化开发繁简度有着很重要的影响,就是在这样的背景下,详细的对两种表现层框架Struts和Jsf进行对比分析,以方便开发者在实际项目应用中的选用。  [关键词]表现层 Struts JSF 对比  中图分类号:TP3 文献标识码:A 文章编号
期刊
[摘要]在开发基于Browser/Server模式的网络应用程序中,数据库的连接是首要考虑的问题,本文通过对数据库的连接、数据库中数据的读取及显示、数据库中数据的添加、更新、删除五个方面详细阐述对WEB数据库中数据访问的实现,总结出如何充分利用ASP.NET的控件来实现对数据库中数据的访问。  [关键词]ASP.NET Web数据库 控件  中图分类号:TP3 文献标识码:A 文章编号:1671-
期刊