| By Chris Pollach | Article Rating: |
|
| February 13, 2013 07:58 AM EST | Reads: |
513 |
PowerBuilder - Events and Precedence
The order in which events happen within a PowerBuilder Classic application is in most cases, a very predictable model. The PB developer should be aware of this aspect when developing GUI based applications. For instance, when focus is shifted from one object to another object, the first object will experience the Modified and LoseFocus events before the second object experiences a get focus event.
To understand this further, consider the following scenarios and the resulting events.
An Application starts and window "A" is opened
WINDOW "A" OPEN
WINDOW "A" ACTIVATE
CHILD OBJECT GET FOCUS (First object in tab order)
Window "B" is opened (Window "A" stays open)
WINDOW "A" DEACTIVATE
WINDOW "B" OPEN
WINDOW "B" ACTIVATE
WINDOW "B" CHILD OBJECT GET FOCUS (First object in tab order)
Window "B" closed, return to Window "A".
WINDOW "B" CURRENT OBJECT LOSE FOCUS
WINDOW "B" CLOSE
WINDOW "B" DEACTIVATE
WINDOW "A" ACTIVATE
OBJECT GET FOCUS (Last object that had focus)
"Click" on new object within Same Window
OBJECT 1 LOSE FOCUS
OBJECT 2 GET FOCUS
OBJECT 2 CLICKED
"Tab" to new object within Same Window
OBJECT 1 LOSE FOCUS
OBJECT 2 GET FOCUS (next object in tab order)
Interestingly enough, events can and will occur even when no actions are performed by the user. If you are
using a screen saver, such as the one in Windows, the following will happen.
OBJECT LOSE FOCUS
OBJECT GET FOCUS
DataWindows and Events
Consider the following scenario:
The User Clicks on a field in a data window, keys something, clicks on another field within the data window, keys something and then clicks on a Command Button (outside of the DataWindow). The sequence of DataWindow events is as follows:
DW GET FOCUS
DW CLICKED
DW EDIT CHANGED (once for each keystroke)
DW CLICKED
DW ITEMCHANGED
DW ITEM FOCUS CHANGED
DW EDIT CHANGED (once for each keystroke)
DW LOSE FOCUS
COMMAND BUTTON GET FOCUS
COMMAND BUTTON CLICKED
A number of significant aspects are happening at this time! For example: there was only one get focus and one lose focus event. Only one item changed event occurred (even though two items were changed). A clicked event occurred two times. One edit changed event occurred for every keystroke made within the DataWindow.
If DataWindow edits were behind the two modified fields, only the first field would have been edited. For all intents and purposes, the second field has nothing in it!
Now let us insert the ACCEPTTEXT() function into the command button Clicked script. Now the sequence of events flows as follows:
DW GET FOCUS
DW CLICKED
DW EDIT CHANGED (once for each keystroke)
DW CLICKED
DW ITEMCHANGED
DW ITEM FOCUS CHANGED
DW EDIT CHANGED (once for each keystroke)
DW LOSE FOCUS
COMMAND BUTTON GET FOCUS
COMMAND BUTTON CLICKED
DW ITEMCHANGED
The last item changed event was triggered by the AcceptText ( ) functionality. You might be tempted to put this function in the DataWindow Control's losefocus event script, but this makes it very difficult for a user to cancel a transaction when they can not get past the edit rule!
Events Precedence Table
Objects Events Order Notes
Window
Open 1
Activate 2 Also after closing of
another Window
Key 3 Each Keystroke (not all objects)
CloseQuery 4
Close 5
Deactivate 6
Single Line Edit, Multi Line Edit
Get Focus 1
Modified 2
LoseFocus 3
List Box, Drop Down List Box
GetFocus 1
SelectionChanged 2 When choice made from list
Modified 3
DoubleClicked 4 Only possible when "always show
list box" is active
LoseFocus 5
Static Text, Picture, Picture Button
GetFocus 1
Clicked 2
DoubleClicked 3 Always issues a Clicked event first
LoseFocus 4
Check Box, Command Button, Radio Button
GetFocus 1
Clicked 2
LoseFocus 3
DataWindow
GetFocus 1
Clicked 2
DoubleClicked 3 Always issues a Clicked event first
EditChanged 4 Once for each keystroke
ItemError 5 When item doesn't pass validation
ItemChanged 6 When object loses focus within dw
RowFocusChanged 7
ItemFocusChanged 8
LoseFocus 9
Events Notes
At any time in an application, an event can occur through use of the TRIGGEREVENT() function. This can be a very handy thing to know and use. It can also cause problems if the application is counting on certain events to occur in a certain sequence.
DataWindow Clicked Event
Often, the clicked event in a data window is used to trigger a choice made by the user. In the script for this event it is always a good policy to check that the clicked row value is greater than zero. If the click is made on the borders or white space of a data window, the GETCLICKEDROW function will return a zero.
Although the ItemError! event listed after EditChanged! event under dw events order is a bit confusing, I am
sure it is correct as per the 4 phases of validation:
. edit-changed check
. data-type check (ItemError! fires here...)
. item-changed check
. validation-rule check
***********************************************************
Read the original blog entry...
Published February 13, 2013 Reads 513
Copyright © 2013 SYS-CON Media, Inc. — All Rights Reserved.
Syndicated stories and blog feeds, all rights reserved by the author.
More Stories By Chris Pollach
Chris Pollach is a Senior Consultant with over 30 years experience in Systems and Software Analysis, Development, Maintenance and Technical Support, mainly in the areas of GUI Design, MS-Windows Programming, Java / .NET Programming, Wireless, Application / Web Server Design & Programming, Object Oriented Development Tools and Methodologies, Data Base, Data Communications and Network application development. He has participated in numerous technical, planning and management roles, as well as consulted and educated in these fields for a diverse clientele. He is also the owner of “Software Tool & Die Inc.” a company dedicated to provide custom software and education solutions on Object Oriented business systems.
As an educator, Chris is certified to teach PowerBuilder (first in Canada), MS-SQLServer, Sybase’s Enterprise Application Studio and EAServer integrated application/web development environment. He is former Certified SilverStream developer (CSSD) and current Certified PowerBuilder Developer – Associate / Professional (CPD-P) as well as a Certified Sybase Tools Instructor (CSI).
Chris has written numerous articles in various popular personal computer magazines, newsletters and is the author of the PowerGuide and PowerExpert products as well as the STD Foundation Classes. Currently, Chris has developed a Foundation Class library for Sybase's PocketBuilder, SAP's PowerBulder and EAServer products and now Appeon Web & mobile products that integrates JSP or ASP web development, Section 508 / CLF web standards and mobile applications. A new Web Service framework has also been released for IIs to support PowerBuilder based web service NVUO's!
Chris recently became a 2nd Degree Black in the TaeKwonDo martial art and has developed a Martial Art multimedia study guide using the Component-One “Doc2Help” and Sybase PowerBuilder products. Since the fall of 2004 he became a TaeKwonDo instructor for the City of Ottawa’s Goulbourn program. He has also been certified with the World TaeKwonDo Federation (February 2005 - 1st Dan and October 2008 - 2nd Dan).
Chris was awarded the Sybase “Innovation and Achievement” award for 2005 as voted for by the International Sybase User Group (ISUG). This award was presented for innovations to the PocketBuilder mobile development product, contributions to the PowerBuilder News groups and support of the Ottawa Sybase User Group.
To round his management and leadership skills, Chris is the former president of the Kiwanis Club of Goulbourn and still volunteers his time with the service clubs in his area. He is also the coordinator of the Ottawa Sybase User group and a certified NAUI scuba instructor. For the last three years, Chris has been voted onto the ISUG Board of Directors and holds the position of "Director - North American User Groups".
- Cloud People: A Who's Who of Cloud Computing
- Windows Azure IaaS Reaches General Availability
- New Relic Q1 2013 Blazes Past Growth Targets and Reaches 40,000 Active Customer Accounts
- Cloud Computing Is Simplifying Things
- Cimtrek announces the general release of its Lotus Notes migrator for Microsoft’s SharePoint platform
- Google Compute enters the IaaS market
- Step-by-Step: Extend Your Network to the Cloud with Windows Azure Virtual Networks
- Six Steps to Get Started with Windows Azure Active Directory
- Microsoft Blue over Windows 8, Retooling Underway
- Build Your Private Cloud in a Month
- RightScale Supports Windows Azure Infrastructure Services General Availability
- Weekly Roundup: Windows Azure IaaS Moves into GA
- Cloud People: A Who's Who of Cloud Computing
- Windows Azure IaaS Reaches General Availability
- New Relic Q1 2013 Blazes Past Growth Targets and Reaches 40,000 Active Customer Accounts
- Cloud Computing Is Simplifying Things
- Cimtrek announces the general release of its Lotus Notes migrator for Microsoft’s SharePoint platform
- Google Compute enters the IaaS market
- Understanding Hyper-V Replica
- Step-by-Step: Tired of Tapes? Backup SQL Databases to the Cloud
- Super-Fast Failover with VM Guest Clustering in Windows Server 2012 Hyper-V
- Accelerating the Cloud with Windows Server 2012 BranchCache
- Step-by-Step: Speaking iSCSI with Windows Server 2012 and Hyper-V
- Step-by-Step: Extend Your Network to the Cloud with Windows Azure Virtual Networks
- Where Are RIA Technologies Headed in 2008?
- Accessing the ASP.NET Authentication, Profile and Role Service in Silverlight
- Building Great AJAX Applications Using ASP.NET
- Cloud People: A Who's Who of Cloud Computing
- Silverlight 2 - Adobe Flex Killer Is on Its Way!
- Spice Up User Experience with Silverlight
- Will Google's Android Sink or Swim?
- The Next Chapter in the Virtualization Story Begins
- Is the Silverlight Adoption Rate Artificially Inflated?
- Cloud Expo 2011 East To Attract 10,000 Delegates and 200 Exhibitors
- Kaazing Announces Support for Silverlight
- Rich Content Rotator for ASP.NET



























