How to Use More than One Type of Font in Picture Box

Last reviewed: June 21, 1995
Article ID: Q81220
The information in this article applies to:

- Standard and Professional Editions of Microsoft Visual Basic for

  Windows, versions 2.0 and 3.0
- Microsoft Visual Basic programming system for Windows, version 1.0

SUMMARY

The text box control in Visual Basic for Windows displays the entire text box with either the FontUnderline, FontBold, FontItalic, or FontStrikethru fonts, but with only one font at a time. This behavior is by design.

However, you may want to display a box with all four fonts at the same time with separate words displayed in different fonts. Below is an example of displaying the fonts FontBold, FontItalic, FontStrikethru, and FontUnderline fonts in a picture box control in Visual Basic for Windows to work around the limitation in text boxes.

MORE INFORMATION

The example below is one way of simulating a text box's contents in a variety of fonts.

  1. Run Visual Basic for Windows, or from the File menu, choose New Project (press ALT, F, N) if Visual Basic for Windows is already running. Form1 is created by default.

  2. Place a picture box on Form1, and double-click the picture box to open the Code window. Add the following code to the Click event. Notice that the font properties are a Boolean type (that is, -1 = True and 0 = False).

    Sub Picture1_Click ( )
    
    '** The word "Hello, " will be in FontBold.
            temp$ = "Hello, "
            Picture1.FontBold = -1
            Picture1.FontItalic = 0
            Picture1.FontStrikethru = 0
            Picture1.FontUnderline = 0
            Picture1.Print temp$
    
    '** Need to program the next location to print in FontItalic.
            Picture1.Currentx = 500
            Picture1.Currenty = 0
            Picture1.FontBold = 0
            Picture1.FontItalic = -1
            Picture1.FontStrikethru = 0
            Picture1.FontUnderline = 0
            temp$ = " there!"
            Picture1.Print temp$
    
    '** Need to program location to print in FontStrikethru.
            Picture1.Currentx = 1100
            Picture1.Currenty = 0
            Picture1.FontBold = 0
            Picture1.FontItalic = 0
            Picture1.FontUnderline = 0
            Picture1.FontStrikethru = -1
            temp$ = "This"
            Picture1.Print temp$
    
    '** Need to program location to print in FontUnderline.
            Picture1.Currentx = 0
            Picture1.Currenty = 200
            Picture1.FontBold = 0
            Picture1.FontItalic = 0
            Picture1.FontStrikethru = 0
            Picture1.FontUnderline = -1
            temp$ = "is a test."
            Picture1.Print temp$
    
    End Sub
    
    
Notice that the CurrentX and CurrentY properties are used to place the text at a certain location in the picture box. This example is rather simple, but its purpose is to give you an idea on how to simulate a text box in Visual Basic for Windows to be more flexible with a mix of the different types of fonts available.

The same method can be used to print more than one type of font to a printer. To do this, modify the Picture1_Click Sub procedure by changing Picture1. to Printer.


Additional reference words: 1.00 2.00 3.00
KBCategory: kbprg kbcode
KBSubcategory: PrgCtrlsStd


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.

Last reviewed: June 21, 1995
© 1998 Microsoft Corporation. All rights reserved. Terms of Use.