darrenecm Posted May 6, 2006 Share Posted May 6, 2006 I'm trying to get a handle on the manner in which the panel system for FS2004 calls C gauge code routines and was wondering if anyone could expand on the following: #define PANEL_SERVICE_PRE_QUERY 0 #define PANEL_SERVICE_POST_QUERY 1 #define PANEL_SERVICE_PRE_INSTALL 2 // extra_data = resource_handle #define PANEL_SERVICE_POST_INSTALL 3 // extra_data = resource_handle #define PANEL_SERVICE_PRE_INITIALIZE 4 #define PANEL_SERVICE_POST_INITIALIZE 5 #define PANEL_SERVICE_PRE_UPDATE 6 #define PANEL_SERVICE_POST_UPDATE 7 #define PANEL_SERVICE_PRE_GENERATE 8 // extra_data = phase #define PANEL_SERVICE_POST_GENERATE 9 // extra_data = phase #define PANEL_SERVICE_PRE_DRAW 10 #define PANEL_SERVICE_POST_DRAW 11 #define PANEL_SERVICE_PRE_KILL 12 #define PANEL_SERVICE_POST_KILL 13 #define PANEL_SERVICE_CONNECT_TO_WINDOW 14 // extra_data = PANEL_WND #define PANEL_SERVICE_DISCONNECT 15 // extra_data = PANEL_WND #define PANEL_SERVICE_PANEL_OPEN 16 #define PANEL_SERVICE_PANEL_CLOSE 17 Getting a handle on the program flow for C gauge code is essential for me in order to be able to optimise my code. I just need confirmation on exactly when sections of C code are called when using these values in a switch statements. The MS SDK is, as usual, quite useless in this matter. For instance I assumed that the PANEL_SERVICE_PRE_INITIALIZE code was generated once for when a gauge is loaded when an aircraft is selected. Now I hear that it's also generated when you simply switch to and from 2D and 3D virtual views! Is this right? If so the INITIALIZE naming convention is quite counter-intuitive :) I'm amazed anyone ever discovers how these defines work in the context of the FS2004 panel system seeing as it's part of a hidden system you don't have much control over, coupled with the fact the official SDK is so pitifully documented. For those who have figured these things out, could you share any tips on how you disocvered the inner workings of these service_id values and when they are generated? I guess I could create a simple gauge that printed text alerts on the screen for each case section that was called, that way you know under what conditions the code sections were processed? I was thinking of doing this but if anyone has already deduced the 'inner workings' of these things already, it would save me a lot of time and potential headaches. Any guidance will be greatly appreciated :) Grassy arse amigos. Link to comment Share on other sites More sharing options...
n4gix Posted May 8, 2006 Share Posted May 8, 2006 In general, all of these cases are evalutated twice during any gauge cycle. The opening case is PANEL_SERVICE_CONNECT_TO_WINDOW, so you can't tell too much about the "order" based on the SDK #define sequence. The ones that I included in the GDI+ Template are the ones most commonly used. Frankly, many of 'em seem to have no real use at all! Doug Dawson created a service_id_test gauge about a year or so ago. It's available at http://avsim.com Bill Leaming http://smileys.sur-la-toile.com/repository/Combat/0054.gif Gauge Programming - 3d Modeling Military Visualizations Flightsim.com Panels & Gauges Forum Moderator Flightsim Rig: Intel Core i7-2600K - 8GB DDR3 1333 - EVGA GTX770 4GB - Win7 64bit Home Premium Development Rig1: Intel Core i7-3770k - 16GB DDR3 - Dual Radeon HD7770 SLI 1GB - Win7 64bit Professional Development Rig2: Intel Core i7-860 - 8GB DDR3 Corsair - GeForce GTS240 1GB - Win7 64bit Home Premium NOTE: Unless explicitly stated in the post, everything written by my hand is MY opinion. I do NOT speak for any company, real or imagined... Link to comment Share on other sites More sharing options...
matsis Posted May 13, 2006 Share Posted May 13, 2006 Any code contained in PANEL_SERVICE_PRE_UPDATE section of a c++-gauge is exectued once every gauge update cycle, i.e. 18 times a second. About PANEL_SERVICE_PRE_INITIALIZE I have assumed the same as you up till now. In there I put anything that requires initialzing before the actual gauge code starts to work, especially if sounds are involved and might click/beep away during panel loading because some general definition is not clear yet during gauge loading. However, I have not found such code to hurt during view changes, and I will usually put it within a seperate counter variable that will only be true once right during panel loaeing and never revert back to the status it had at first. Of the other stuff I have hardly a clue myself, apart from the KILL parts that again are important when having to clear sound handles and such from RAM before gauge code execution is ended. Link to comment Share on other sites More sharing options...
darrenecm Posted May 14, 2006 Author Share Posted May 14, 2006 I just tried posting a response in this thread (a long one) and it seems to have gone awol when I clicked on 'Post message'. I didn't see any error messages. This DCForum is quite irritaing at times. No easy formatting, refuses to stay in linear viewing mode (I hate threaded mode's indent-ad-infinitum style) :) So here it is again, hopefully my original post won't magically appear and create a repeat post. Anyway. I stumbled across Arne Bartel's sdkbugs.zip file today that had some pertinent information regarding service_id sequences. I've pasted an excerpt at the bottom of this post. Arne used tabs in the word document for his listing but I couldn't figure out how to apply tab formatting using DCForums poor formatting abilities, so I simply used --- to indent the appropriate lines. I'm also not sure of the line '// aircraft change' in the document at the end of the two service_id blocks. Should there be another listing showing how things are called when an aircraft is changed. I would have thought 'aircraft change' is the same as 'aircraft selected...or is there a difference? The information also appears to have been written during the FS2000 era, so the question is whether any changes in FS2004 may mean the information needs to be updated? Can anyone confirm? My stumbling on sdkbugs.zip also raises the question of whether the gauge programming community really needs a single place to come to in order to find the name and location of all informational material relating to gauge programming. Maybe Bill or one of the other forum moderators could start a 'sticky' thread that brings together a listing of known filenames and locations for all such files? They all seem sequestered away all over the Internet :) The only information files I know of in addition to sdkbugs.zip are: idehowto.zip sd2gau17.zip Can anyone point me towards any others? Finally, do all these service_id values actually compare to standard Win32 message ID values as used in general Windows programming? A gauge does exist within a resieable window after all, so I was wondering if, behind all those cryptic macros in the panel SDK that insist on hiding plain C code, the gauge DLL code structure is in fact simply the same as that found when programming your own window code and message handling in Win32? Thanks for the help guys - Darren **** Excerpt from sdkbugs.zip / Author: Arne Bartels**** service_id sequence: An FS2000 gauge runs through a specific sequence of service_ids (like the FS98 gauges ran through the initialize_routine(),install_routine().....kill_routine() sequence); below is an example of such a sequence: //aircraft selected PANEL_SERVICE_CONNECT_TO_WINDOW PANEL_SERVICE_PRE_INSTALL PANEL_SERVICE_POST_INSTALL PANEL_SERVICE_PRE_INITIALIZE PANEL_SERVICE_POST_INITIALIZE ---PANEL_SERVICE_PRE_UPDATE ---PANEL_SERVICE_POST_UPDATE PANEL_SERVICE_PRE_GENERATE PANEL_SERVICE_POST_GENERATE ---PANEL_SERVICE_PRE_DRAW ---PANEL_SERVICE_POST_DRAW ---PANEL_SERVICE_PRE_UPDATE ---PANEL_SERVICE_POST_UPDATE ...//(_DRAW_, _UPDATE_ constantly repeated) ---PANEL_SERVICE_PRE_DRAW ---PANEL_SERVICE_POST_DRAW ---PANEL_SERVICE_PRE_UPDATE ---PANEL_SERVICE_POST_UPDATE PANEL_SERVICE_PRE_KILL PANEL_SERVICE_POST_KILL // window resize PANEL_SERVICE_PRE_INSTALL PANEL_SERVICE_POST_INSTALL PANEL_SERVICE_PRE_INITIALIZE PANEL_SERVICE_POST_INITIALIZE ---PANEL_SERVICE_PRE_UPDATE ---PANEL_SERVICE_POST_UPDATE PANEL_SERVICE_PRE_GENERATE PANEL_SERVICE_POST_GENERATE ---PANEL_SERVICE_PRE_DRAW ---PANEL_SERVICE_POST_DRAW ---PANEL_SERVICE_PRE_UPDATE ---PANEL_SERVICE_POST_UPDATE ...//(_DRAW_, _UPDATE_ constantly repeated) ---PANEL_SERVICE_PRE_UPDATE ---PANEL_SERVICE_POST_UPDATE ---PANEL_SERVICE_PRE_UPDATE ---PANEL_SERVICE_POST_UPDATE PANEL_SERVICE_PRE_KILL PANEL_SERVICE_POST_KILL PANEL_SERVICE_DISCONNECT //aircraft change This example shows that the gauge will run on every window resizing through a 'kill','install/initialize' sequence (just like in FS98). Unlike FS98, it is possible to distinguish an aircraft change from a window resize: with FS2000 there is PANEL_SERVICE_CONNECT_TO_WINDOW at startup and PANEL_SERVICE_DISCONNECT at shutdown. Also the whole gauge is loaded at startup and released at a change to the next aircraft, which is not like FS98 where a gauge is reloaded on every window resize. The ..._UPDATE service_ids occur in a fixed cycle at 18Hz, the ..._DRAW service_ids are synchronous with the frame rate (sounds logical: why draw when no one can see it, but it didn't stop FS98 using the same fixed 18Hz cycle both for drawing and updating). Link to comment Share on other sites More sharing options...
Recommended Posts