ImageVerifierCode 换一换
格式:PPTX , 页数:23 ,大小:180.67KB ,
资源ID:4250231      下载积分:10 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/4250231.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(用户对象.pptx)为本站上传会员【丰****】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

用户对象.pptx

1、第12章用户对象在面向对象程序设计中,有两个重要的概念:对象和类。在PowerBuilder中,系统提供了很多标准的对象和类,它们有各自的功能、表现特征、属性、事件和函数。12.1用户对象的概念用户对象只需定义一次,就能够反复多次使用,并且每修改一次,就能把修改结果反映到所有使用该用户对象的地方。在PowerBuilder中用户对象分为两类:可视用户对象(VisualUserObject)和类(非可视)用户对象(ClassUserObject)。1、可视用户对象、可视用户对象可视用户对象是一个可视的控件或一组完成一定功能的控件。可视用户对象共分为以下三类:(1)标准可视用户对象(Standar

2、dVisual)标准可视用户对象是对PowerBuilder现有控件的扩充,它在现有控件的基本功能的基础上增加应用程序需要的功能。标准可视用户对象继承了原始控件的各种特征,包括属性、事件和函数。结束放映第一页上一页下一页最后一页12.1用户对象的概念(2)定制可视用户对象(CustomVisual)定制可视用户对象是若干标准控件或已经存在的可视用户对象的组合,它把不同的部件集成在一起,每一部分都具有其原有的属性、事件,都可在用户对象画板中编写脚本。而在使用时又作为一个整体,一旦将该对象放在窗口上之后,就不能再为其中某一组成部件的事件进行编码了。(3)外部可视用户对象(ExternalVisua

3、l)外部可视用户对象实际上就是在PowerBuilder应用程序中使用其他语言(比如C或C+)编写的控件,这些可视控件存放在DLL文件中。通常是为了完成PowerBuilder本身难以完成或不支持的功能。2、类用户对象、类用户对象类用户对象是对不可视组件的逻辑和功能的封装。PowerBuilder中有两种类型的类用户对象:标准类用户对象和定制类用户对象。类用户对象最主要的优点就是真正的不可视。所以它不消耗GUI资源,仅仅消耗对象和它的工作结构以及为动态创建它所需的内存。(1)标准类用户对象(StandardClass)标准类用户对象是对PowerBuilder的标准对象的继承,并且允许用户用自

4、己的代码扩充缺省的行为以便使它们适应用户的需要。结束放映第一页上一页下一页最后一页12.1用户对象的概念(2)定制类用户对象(CustomClass)定制类用户对象并不继承PowerBuilder中的任何基本对象,只通过用户自己定义的实例变量、函数以及事件来完成特定的功能。定制类用户对象只有两个系统预定义事件:Constructor和Destructor。12.2用户对象的创建在PowerBuilder中,单击PowerBar工具条栏中的New图标,在弹出的对话框中选择PowerBuilderObject标签页,选中你要创建的用户对象的类型,单击OK按钮即可创建。12.2.1创建标准可视用户对

5、象单击PowerBar工具条栏中的New图标,在弹出的对话框中选择PowerBuilderObject标签页中的StandardVisual项,单击OK按钮。弹出SelectStandardVisualType对话框,选择一种标准可视类型对象,单击OK按钮即可创建。下面以实例来说明标准可视用户对象的创建过程。现在要创建的标准可视用户对象是一个用来关闭窗口的按钮对象u_cb_close,步骤如下:结束放映第一页上一页下一页最后一页12.2.1创建标准可视用户对象(1)在SelectStandardVisualType对话框中选择commandbutton,单击Ok按钮,弹出UserObject画

6、板,此画板同窗口的编辑画板类似,只是有一部分工具不可用。(2)按钮的Text属性初始设置为none,在按钮上单击鼠标右键然后选择Properties菜单项,打开属性对话框,将按钮的Text属性改为“退出”。(3)在按钮上单击鼠标右键然后选Script菜单项,打开脚本画板。在脚本画板中单击选择事件的下拉列表框的箭头,显示出命令按钮的预定义事件。为Clicked事件输入如下脚本:/u_cb_close的click事件IntegerIsCancelIsCancel=MessageBox(“提示!”,“是否要退出?”,Question!,okcancel!)IfIsCancel=0ThenClose(

7、Parent)EndIf(4)单击PainterBar上的Return按钮返回。再单击Save按钮将新建的用户对象存盘,用户对象名存为u_cb_close。这样一个简单的用户对象就创建完成了。结束放映第一页上一页下一页最后一页12.2.2创建定制可视用户对象编程时经常会遇到数据的录入和修改,操作都十分类似。我们可以创建一个用户对象u_dataedit,它包括一个数据窗口控件、包括插入、删除和提交按钮各一个。我们只要给它指定一个数据窗口对象,就可以进行插入、删除和更新操作。具体操作步骤如下:(1)单击PowerBar工具条栏中的New图标,在弹出的对话框中选择PowerBuilderObject

8、标签页,选中CustomVisual项,单击OK按钮,打开UserObject画板。(2)在定制可视用户对象中放置控件的方法与在窗口中放置控件一样。单击窗口控件下拉按钮,在弹出的工具条中选择所需的控件和用户对象。在用户对象u_dataedit中放置三个按钮、一个数据窗口控件。(3)将三个按钮的Text属性分别改为“插入”、“删除”和“提交”,将Name属性分别改为cb_insert、cb_delete和cb_save。分别为它们的Clicked事件编写如下脚本:结束放映第一页上一页下一页最后一页12.2.2创建定制可视用户对象/cb_insert的Clicked事件的脚本/在当前行之前插入一条

9、新的记录intli_row,li_cur_rowli_cur_row=dw_l.GetRow()li_row=dw_l.InsertRow(li_cur_row)dw_l.ScrollToRow(li_row)dw_l.SetFocus()/cb_delete的Clicked事件脚本Longll_cur_rowll_cur_row=dw_l.GetRow()dw_l.DeleteRow(ll_cur_row)dw_l.setfocus()结束放映第一页上一页下一页最后一页12.2.2创建定制可视用户对象/cb_save的Clicked事件脚本Stringls_errtextIfdw_l.Upd

10、ate()=lThenCommit;ElseLs_errtext=SQLCA.SQLErrtextRollBack;MessageBox(”存盘失败!”,ls_errtext)EndIf(4)为数据窗口dw_l的Rowfocuschanged事件输入如下脚本:/dw_l的rowfocuschanged事件/将当前行设置为选中行this.SelectRow(0,False)this.SelectRow(currentrow,true)结束放映第一页上一页下一页最后一页12.2.2创建定制可视用户对象为了更好地实现用户对象的功能,我们不但可以使用对象原有的事件,还可以自己定制一些事件。下面我们为u

11、dataedit添加一个定制事件ue_init。在Script编程窗口中,选u_dataedit对象和New Event事件,将弹出定制事件的对话框。在Event Name下添加事件名称ue_init,设置Argument Name为datawinname,Argument Type为String,Pass By为Value,Return Type为Integer,Event ID为none。为新建的定制事件编写脚本。/u_dataedit的ue_init事件脚本int li_numberdw_l.DataObject=datawinnamedw_l.SetTransObject(sqlca

12、)li_number=dw_l.Retrieve()Return li_number 在使用时只能通过Post或Trigger语句来触发此事件,使用格式为:userobjectname.post|trigger event ue_init(datawindowname)结束放映第一页上一页下一页最后一页12.2.3创建外部可视用户对象单击PowerBar工具条栏中的New图标,在弹出的对话框中选择PowerBuilderObject标签页中的ExternalVisual项,这将打开UserObject设计界面。其他步骤与标准可视用户对象相同。12.2.4创建标准类用户对象创建一个标准类用户对象

13、应在单击PowerBar工具条栏中的New图标,在弹出的对话框中选择PowerBuilderObject标签页中的StandardClass项,这将打开SelectStandardClassType对话框,如图12.6所示,用户可以选择想要扩充的类用户对象。下面我们定义一个Transaction类型的用户对象,用于管理数据库连接。通过以下方法可以定义若干个函数用于不同的数据库事务。(1)在Select Standard Class Type对话框中选择Transaction,并单击OK按钮进入User Object画板。(2)在函数列表框中选择Functions,新建一个函数f_connec

14、t_anywhere用于Adaptive Server Anywhere数据库建立连接,程序清单如下:结束放映第一页上一页下一页最后一页12.2.4创建标准类用户对象/uf_connect_anywhere函数脚本this.DBMS=”ODBC”this.DbParm=”Connectstring=”+ar_dbfileConnectUsingthis;Ifthis.SQLCODE=-1ThenMessageBox(”连接”,”不能连接到AdaptiveServerAnywhere数据库!”)EndIfReturnthis.SQLCODE这样,一个简单的标准类用户对象就定义完成了。12.2.5

15、创建定制类用户对象创建一个定制类用户对象,应单击PowerBar工具条栏中的New图标,在弹出的对话框中选择PowerBuilderObject标签页中的CustomClass项,定制类画板与定制窗口画板或定制可视用户对象画板相似。Constructor:发生在窗口的Open事件之前或用户对象被动态地放置在窗口上时。Destructor:发生在窗口的Close事件之后或用户对象被动态地从窗口上取消时。结束放映第一页上一页下一页最后一页12.3使用用户对象创建了用户对象后,在应用程序中就可以随时使用它们了。可视用户对象在使用前需要放置到窗口或其他定制可视用户对象上,类用户对象则需要在代码中通过编

16、写程序来使用。12.3.1 使用可视用户对象 通过把可视用户对象放置到窗口或其他定制可视用户对象上来使用这些对象。(1)打开要放置可视用户对象的窗口。(2)从窗口画板的控件下拉列表中选择用户对象图标,系统打开Select Object对话框。(3)选择要使用的用户对象,单击OK,关闭对话框。(4)在窗口上要放置用户对象的地方单击,所选用户对象即出现在窗口上。在窗口或定制可视用户对象上放置了可视用户对象后,可以像使用标准控件那样为它命名、调整大小、调整位置、编写事件处理程序等。需要注意的是,在窗口画板中不能直接修改所使用的用户对象。当需要修改时,应关闭窗口画板,然后使用用户对象画板进行修改。在代

17、码中可以使用PowerScript函数OpenUserObject()或OpenUserObjectWithParm()动态地往窗口上添加用户对象,也可以使用CloseUserObject()函数将其删除。结束放映第一页上一页下一页最后一页12.3.2使用类用户对象类用户对象没有可视成分,它们不能像可视用户对象那样放置到窗口上。使用类用户对象时,需要在代码中创建它的一个实例,步骤为:(1)说明类用户对象类型的变量,用CREATE语句创建该对象的一个实例。(2)在变量的整个作用域中,代码都能访问该对象的属性、事件、函数,引用方法依然使用点操作符,就像使用系统预定义对象那样(比如事务对象)。(3)

18、不再使用该用户对象时,使用DESTROY语句删除该对象,以释放它所占用的内存。例如,创建了一个标准类用户对象u_ds,它从数据库存储对象继承得到,那么代码中可以这样使用u_ds:u_dsu_ds_delete/说明u_ds类型的变量u_ds_delete=CREATEu_ds/创建用户对象实例u_ds_delete.DataObject=“d_user_delete”/将数据窗口对象与类用户对象联系起来u_ds_delete.SetTransObject(SQLCA)/设置类用户对象使用的事务对象u_ds_delete.Retrieve()/检索数据/应用程序所需的其他处理DESTROYu_d

19、s_delete/不用后删除该用户对象结束放映第一页上一页下一页最后一页12.4窗口与用户对象间的通讯用户对象是一个完成特定功能的封闭组件,与结构化程序设计中的子程序类似。窗口与可视用户对象之间交换信息的方法很多,归纳起来,比较好的通讯方式有三种:使用函数;使用用户事件;直接引用用户对象的属性。例如,用户对象控件uo_1中放置了一个单行文本编辑框sle_1,那么,在窗口的事件处理程序中可以给用户对象中的单行文本编辑框的Text属性直接赋值,表述如下:uo_1.sle_1.text=”测试用户对象通讯”使用函数进行信息交换时,定义一些公共的(Public)用户对象级函数,利用这些函数把内部信息传

20、递给窗口,或把窗口信息传递到用户对象内部。使用用户事件进行信息交换时,可以为用户对象定义一些用户事件以及相应的参数,这样也可以通过编写事件处理程序、触发事件来完成用户对象与窗口之间的通讯。结束放映第一页上一页下一页最后一页12.5用户对象示例下面通过两个例子完整地介绍使用用户对象的全过程,以进一步加深理解。例1:本例的要求是:使用用户对象实现日期的调整。初始日期为当前日期;当使用鼠标单击上下箭头时,可以上下调整日期;能够直接设置为下周一的日期;并且能够触发显示当前的时间,如下图所示。日期调整功能是比较常用的,使用用户对象来实现比较适合,而下周一这种设置则具有特殊性,不适合使用用户对象。下面介绍

21、实现的方法:(1)建立定制的可视用户对象uo_date,其中包含单行文本编辑框sle_1和垂直滚动条vsb_1。结束放映第一页上一页下一页最后一页12.5用户对象示例(2)定义实例变量dateid_date。(3)在对象级Constructor事件中加入如下脚本:id_date=today()sle_1.text=string(id_date,”yyyy-mm-dd”)(4)在vsb_1的Lineup事件中加入如下脚本:id_date=RelativeDate(id_date,1)sle_1.text=string(id_date,”yyyy-mm-dd”)(5)在vsb_1的Linedown

22、事件中加入如下脚本:id_date=RelativeDate(id_date,-1)sle_1.text=string(id_date,”yyyy-mm-dd”)(6)定义用户对象函数uof_display_time(booleanar_datetime),实现日期和时间的显示,其脚本如下:结束放映第一页上一页下一页最后一页12.5用户对象示例timeIt_timeifar_datetimethenIt_time=now()sle_1.text=string(It_time,”hh:mm:ss”)sle_1.textcolor=RGB(255,255,255)sle_1.backcolor=R

23、GB(255,0,0)elsesle_1.text=string(id_date,”yyyy-mm-dd”)sle_1.textcolor=RGB(0,0,0)sle_1.backcolor=RGB(255,255,255)endif(7)保存后退出。(8)建立窗口w_uo_date,类型为main。(9)在窗口上加入用户对象uo_1,原型为uo_date。结束放映第一页上一页下一页最后一页12.5用户对象示例(10)放置按钮cb_1,cb_1.text=”下周一”,其Clicked事件脚本为:dateld_month_dayintli_weekday,lld_month_day=uo_1.i

24、d_date/访问用户对象例程变更li_weekday=DayNumber(ld_month_day)l=7-li_weekday+1ld_month_day=RelativeDate(ld_month_day,l)uo_1.id_date=ld_month_dayuo_1.sle_1.text=string(uo_1.id_date,”yyyy-mm-dd”)/访问用户对象控件属性(11)放置按钮cb_2,cb_2.text=”时间”,其Clicked事件脚本为:uo_1.uof_display_time(true)/调用用户对象函数timer(1)uo_1.uof_display_time

25、false)其功能是:当按下“时间”按钮后,通过调用用户对象函数(传递参数True),实现时间显示,同时设置1秒延时。定时结束后,调用用户对象函数(传递参数False),重新显示日期。结束放映第一页上一页下一页最后一页12.5用户对象示例(12)放置按钮cb_3,cb_3.text=”返回”,其Clicked事件脚本为:Close(parent)(13)保存。例2:本例完成一个定制类用户对象的创建,这个类(用户对象)可以实现在DataWindow中检索、更新、插入和删除数据,这些功能是通过它的方法(用户对象函数)来实现的。选择DeclareInstanceVariables标签声明实例变量如

26、下:datawindowidw_parm/声明数据窗口变量各个函数的参数及代码如下:/Function:uf_init/Purpose:对这个数据窗口保存一个引用/Scope:public/Arguments:adw_parmaDataWindowpassedbyreference/Returns:noneidw_parm=adw_parm结束放映第一页上一页下一页最后一页12.5用户对象示例/Function:uf_retrieve_row/Purpose:RetrievestheDataWindow/Scope:public/Arguments:none/Returns:longretur

27、nidw_parm.Retrieve()/Function:uf_update_row/Purpose:UpdatestheDataWindow/Scope:public/Arguments:none/Returns:integer1success,-1errorintli_rcli_rc=idw_parm.Update()ifli_rc=1thencommit;elserollback;endifreturnli_rc结束放映第一页上一页下一页最后一页12.5用户对象示例/Function:uf_insert_row/Purpose:在数据窗口中插入一条新记录,如果al_row=0,则在最后

28、插入。否则在al_row的前一行插入/Scope:public/Arguments:al_row/Returns:longsuccessreturntherownumberofthenewrowthat/wasadded,-1errorlongll_rcll_rc=idw_parm.InsertRow(al_row)ifll_rc0thenidw_parm.ScrollToRow(ll_rc)idw_parm.SetFocus()endifreturnll_rc结束放映第一页上一页下一页最后一页12.5用户对象示例/Function:uf_delete_row/Purpose:从数据窗口中删除

29、指定的一行数据,如果al_row=0,则当前行被删除/Scope:public/Arguments:al_row/Returns:integer1success-1errorintli_rcifal_row=0andal_row=idw_parm.RowCount()thenli_rc=idw_parm.DeleteRow(al_row)idw_parm.SetFocus()returnli_rcelsereturn-1endif结束放映第一页上一页下一页最后一页12.5用户对象示例下面介绍如何应用刚才我们创建的类用户对象u_business_object:(1)创建一个窗口,在窗口上放一个数

30、据窗口控件和四个命令按钮,命令按钮上显示的文本分别是检索、更新、插入、删除。(2)在DelclareInstanceVariables标签视图中声明实例变量:/用前面已经定义的类用户对象声明一个实例变量u_business_objectiuo_business_object(3)在窗口的Open事件中创建类用户对象。Connect;dw_1.SetTransObject(sqlca)iuo_business_object=createu_business_objectiuo_business_object.uf_init(dw_1)/调用初始化函数,传递参数dw_1(4)在Retrieve按钮的Clicked事件中编写代码:iuo_business_object.uf_retrieve_row()(5)在Update按钮的Clicked事件中编写代码:iuo_business_object.uf_update_row()结束放映第一页上一页下一页最后一页12.5用户对象示例(6)在Insert按钮的Clicked事件中编写代码:iuo_business_object.uf_insert_row()(7)在Delete按钮的Clicked事件中编写代码:iuo_business_object.uf_delete_row()结束放映第一页上一页下一页最后一页

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服