Partenza this guide. Vorrei fare un manipolatore personalizzato così ho potuto fare qualcosa di simile:
std::cout << "standard text" << setcolour(red) << "red text" << std::endl;
Here s' una piccola guida su come implementare il proprio manipolatore.
Un esempio di codice rapido:
#include <iostream>
#include <windows.h>
#include <iomanip>
using namespace std;
enum colour { DARKBLUE = 1, DARKGREEN, DARKTEAL, DARKRED, DARKPINK, DARKYELLOW, GRAY, DARKGRAY, BLUE, GREEN, TEAL, RED, PINK, YELLOW, WHITE };
struct setcolour
{
colour _c;
HANDLE _console_handle;
setcolour(colour c, HANDLE console_handle)
: _c(c), _console_handle(0)
{
_console_handle = console_handle;
}
};
// We could use a template here, making it more generic. Wide streams won't
// work with this version.
basic_ostream<char> &operator<<(basic_ostream<char> &s, const setcolour &ref)
{
SetConsoleTextAttribute(ref._console_handle, ref._c);
return s;
}
int main(int argc, char *argv[])
{
HANDLE chandle = GetStdHandle(STD_OUTPUT_HANDLE);
cout << "standard text" << setcolour(RED, chandle) << " red text" << endl;
cin.get();
}
Questo codice in realtà non funziona, tuttavia la versione precedente appena sostituita. Ill doppio controllo ho ragione anche se –
@ Woolf Woolf: Sì, mi dispiace. Ho avuto un problema con la copia di HANDLE. – Skurmedel
Meraviglioso che funziona perfettamente. Grazie! : D –