Linux ncurses覆盖由box()创建的边框

时间:2013-03-07 23:13:46

标签: c++ linux border ncurses

当我执行此代码时,我创建的边框的左侧将被覆盖在右上方的框中。问题似乎是局限于这个领域,即使代码看起来相同。如何防止这覆盖我的边界? 我正在使用g ++ -lncurses进行编译并在Ubuntu终端中运行

#include <ncurses.h>
#include <string.h> 
#define WINDOWY 24
#define WINDOWX 80
#define ROW1 3
#define RROW1 1
#define COL1 2
#define COL2 23
#define COL3 33 
#define COL4 38
#define MEMORYROW 9
#define MEMORYCOL 1
#define COMMANDROW 1
#define COMMANDCOL 41


int closeUp(void);
void printMockup(void);
void drawBorders(void);
WINDOW *create_newwin(int height, int width, int starty, int startx);

int main()
{
    char input = ' ';
    int row,col;    

    //initialize ncurses stuff
    initscr();      
    cbreak();
    curs_set(0);

    //check window is right size
    getmaxyx(stdscr,row,col);
    if (row < WINDOWY || col < WINDOWX)
    {
        printw("You need to increase the terminal size to at least 24 x 70");
        return closeUp();
    }

    //draw border
    drawBorders();

    //draw UI
    printMockup();

    getch();
    endwin();

    return 0;
}



int closeUp(void)
{
    getch();
    endwin();
    return 0;
}



void printMockup(void)
{
    mvprintw(1, 2, "6808 Emulator");
    mvprintw(ROW1, COL1, "Accumulator:");
    mvprintw(ROW1, COL2, "0x00");
    mvprintw(ROW1+1, COL1, "Program Counter:");
    mvprintw(ROW1+1, COL2, "0x0000");
    mvprintw(ROW1+2, COL1, "Stack Pointer:");
    mvprintw(ROW1+2, COL2, "0x0000");
    mvprintw(ROW1+3, COL1, "Index Register Low:");
    mvprintw(ROW1+3, COL2, "0x00");
    mvprintw(ROW1+4, COL1, "Index Register High:");
    mvprintw(ROW1+4, COL2, "0x00");

    mvprintw(RROW1, COL3, "PC:");
    mvprintw(RROW1, COL4, "0");
    mvprintw(RROW1+1, COL3, "C:");
    mvprintw(RROW1+1, COL4, "0");
    mvprintw(RROW1+2, COL3, "Z:");
    mvprintw(RROW1+2, COL4, "0");
    mvprintw(RROW1+3, COL3, "N:");
    mvprintw(RROW1+3, COL4, "0");
    mvprintw(RROW1+4, COL3, "I:");
    mvprintw(RROW1+4, COL4, "0");
    mvprintw(RROW1+5, COL3, "H:");
    mvprintw(RROW1+5, COL4, "0");
    mvprintw(RROW1+6, COL3, "V:");
    mvprintw(RROW1+6, COL4, "0");

    mvprintw(COMMANDROW+1, COMMANDCOL+11, "r - Run");
    mvprintw(COMMANDROW+2, COMMANDCOL+11, "s - Step");
    mvprintw(COMMANDROW+3, COMMANDCOL+11, "a - Auto-step");
    mvprintw(COMMANDROW+4, COMMANDCOL+11, "x - Reset");
    mvprintw(COMMANDROW+5, COMMANDCOL+11, "m - Main menu");

    mvprintw(MEMORYROW+1, MEMORYCOL+1, "PC:");
    mvprintw(MEMORYROW+1, MEMORYCOL+1, "0");

}



WINDOW *create_newwin(int height, int width, int starty, int startx)
{   
    WINDOW *local_win;

    local_win = newwin(height, width, starty, startx);
    //wborder(local_win, '|', '|', '-', '-', '+', '+', '+', '+');
    box(local_win, 0 , 0);
    wrefresh(local_win);

    return local_win;
}



void drawBorders(void)
{
    refresh();
    create_newwin(WINDOWY, WINDOWX, 0, 0);
    create_newwin(WINDOWY-(WINDOWY-MEMORYROW-1)-2, WINDOWX-COMMANDCOL-1, COMMANDROW, COMMANDCOL);
    create_newwin(WINDOWY-MEMORYROW-1, WINDOWX-MEMORYCOL-1, MEMORYROW, MEMORYCOL);
}

1 个答案:

答案 0 :(得分:0)

您通常会打印到窗口中并刷新它。对于这个特殊问题,我们可以通过专注于您的“命令窗口”来解决它。给定代码的结构,创建一个全局变量来保存命令窗口指针。

WINDOW *command_window;

然后,从drawBorders()函数初始化它。

command_window = create_newwin(WINDOWY-(WINDOWY-MEMORYROW-1)-2,
                               WINDOWX-COMMANDCOL-1,
                               COMMANDROW, COMMANDCOL);

将打印命令的代码修改为主窗口,将其打印到command_window中。然后,刷新command_window

mvwprintw(command_window, 1, 11, "r - Run");
mvwprintw(command_window, 2, 11, "s - Step");
mvwprintw(command_window, 3, 11, "a - Auto-step");
mvwprintw(command_window, 4, 11, "x - Reset");
mvwprintw(command_window, 5, 11, "m - Main menu");
wrefresh(command_window);