cairo - 显示多个叠加的小部件
问题描述
我正在尝试显示多个相互重叠的 cairo 图纸:
extern crate cairo;
extern crate gio;
extern crate gtk;
use std::f64::consts::PI;
use gio::prelude::*;
use gtk::prelude::*;
use gtk::DrawingArea;
use std::env::args;
fn build_ui(application: >k::Application) {
let window = gtk::ApplicationWindow::new(application);
window.set_default_size(300, 300);
let overlay = gtk::Overlay::new();
// Draw first circle
let drawing_area1 = Box::new(DrawingArea::new)();
drawing_area1.connect_draw(|_, ctx| draw(ctx, 0.5, 0.4));
overlay.add(&drawing_area1);
// Draw second circle
let drawing_area2 = Box::new(DrawingArea::new)();
drawing_area2.connect_draw(|_, ctx| draw(ctx, 0.2, 1.0));
overlay.add(&drawing_area2);
window.add(&overlay);
window.show_all();
}
fn draw(ctx: &cairo::Context, width: f64, color: f64) -> Inhibit {
ctx.scale(300., 300.);
ctx.arc(0.5, 0.5, width, 0.0 * PI, 2.0 * PI);
ctx.set_source_rgba(color, 0.0, 0.0, 0.8);
ctx.fill_preserve();
Inhibit(false)
}
fn main() {
let application =
gtk::Application::new(Some("example.overlay"), Default::default())
.expect("Initialization failed...");
application.connect_activate(|app| {
build_ui(app);
});
application.run(&args().collect::<Vec<_>>());
}
运行这段代码给了我这个警告:
(test_overlay_gtk:25534): Gtk-WARNING **: 19:12:05.573: Attempting to add a widget with type GtkDrawingArea to a GtkOverlay, but as a GtkBin subclass a GtkOverlay can only contain one widget at a time; it already contains a widget of type GtkDrawingArea
我了解该overlay
对象只能显示其中一个绘图区域。我认为这个overlay
类正是为了这个目的,显示重叠的小部件。我找不到显示第二个重叠绘图区域的方法。
解决方案
add
将小部件作为主要子元素添加到叠加层 - 您只能拥有其中一个。set_child
这是从旧版本的 gtkmm(我假设您正在使用)中的容器类继承的,并在 gtkmm 4(不再继承add
自)中被替换Gtk::Container
。
add_overlay
是Gtk::Overlay
允许您添加任意数量的小部件以显示在子小部件之上的特定方法。
尝试用您的第二种add
方法替换add_overlay
它应该可以工作。
推荐阅读
- google-apps-script - 如何在 Google 表格中使用“frozenColumns”?
- angular - Angular 8 中的 REST API 请求显示 statusText:“未知错误”
- linux - 如何从 .cer 文件中获取 CA 根证书和中间证书
- jquery - 如何修改我的代码以在数据表中有多个行标题?
- android - 添加 Firebase 数据时加载两次数据
- javascript - 如何正确绑定模型?
- google-cloud-platform - CORS 错误 - 响应标头中缺少 Access-Control-Allow-Origin(仅来自西班牙 IP)
- python - 在 Maya 场景中关联/引用 JSON 文件
- css - Bootstrap 4卡:删除空格
- android - 如何更改 BadgeDrawable Android 中的背景颜色