DOCUMENT:Q132534 24-MAR-2000 [foxpro] TITLE :FIX: Error Changing Grid s DynamicBackColor & DynamicForeColor PRODUCT :Microsoft FoxPro PROD/VER:WINDOWS:3.0,3.0b OPER/SYS: KEYWORDS:kbvfp kbvfp300bBUG kbvfp500fixkbbuglist kbfixlist ====================================================================== ------------------------------------------------------------------------------- The information in this article applies to: - Microsoft Visual FoxPro for Windows, versions 3.0, 3.0b ------------------------------------------------------------------------------- SYMPTOMS ======== You get the following error when changing the DynamicBackColor and DynamicForeColor in a grid that has a class object added to a column and that class object is the active control with the Sparse Property set to false (.F.): Expression evaluated to an illegal value RESOLUTION ========== Change either the DynamicBackColor or the DynamicForeColor but not both. Or use the default controls that the Form Builder offers. STATUS ====== Microsoft has confirmed this to be a problem in the Microsoft products listed at the beginning of this article. This problem has been fixed in Visual FoxPro 5.0 for Windows. MORE INFORMATION ================ Steps to Reproduce Problem -------------------------- 1. Create a new class named CenterChk based on Container, and store it in Mylib.vcx. 2. In the Class Designer, set the following properties for the container: Height = 19 Width = 68 BackStyle = 0-Transparent BorderWidth = 0 3. From the Form Controls toolbar, select the check box Control, and place a check box in the container. 4. Set the following Properties for the check box: BackStyle 0-Transparent Height = 16 Caption = "" Width = 14 5. With the check box selected, click Center Horizontally and Center Vertically on the Format menu. Then save and close the class. 6. Open the Tastrade.dbc in the VFP\Samples\Mainsamp\Data directory. 7. Create a new form called TestGrid, and add a new property to the form called nCurRec. 8. Using the right mouse button, click the form to bring up the Data Environment. Then using the right mouse button, click the Data Environment. Click Add, and add the Products table. 9. From the Form Controls toolbar, select the Grid control, and add a grid to the form. 10. Using the right mouse button, click the grid, and choose Builder. From the Grid Builder, select the Products table. From the Available Fields, select Product_id, Product_name, and Discontinued. 11. Close the Builder by clicking OK. 12. Set the following Property for the grid: RowHeight = 19 13. Using the right mouse button, click the grid, then click Edit. 14. From the Form Controls toolbar, click the View Classes button and choose Add. Select Mylib.vcx from the Open dialog box. From the Form Controls Toolbar, select the CenterChk control, and add it to the Discontinued Column on the grid. 15. Set the following Properties for Column 3 in the grid: CurrentControl CenterChk1 Width = 68 Sparse = .F. 16. Set the following Property for Column 3 CenterChk1 Check1 in the grid: ControlSource = products.discontinued 17. Add the following code to the Init event of the grid: THISFORM.nCurRec = RECNO() THISFORM.Grid1.SETALL('DynamicBackColor',; 'IIF(THISFORM.nCurRec == RECNO(), rgb(0,0,128), rgb(255,255,0))',; 'Column') THISFORM.Grid1.SETALL('DynamicForeColor', ; 'IIF(THISFORM.nCurRec == RECNO(), rgb(0,0,255), rgb(0,0,0))', ; 'Column') THIS.REFRESH 18. Add the following code to the AfterRowColChange event of the grid: THISFORM.nCurRec = RECNO() THIS.REFRESH 19. Save and run the form. For more information on creating forms, please see Chapter 9 in the Developer's Guide. For more information on creating classes, please see Chapt1er 10 in the Developer's Guide. And for more information on using controls on a form, please see Chapter 11 in the Developer's Guide. Additional query words: ====================================================================== Keywords : kbvfp kbvfp300bBUG kbvfp500fix kbbuglist kbfixlist Technology : kbVFPsearch kbAudDeveloper kbVFP300 kbVFP300b Version : WINDOWS:3.0,3.0b Issue type : kbbug Solution Type : kbfix ============================================================================= 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 2000.