《人机交互第6章优秀课件.ppt》由会员分享,可在线阅读,更多相关《人机交互第6章优秀课件.ppt(52页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、人机交互第人机交互第6 6章章第1页,本讲稿共52页人机交互界面表示模型界面描述语言窗口系统用户界面管理系统第2页,本讲稿共52页6.1.1 6.1.1 行为模型行为模型 分析人员获取用户需求后,结合领域专家的意见和指导,获取系统中需要完成的任务,对任务的主要因素进行详细地分析,如任务的层次、发生条件、完成的方法以及它们之间的关系等等。下面就从模型的基本原理、实例、局限性等几个方面详细介绍四种常见的行为模型。第3页,本讲稿共52页GOMS(Goal,Operator,Method,Selection)目标操作方法和选择行为模型是在交互系统中用来分析用户复杂性的建模技术,用于建立用户行为模型。它
2、采用“分而治之”的思想,将一个任务进行多层次的细化,通过目标(Goal)、操作(Operator)、方法(Method)以及选择规则(Selection rule)四个元素来描述用户行为。第4页,本讲稿共52页l目标目标 目标就是用户执行任务最终想要得到的结果。l操作操作 操作是任务分析到最底层时的行为,是用户为了完成任务所必须执行的基本动作。l方法方法 方法是描述如何完成目标的过程。一个方法本质上来说是一个内部算法,用来确定子目标序列及完成目标所需要的操作。第5页,本讲稿共52页关闭窗口行为描述实例第6页,本讲稿共52页l选择规则选择规则 选择规则是用户要遵守的判定规则,以确定在特定环境下所
3、使用的方法。当有多个方法可供选择时,GOMS中并不认为这是一个随机的选择,而是尽量预测可能会使用哪个方法。第7页,本讲稿共52页LOTOS(Language Of Temporal Ordering Specification)时序关系说明语言是一种作为国际标准的形式描述语言,它提供了一种通用的形式语义,可保证描述不存在二义性,便于分析和一致性测试理论的研究。其基本思想是用一套形式化和严格的表示法来刻画系统外部可见行为之间的时序关系,系统由一系列进程组成,两个以上的进程在执行同一个外部可见的行为时会发生交互,进行数据交换、信息传递、协调同步等操作。第8页,本讲稿共52页l下面给出LOTOS模型
4、中定义的基本算符:T1|T2(交替Interleaving):T1和T2两个任务相互独立执行,可按任意顺序执行,但永远不会同步。T1 T2(选择Choice):需要在T1,T2中选择一个执行,一旦选择某一个后,必须执行它直到结束,在这中间另一个再无执行机会。任务如何来选择,并没有给出一定的形式化描述。第9页,本讲稿共52页 T1|a1,.,an|T2(同步Synchronization):任务T1,T2必须在动作(a1,,an)处保持同步。T1 T2(禁止Deactivation):一旦T2任务被执行,T1便无效(不活动)。T1 T2(允许Enabling):当T1成功结束后才允许T2执行。第
5、10页,本讲稿共52页中国象棋LOTOS的图形描述第11页,本讲稿共52页UAN(User Action Notion)用户行为标注是一种简单的符号语言,着眼于用户和界面两个交互实体的描述,主要描述用户的行为序列以及在执行任务时所用的界面。UAN模型的标识符主要有两种:用户动作标识符和条件选择标识符。第12页,本讲稿共52页l用户动作标识符用户动作标识符 在UAN的表示模型中有一些常用的已经预定义的符号,用来表示常见的用户界面的交互动作。如:move_mouse(x,y)移动鼠标至(x,y);release_button(x,y)在(x,y)位置释放鼠标按钮;hightLight(icon)使
6、icon高亮显示;de_highlight(icon)取消icon的高亮显示。第13页,本讲稿共52页l条件选择标识符条件选择标识符 除了表示动作的符号,UAN模型还包含表示条件及选择的标识符,主要有以下几种:while while(condition)TASK 当条件condition为真时,循环执行任务TASK;if if(condition)thenthen TASK 如果条件condition满足,则执行任务TASK;iteration iteration A*or A+表示迭代操作;waitingwaiting 表示等待,可以等待一个条件满足,也可以等待任务中的一个操作执行。第14页
7、,本讲稿共52页UAN表格表示形式UAN描述的任务“文件拖入垃圾箱”的单通道实例第15页,本讲稿共52页CTT(Concurrent Task Tree Notation)任务模型表示法是一种基于图形符号的,采用层次的树状结构来组织并表示任务模型的方法。任务种类和暂态关系的含义及其图形符号:任务分析是一个以人们的行为为出发点的分析过程,它分析人们完成任务的方法:他们要做的事、要起作用的事和想要知道的事。任务种类:抽象任务(Abstract Task),用户任务(User Task),交互任务(Interaction Task),系统任务(Application Task)。第16页,本讲稿共5
8、2页暂态关系符号:暂态关系符号:Choice:t1 t2 tn Concurrent(Independent Concurrency):t1|t2|tn带信息交换的Concurrent:t1|t2|tnDisabling:t1 t2Enabling:t1 t2 tn带信息交换的Enabling:t1 t2 tnIndependence:t1|=|t2第17页,本讲稿共52页单用户任务模型单用户任务模型 单用户任务模型在CTT中表示为一棵树。用户使用自动取款机的任务模型第18页,本讲稿共52页6.1.2 6.1.2 结构模型结构模型 形式化语言的描述产生式规则:if condition then
9、 action 或 condition action 或 condition:action 一般来说,组成界面描述的产生式规则很多,规则定义的顺序并不重要,只要与规则中的条件相匹配,就可以激活相应的动作。产生式规则系统可以是事件引导的,也可以是状态引导的,或者两者都有。第19页,本讲稿共52页l状态转换网络状态转换网络 状态转换网络(STN)的基本思想是定义一个具有一定数量的状态的转换机,称之为有限状态机(FSM),FSM从外部世界中接收到事件,并能使FSM从一个状态转换到另一个状态。两种最基本的状态转换网络:状态转换网络(State Diagrams)扩展状态转换网络(State Chart
10、s)第20页,本讲稿共52页状态转换网络符号简单状态转换网络带条件和动作的状态转换网络状态转换网络状态转换网络(State Diagrams)第21页,本讲稿共52页基于鼠标画图工具状态转换网第22页,本讲稿共52页扩展状态转换网络扩展状态转换网络(State Charts)分层的状态图实例第23页,本讲稿共52页6.1.3 6.1.3 行为模型和结构模型的转换行为模型和结构模型的转换 一般来说行为模型主要对设计起指导作用,在此基础上,设计人员再进行结构模型(如状态转换网络等)的创建,这个过程很大程度上取决于设计人员的经验和对行为模型的理解。整体框架整体框架转换算法转换算法实例应用实例应用第2
11、4页,本讲稿共52页最高层目标状态转换“运行”目标状态转换第25页,本讲稿共52页“走棋”目标状态转换第26页,本讲稿共52页6.1.4 6.1.4 表现模型表现模型 表现模型(PM)描述了用户界面的表现形式,由层次性的交互对象组成。逻辑组织结构逻辑组织结构面板用户界面的图形显示面板用户界面的数据结构表示面板用户界面的绘制面板用户界面的逻辑组织结构第27页,本讲稿共52页l面板内部的事件分发及响应方式面板内部的事件分发及响应方式 控制面板用户界面交互的核心模块可以看作是一个事件处理中心,事件处理中心接收并解析用户动作,然后将结果表现给用户。事件处理中心对事件的响应的实现第28页,本讲稿共52页
12、l面板间的关系面板间的关系 Jacob Eisenstein创立了两种新的抽象描述来描述基于面板的用户界面表现模型。面板关系分类面板种类第29页,本讲稿共52页 界面描述语言一般分为两类:命令式语言(Imperative Language)和陈述式语言(Declarative Language)。命令式语言要求编程人员明确的指定如何执行任务,陈述性语言要求编程人员只需指定任务要做什么,陈述性语言要比命令式的语言更为抽象。下面介绍几种常见的陈述性语言。第30页,本讲稿共52页用户界面标记语言(UIML)语言的基本表示结构第31页,本讲稿共52页扩展界面标记语言(XIML)XIML由组件(Comp
13、onents)、关系(Relations)和属性(Attributes)三部分构成。XML语言的基本表示结构第32页,本讲稿共52页 XML用户界面语言XUL XUL提供了创建现代图形界面大多数元素的能力。能够满足特定设备的普遍需求,对开发者来说,也已经足够强大,能够创建复杂的界面。第33页,本讲稿共52页6.3.1 6.3.1 窗口系统结构窗口系统结构 窗口系统一般有三种结构:在各个应用程序内部实现和管理多任务在操作系统核心集中处理多任务管理多任务的管理可由独立的管理程序进行管理,应用程序通过调用该管理程序提供的接口来实现对多任务的管理和设备的独立性操作第34页,本讲稿共52页6.3.2 6
14、.3.2 交互事件处理交互事件处理 应用程序内部事件处理循环应用程序内部事件处理循环事件处理循环第35页,本讲稿共52页l事件注册方式事件注册方式事件注册方式处理流程图第36页,本讲稿共52页6.3.3 6.3.3 交互组件开发包交互组件开发包 一般的窗口系统,输入和显示是分离的,许多语言提供了用于开发交互系统的开发软件包,交互系统开发软件包在支持窗口管理的基础上增加了另一种抽象,它把输入和输出的行为结合起来。按钮交互对象行为第37页,本讲稿共52页6.3.4 6.3.4 交互框架交互框架桌面应用框架第38页,本讲稿共52页下拉菜单示例工具栏示例第39页,本讲稿共52页树形菜单示例状态栏示例标
15、签页方式工作区示例第40页,本讲稿共52页6.3.5 MVC6.3.5 MVC模式和基于模式和基于StrutsStruts的实现的实现 MVC把一个应用的输入、处理、输出流程按照模型(model)、视图(View)和控制(Controller)的方式进行分离,形成模型层、视图层、控制层三个层次。MVC模型第41页,本讲稿共52页 Struts的体系结构实现了MVC模式的概念,它将这些概念映射到web应用程序的组件和概念中。Struts结构第42页,本讲稿共52页struts演示的基本构架和数据流程第43页,本讲稿共52页 UIMS(User Interface Management Syste
16、ms)支持用户界面的表示、设计、实现、执行、评估和维护,能够为用户提供一致的人机界面,以极其友好的方式与用户进行人机交互,并能使开发者几乎随心所欲地使用此开发工具进行软件开发。第44页,本讲稿共52页6.4.1 6.4.1 对话独立性对话独立性 对话的独立性是人机交互研究领域的主要问题,主要是强调业务(应用程序的语义)与提供给用户的界面的分离。对话的独立性有许多优点:可移植性、可重用性、界面的多样性、定制界面第45页,本讲稿共52页6.4.2 UIMS6.4.2 UIMS的表示方法的表示方法 主要包含人机界面的规格说明和它与人的因素、应用程序及其数据结构的联系等。UIMS逻辑结构模型中几个主要
17、元素的表示方法,其中除了对话控制的表示方法比较成熟、研究成果丰富外,其它层次的表示方法尚有待发展。如:表现层的表示方法表现层的表示方法 对话控制的表示方法对话控制的表示方法 应用层的表示方法应用层的表示方法第46页,本讲稿共52页6.4.3 6.4.3 一个基于一个基于JavaJava的的UIMSUIMS的实现的实现 本节给出用Java语言实现一个实用的UIMS的例子,该系统以 Eclipse作为开发平台,以swing组件作为实现交互组件的基础,实现了基于填表界面自动生成一个实例,并给出UIMS具体实现的过程。第47页,本讲稿共52页UIMS系统的组成模型模型第48页,本讲稿共52页UIMS模型的结构图第49页,本讲稿共52页事件处理器事件处理器事件处理过程示意图第50页,本讲稿共52页界面生成界面生成Panel界面例子第51页,本讲稿共52页用Java语言实现时间处理中心管理程序。用Java语言实现面板输入界面的UIMS系统管理程序。请用GOMS模型给出一个拼图游戏的任务描述,要求用户能从给定的几种图形中随机产生需要拼接的图案。请用状态转换图描述一个绘制折线的对话过程,并按照状态设计模式给出具体实现过程。第52页,本讲稿共52页