none
instrucciones clrscr y gotoxy RRS feed

  • Pregunta

  •  

    hola... tengo un pequeño "problemita" con el visual c++ 2008. no me acepta las instrucciones clrscr y gotoy. =(

    ¿que instrucciones puedo usar en su lugar? ó es necesario que añada una libreria.. de ser así alguen podria decirme como lo hago??  desde antes graxx...  =D

    miércoles, 8 de octubre de 2008 22:53

Respuestas

  • Hola,

    pues claro que no las acepta, no existen. No pertenecen ni a C estándar ni a C++ estándar ni a alguna librería de Windows que venga con Visual C++. 

    Para borrar los datos de la consola, puedes emplear 

    system("cls");

    Para emplear cuestiones avanzadas de la consola (i.e. mover corrdenadas, cambiar colores, etc), emplea la API de la Consola:


    En particular, la función que buscas es SetConsoleCursorPosition.

    Saludos.
    miércoles, 8 de octubre de 2008 23:19
  •  

    Equivalente a Gotoxy en la api de windows:

     

    SetCursorPosition

     

     

    borrar Pantalla:

     

    forma 1

     

    Code Snippet
    system("cls");
    

     

     

    forma 2

     

    Code Snippet
     /* Standard error macro for reporting API errors */ 
     #define PERR(bSuccess, api){if(!(bSuccess)) printf("%s:Error %d from %s \ 
        on line %d\n", __FILE__, GetLastError(), api, __LINE__);}
    
     void cls( HANDLE hConsole )
     {
        COORD coordScreen = { 0, 0 };    /* here's where we'll home the
                                            cursor */ 
        BOOL bSuccess;
        DWORD cCharsWritten;
        CONSOLE_SCREEN_BUFFER_INFO csbi; /* to get buffer info */ 
        DWORD dwConSize;                 /* number of character cells in
                                            the current buffer */ 
    
        /* get the number of character cells in the current buffer */ 
    
        bSuccess = GetConsoleScreenBufferInfo( hConsole, &csbi );
        PERR( bSuccess, "GetConsoleScreenBufferInfo" );
        dwConSize = csbi.dwSize.X * csbi.dwSize.Y;
    
        /* fill the entire screen with blanks */ 
    
        bSuccess = FillConsoleOutputCharacter( hConsole, (TCHAR) ' ',
           dwConSize, coordScreen, &cCharsWritten );
        PERR( bSuccess, "FillConsoleOutputCharacter" );
    
        /* get the current text attribute */ 
    
        bSuccess = GetConsoleScreenBufferInfo( hConsole, &csbi );
        PERR( bSuccess, "ConsoleScreenBufferInfo" );
    
        /* now set the buffer's attributes accordingly */ 
    
        bSuccess = FillConsoleOutputAttribute( hConsole, csbi.wAttributes,
           dwConSize, coordScreen, &cCharsWritten );
        PERR( bSuccess, "FillConsoleOutputAttribute" );
    
        /* put the cursor at (0, 0) */ 
    
        bSuccess = SetConsoleCursorPosition( hConsole, coordScreen );
        PERR( bSuccess, "SetConsoleCursorPosition" );
        return;
     }
    http://support.microsoft.com/kb/99261
     
    jueves, 9 de octubre de 2008 15:17
    Moderador

Todas las respuestas

  • Hola,

    pues claro que no las acepta, no existen. No pertenecen ni a C estándar ni a C++ estándar ni a alguna librería de Windows que venga con Visual C++. 

    Para borrar los datos de la consola, puedes emplear 

    system("cls");

    Para emplear cuestiones avanzadas de la consola (i.e. mover corrdenadas, cambiar colores, etc), emplea la API de la Consola:


    En particular, la función que buscas es SetConsoleCursorPosition.

    Saludos.
    miércoles, 8 de octubre de 2008 23:19
  •  

    Equivalente a Gotoxy en la api de windows:

     

    SetCursorPosition

     

     

    borrar Pantalla:

     

    forma 1

     

    Code Snippet
    system("cls");
    

     

     

    forma 2

     

    Code Snippet
     /* Standard error macro for reporting API errors */ 
     #define PERR(bSuccess, api){if(!(bSuccess)) printf("%s:Error %d from %s \ 
        on line %d\n", __FILE__, GetLastError(), api, __LINE__);}
    
     void cls( HANDLE hConsole )
     {
        COORD coordScreen = { 0, 0 };    /* here's where we'll home the
                                            cursor */ 
        BOOL bSuccess;
        DWORD cCharsWritten;
        CONSOLE_SCREEN_BUFFER_INFO csbi; /* to get buffer info */ 
        DWORD dwConSize;                 /* number of character cells in
                                            the current buffer */ 
    
        /* get the number of character cells in the current buffer */ 
    
        bSuccess = GetConsoleScreenBufferInfo( hConsole, &csbi );
        PERR( bSuccess, "GetConsoleScreenBufferInfo" );
        dwConSize = csbi.dwSize.X * csbi.dwSize.Y;
    
        /* fill the entire screen with blanks */ 
    
        bSuccess = FillConsoleOutputCharacter( hConsole, (TCHAR) ' ',
           dwConSize, coordScreen, &cCharsWritten );
        PERR( bSuccess, "FillConsoleOutputCharacter" );
    
        /* get the current text attribute */ 
    
        bSuccess = GetConsoleScreenBufferInfo( hConsole, &csbi );
        PERR( bSuccess, "ConsoleScreenBufferInfo" );
    
        /* now set the buffer's attributes accordingly */ 
    
        bSuccess = FillConsoleOutputAttribute( hConsole, csbi.wAttributes,
           dwConSize, coordScreen, &cCharsWritten );
        PERR( bSuccess, "FillConsoleOutputAttribute" );
    
        /* put the cursor at (0, 0) */ 
    
        bSuccess = SetConsoleCursorPosition( hConsole, coordScreen );
        PERR( bSuccess, "SetConsoleCursorPosition" );
        return;
     }
    http://support.microsoft.com/kb/99261
     
    jueves, 9 de octubre de 2008 15:17
    Moderador