DOCUMENT:Q101374  14-JUN-2001  [accother]
TITLE   :ADT/ODE: How to Create a Custom Startup "Splash" Screen
PRODUCT :Microsoft Access Distribution Kit
PROD/VER:WINDOWS:1.1,2.0,7.0,97
OPER/SYS:
KEYWORDS:kbprogramming

======================================================================
-------------------------------------------------------------------------------
The information in this article applies to:

 - Microsoft Access Distribution Kit, version 1.1 
 - Microsoft Access Developer's Toolkit, versions 2.0, 7.0 
 - Microsoft Office 97 Developer Edition 
-------------------------------------------------------------------------------

Advanced: Requires expert coding, interoperability, and multiuser skills.

SUMMARY
=======

This article explains how to create a custom startup "splash" screen (title
screen) for your Microsoft Access application.

This article assumes that you are familiar with Visual Basic for Applications and
with creating Microsoft Access applications using the programming tools provided
with Microsoft Access. For more information about Visual Basic for Applications,
please refer to your version of the "Building Applications with Microsoft
Access" manual.

NOTE: Visual Basic for Applications is called Access Basic in Microsoft Access
versions 1.x and 2.0. For more information about Access Basic, please refer to
the "Introduction to Programming" manual in Microsoft Access version 1.x or the
"Building Applications" manual in Microsoft Access version 2.0

MORE INFORMATION
================

A startup "splash" screen is used by programmers to display important
information about a program during startup and to give the user something
colorful to look at and read while waiting for the program to complete its
initial processing, such as reading and setting up user-defined preferences.

A typical splash screen contains the following information:

 - The program name and version number
 - The registered user's name and company
 - Copyright information
 - The developer's company name and logo

This article contains two sample user-defined functions to implement splash
functionality.

Creating a New Splash Module
----------------------------

To create the functions, follow these steps:

1. Create a new module, and type the following functions.

   NOTE: In the following code, an underscore (_) is used as a line- continuation
   character. Remove the underscore from the end of the line when re-creating
   this code in Access Basic.

          '******************************************************************
          ' MODULE NAME: Splash
          ' DECLARATION SECTION
          '******************************************************************
          Option Explicit

          Dim gSplashStart     ' The time when the splash screen opened.
          Dim gSplashInterval  ' The minimum time to leave the splash screen
                               ' up.
          Dim gSplashForm      ' The name of the splash screen form.

          '******************************************************************
          ' FUNCTION: SplashStart()
          '
          ' PURPOSE: Used to invoke the splash screen form specified by the
          '    SplashForm argument.
          '
          ' ARGUMENTS:
          '    SplashForm     - The name of the form to use as the splash
          '                     screen.
          '    SplashInterval - The minimum time, in seconds, that the splash
          '                     screen must remain active on the screen.
          '
          '******************************************************************
          Function SplashStart (ByVal SplashForm As String, ByVal _
                 SplashInterval As Integer)
              ' Open the splash form.
              DoCmd.OpenForm SplashForm  ' In Microsoft Access 97 and 7.0.
              'DoCmd OpenForm SplashForm ' In versions 1.x and 2.0 only.

              ' Set the starting time.
              gSplashStart = Timer

              ' Record the global information.
              gSplashInterval = SplashInterval
              gSplashForm = SplashForm
          End Function

          '******************************************************************
          ' FUNCTION: SplashEnd()
          '
          ' PURPOSE: Used to close the splash screen form opened by the
          '    SplashStart() function. This function checks to ensure that
          '    the splash screen remains active until the user-specified
          '    interval has expired.
          '
          '******************************************************************
          Function SplashEnd ()
             Dim RetVal

             ' Loop until the splash screen has been active for
             ' the desired interval.
             Do Until Timer - gSplashStart > gSplashInterval
                ' Yield control so other applications can process.
                RetVal = DoEvents()
             Loop

             ' Close the splash screen.
             DoCmd.Close acForm, gSplashForm ' In Microsoft Access 97 and 7.0.
            'DoCmd Close A_FORM, gSplashForm ' In version 1.x and 2.0 only.

          End Function

2. Save the new module as Splash.

Using the SplashStart() and SplashEnd() Functions
-------------------------------------------------

To use the SplashStart() and SplashEnd() functions, follow these steps:

1. Create a form not based on any table or query with the text and graphics you
   want to display on the splash screen. For more information, see the "Setting
   Form Properties" section later in this article.

2. In the Database window, click the Macros tab and then click New.

3. Create a macro with the following actions and save it as AutoExec:

          Macro Name   Action
          -----------------------------------------------------------------
          AutoExec     RunCode
                       <any startup macro actions required by your program>
                       RunCode

          AutoExec Actions
          ----------------------------------------------------------------
          RunCode

             Function Name: SplashStart("YourSplashFormNameHere", 5)
          <any startup macro actions required by your program .. optional>
          RunCode
             Function Name: SplashEnd()

Setting Form Properties
-----------------------

For best results, the splash form should have its form properties set as
follows:

   ScrollBars: Neither
   PopUp: Yes
   Modal: Yes
   RecordSelectors: No

Suppressing the Default Splash Screen
-------------------------------------

To prevent the default Microsoft Access splash screen from appearing in versions
of Microsoft Access earlier than version 7.0, you can use the run-time version
of Microsoft Access provided with the Microsoft Access Developer's Toolkit for
version 2.0, or the Microsoft Access Distribution Kit (ADK) for version 1.1.

REFERENCES
==========

For more information about running an AutoExec macro in Microsoft Access, search
the Help Index for "AutoExec macros," or ask the Microsoft Access 97 Office
Assistant.

Additional query words: title intro

======================================================================
Keywords          : kbprogramming 
Technology        : kbOfficeSearch kbAudDeveloper kbAccessSearch kbOffice97Search kbAccessDevTK200 kbOffice97 kbZNotKeyword3 kbAccessDevTK700 kbAccessDistKit110 kbOffice97DevSearch
Version           : WINDOWS:1.1,2.0,7.0,97
Hardware          : x86
Issue type        : kbhowto

=============================================================================

THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS
PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND.  MICROSOFT DISCLAIMS
ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.  IN NO
EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR
ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL,
CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF
MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE
POSSIBILITY OF SUCH DAMAGES.  SOME STATES DO NOT ALLOW THE EXCLUSION
OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES
SO THE FOREGOING LIMITATION MAY NOT APPLY.

Copyright Microsoft Corporation 2001.