Я использую Gtkmm 3+ и пытаюсь сделать так, чтобы в текстовом буфере была постоянная строка «>», даже если пользователь пытается ее удалить. Кроме того, когда пользователь нажал кнопку возврата, он автоматически снова будет там. В основном есть постоянная строка, как терминал.
Единственный способ, которым я могу думать о достижении этой цели, — это подключиться к сигналам удаления и возврата, чтобы пользователь не мог удалить строку. Но есть ли лучший способ?
до сих пор это единственный способ, которым я могу думать:
//in constructor
txt_view_i_.signal_event().connect(sigc::mem_fun(*this, &MainWindow::inputEvent));
//function
bool MainWindow::inputEvent(GdkEvent* event)
{
if((event->key.keyval == GDK_KEY_BackSpace || event->key.keyval == GDK_KEY_Delete) && buffer_input_->get_char_count() < 3)
return true;
return false;
}
Но не работает идеально, потому что, если вы наберете более 3 символов, а затем перейдете к началу строки, вы можете удалить постоянную строку.
Еще один способ, о котором я только что подумал, — добавить метку в виджет TextView. Я сделал это, но пользователь все еще может удалить его. Вот код для этого:
Gtk::TextBuffer::iterator it = buffer_input_->get_iter_at_line(1);
Glib::RefPtr<Gtk::TextChildAnchor> refAnchor = buffer_input_->create_child_anchor(it);
Gtk::Label* lbl = Gtk::manage(new Gtk::Label("> "));
txt_view_i_.add_child_at_anchor(*lbl, refAnchor);
Это очень похоже, но не совсем идентично, на вопрос, на который я ответил Вот: Вы можете создать GtkTextTag
что делает его содержимое недоступным для редактирования, и применяет его от начала буфера до включительно "> "
незамедлительный.
Затем, когда вы получите ввод, добавьте ваш вывод в буфер, а затем добавьте новое приглашение на следующей строке и повторно примените тег, чтобы сделать все это не редактируемым.
Ссылки в связанном ответе показывают некоторый C-код, где это делается, даже включая подсказку. Это не Gtkmm или C ++, но это должно служить иллюстрацией.
Вот код, который я использовал для его решения:
Glib::RefPtr<Gtk::TextBuffer::Tag> tag = Gtk::TextBuffer::Tag::create();
tag->property_editable() = false;
Glib::RefPtr<Gtk::TextBuffer::TagTable> tag_table = Gtk::TextBuffer::TagTable::create();
tag_table->add(tag);
buffer_input_ = Gtk::TextBuffer::create(tag_table);
txt_view_i_.set_buffer(buffer_input_);
scroll_win_i_.add(txt_view_i_);
Gtk::TextBuffer::iterator buffer_it_ = buffer_input_->begin();
buffer_input_->insert_with_tag(buffer_it_, "> ", tag);
Вот как я сделал это, чтобы пользователь не мог редактировать до постоянной строки:
//connect to the mark set signal
buffer_input_->signal_mark_set().connect(sigc::mem_fun(*this, &MainWindow::setMark));
//make the box uneditable
void MainWindow::setMark(const Gtk::TextBuffer::iterator& it, const Glib::RefPtr<Gtk::TextBuffer::Mark>& mark)
{
if(it.get_offset() < 2)
txt_view_i_.set_editable(false);
else
txt_view_i_.set_editable(true);
}
Надеюсь, кто-то найдет это полезным.