我目前使用 cairo/pango 从动态文本生成原始图像数据。我的应用程序不是 Gtk+ GUI 应用程序,只是本机 C++ 无头视频服务器。使用动态文本,我为叠加层生成原始图像,然后将它们与服务器处理并通过网络分发的视频流进行 alpha 混合。该文本不涉及文本编辑,但给定文本,我会生成适合 Alpha 混合的相应图像叠加层。
但是,我需要更多的格式灵活性(缩进、中心对齐等)。在 cairo/pango 中进行大量格式化是很痛苦的。
我一直在研究 GtkTextView/GtkTextBuffer API,我认为使用 GtkTextTag 更容易格式化。这些小部件显然具有广泛的编辑功能,但我只需要格式化功能。
问题:我可以在不通过 gtk_init()/gtk_main() 运行主 gtk+ 循环的情况下使用 GtkTextView/GtkTextBuffer/GtkTextTag吗?
问题:在所有标签都格式化文本后,如何获取对原始格式化缓冲区(cairo 图像表面或小部件 pixbuf)的引用?
我一直在使用 gtk_widget_get_pango_context()、pango_layout_new()、gtk_widget_create_pango_layout() 等例程,但由于没有屏幕而出现各种错误。
编辑:附加信息:我要做的基本上是仅使用 GtkTextView/GtkTextBuffer/GtkTextTag 例程作为一种独立库,用于生成渲染和格式化文本的图像数据。
谢谢,-安德烈斯