Microsoft KB Archive/42553

= &quot;Illegal Function Call&quot; Using VIEW, WINDOW, GET, or PUT =

Article ID: 42553

Article Last Modified on 11/21/2006

-

APPLIES TO


 * Microsoft QuickBasic 4.0
 * Microsoft QuickBASIC 4.0b
 * Microsoft QuickBasic 4.5 for MS-DOS
 * Microsoft BASIC Compiler 6.0
 * Microsoft BASIC Compiler 6.0b
 * Microsoft BASIC Professional Development System 7.0

-



This article was previously published under Q42553



SUMMARY
When using the QuickBasic graphics functions GET, PUT, VIEW, and WINDOW, it is very easy to encounter the error &quot;Illegal Function Call.&quot; The error can be generated for many reasons.

This information applies to Microsoft QuickBasic Versions 4.00, 4.00b, and 4.50 for MS-DOS, to Microsoft Basic Compiler Versions 6.00 and 6.00b for MS-DOS and MS OS/2, and to Microsoft Basic PDS Version 7.00 for MS-DOS and MS OS/2.



MORE INFORMATION
If you encounter the above error, the following are some suggestions for determining where the error occurs:

 If &quot;Illegal Function Call&quot; occurs on a GET statement, do the following:

 Make sure you are actually GETting part of the screen or VIEW. Make sure your array is large enough to hold the image. There is a formula in the &quot;Microsoft QuickBasic: Programming in Basic&quot; manual for Version 4.50 on Page 194 that calculates the size of the array:

sizeinbytes=4+height*planes*INT((width*bitsperpixel/planes+7)/8)  If &quot;Illegal Function Call&quot; occurs on the PUT statement, do the following:

 Make sure you are PUTting the image within the boundary of your WINDOW or VIEW statement. Certain problems that occur with the WINDOW statement may not occur with the WINDOW SCREEN statement. The use of this statement is discussed in the &quot;Microsoft QuickBasic 4.0: Basic Language Reference&quot; manual for Versions 4.00 and 4.00b.</li></ol> </li>  If you use the following code example, when run under QuickBasic Version 4.50, you will get an &quot;Illegal Function Call&quot; when trying to execute the PUT statement: DEFINT A-Z DIM image(40) AS LONG SCREEN 9 VIEW (0,0)-(300,95)    ' Sets the view for the screen WINDOW (0,0)-(300,190) ' Sets screen coordinates LINE (0,0)-(300,190),,B ' Draws a box around the vie GET (0,1)-(0,189),Image ' Gets vertical image SLEEP      10                ' Pause PUT (0,1),Image,PSET   ' Put image back to screen SLEEP 10               ' Pause This error can be corrected in one of two ways:

 The VIEW statement can be enlarged, from 95 to 96 or more. The WINDOW statement can be changed to a WINDOW SCREEN.

The current program will not accept values of 95 or less with the current WINDOW statement, but it will if a WINDOW SCREEN is used. This WINDOW SCREEN statement alters the coordinates of the screen to create a right-hand coordinate system.</li></ol> </li></ol>

Additional query words: QuickBas BasicCom

Keywords: KB42553

-

[mailto:TECHNET@MICROSOFT.COM Send feedback to Microsoft]

© Microsoft Corporation. All rights reserved.