|
Packit |
1470ea |
|
|
Packit |
1470ea |
<page xmlns="http://projectmallard.org/1.0/" xmlns:its="http://www.w3.org/2005/11/its" xmlns:xi="http://www.w3.org/2001/XInclude" type="guide" style="task" id="tooltip.py" xml:lang="ko">
|
|
Packit |
1470ea |
<info>
|
|
Packit |
1470ea |
<title type="text">Tooltip (Python)</title>
|
|
Packit |
1470ea |
<link type="guide" xref="beginner.py#misc"/>
|
|
Packit |
1470ea |
<link type="seealso" xref="toolbar.py"/>
|
|
Packit |
1470ea |
<link type="next" xref="toolbar_builder.py"/>
|
|
Packit |
1470ea |
<revision version="0.1" date="2012-08-20" status="draft"/>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
<credit type="author copyright">
|
|
Packit |
1470ea |
<name>Marta Maria Casetti</name>
|
|
Packit |
1470ea |
<email its:translate="no">mmcasetti@gmail.com</email>
|
|
Packit |
1470ea |
<years>2012</years>
|
|
Packit |
1470ea |
</credit>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
<desc>위젯에 도움말을 추가합니다</desc>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
<mal:credit xmlns:mal="http://projectmallard.org/1.0/" type="translator copyright">
|
|
Packit |
1470ea |
<mal:name>조성호</mal:name>
|
|
Packit |
1470ea |
<mal:email>shcho@gnome.org</mal:email>
|
|
Packit |
1470ea |
<mal:years>2017</mal:years>
|
|
Packit |
1470ea |
</mal:credit>
|
|
Packit |
1470ea |
</info>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
<title>Tooltip</title>
|
|
Packit |
1470ea |
<media type="image" mime="image/png" src="media/tooltip.png"/>
|
|
Packit |
1470ea |
단추에 풍선 도움말(및 그림)을 넣은 도구 모음입니다.
|
|
Packit |
1470ea |
<note>이 예제는 <link xref="toolbar.py">도구 모음</link> 예제로 만듭니다. </note>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
<links type="section"/>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
<section id="code">
|
|
Packit |
1470ea |
<title>예제 결과를 만드는 코드</title>
|
|
Packit |
1470ea |
from gi.repository import Gtk
|
|
Packit |
1470ea |
from gi.repository import Gdk
|
|
Packit |
1470ea |
from gi.repository import Gio
|
|
Packit |
1470ea |
import sys
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
class MyWindow(Gtk.ApplicationWindow):
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
def __init__(self, app):
|
|
Packit |
1470ea |
Gtk.Window.__init__(
|
|
Packit |
1470ea |
self, title="Toolbar with Tooltips Example", application=app)
|
|
Packit |
1470ea |
self.set_default_size(400, 200)
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
grid = Gtk.Grid()
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
toolbar = self.create_toolbar()
|
|
Packit |
1470ea |
toolbar.set_hexpand(True)
|
|
Packit |
1470ea |
toolbar.show()
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
grid.attach(toolbar, 0, 0, 1, 1)
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
self.add(grid)
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
undo_action = Gio.SimpleAction.new("undo", None)
|
|
Packit |
1470ea |
undo_action.connect("activate", self.undo_callback)
|
|
Packit |
1470ea |
self.add_action(undo_action)
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
fullscreen_action = Gio.SimpleAction.new("fullscreen", None)
|
|
Packit |
1470ea |
fullscreen_action.connect("activate", self.fullscreen_callback)
|
|
Packit |
1470ea |
self.add_action(fullscreen_action)
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
def create_toolbar(self):
|
|
Packit |
1470ea |
toolbar = Gtk.Toolbar()
|
|
Packit |
1470ea |
toolbar.get_style_context().add_class(Gtk.STYLE_CLASS_PRIMARY_TOOLBAR)
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
# button for the "new" action
|
|
Packit |
1470ea |
new_button = Gtk.ToolButton.new_from_stock(Gtk.STOCK_NEW)
|
|
Packit |
1470ea |
# with a tooltip with a given text
|
|
Packit |
1470ea |
new_button.set_tooltip_text("Create a new file")
|
|
Packit |
1470ea |
new_button.set_is_important(True)
|
|
Packit |
1470ea |
toolbar.insert(new_button, 0)
|
|
Packit |
1470ea |
new_button.show()
|
|
Packit |
1470ea |
new_button.set_action_name("app.new")
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
# button for the "open" action
|
|
Packit |
1470ea |
open_button = Gtk.ToolButton.new_from_stock(Gtk.STOCK_OPEN)
|
|
Packit |
1470ea |
# with a tooltip with a given text in the Pango markup language
|
|
Packit |
1470ea |
open_button.set_tooltip_markup("Open an <i>existing</i> file")
|
|
Packit |
1470ea |
open_button.set_is_important(True)
|
|
Packit |
1470ea |
toolbar.insert(open_button, 1)
|
|
Packit |
1470ea |
open_button.show()
|
|
Packit |
1470ea |
open_button.set_action_name("app.open")
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
# button for the "undo" action
|
|
Packit |
1470ea |
undo_button = Gtk.ToolButton.new_from_stock(Gtk.STOCK_UNDO)
|
|
Packit |
1470ea |
# with a tooltip with an image
|
|
Packit |
1470ea |
# set True the property "has-tooltip"
|
|
Packit |
1470ea |
undo_button.set_property("has-tooltip", True)
|
|
Packit |
1470ea |
# connect to the callback function that for the tooltip
|
|
Packit |
1470ea |
# with the signal "query-tooltip"
|
|
Packit |
1470ea |
undo_button.connect("query-tooltip", self.undo_tooltip_callback)
|
|
Packit |
1470ea |
undo_button.set_is_important(True)
|
|
Packit |
1470ea |
toolbar.insert(undo_button, 2)
|
|
Packit |
1470ea |
undo_button.show()
|
|
Packit |
1470ea |
undo_button.set_action_name("win.undo")
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
# button for the "fullscreen/leave fullscreen" action
|
|
Packit |
1470ea |
self.fullscreen_button = Gtk.ToolButton.new_from_stock(
|
|
Packit |
1470ea |
Gtk.STOCK_FULLSCREEN)
|
|
Packit |
1470ea |
self.fullscreen_button.set_is_important(True)
|
|
Packit |
1470ea |
toolbar.insert(self.fullscreen_button, 3)
|
|
Packit |
1470ea |
self.fullscreen_button.set_action_name("win.fullscreen")
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
return toolbar
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
# the callback function for the tooltip of the "undo" button
|
|
Packit |
1470ea |
def undo_tooltip_callback(self, widget, x, y, keyboard_mode, tooltip):
|
|
Packit |
1470ea |
# set the text for the tooltip
|
|
Packit |
1470ea |
tooltip.set_text("Undo your last action")
|
|
Packit |
1470ea |
# set an icon fot the tooltip
|
|
Packit |
1470ea |
tooltip.set_icon_from_stock("gtk-undo", Gtk.IconSize.MENU)
|
|
Packit |
1470ea |
# show the tooltip
|
|
Packit |
1470ea |
return True
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
def undo_callback(self, action, parameter):
|
|
Packit |
1470ea |
print("You clicked \"Undo\".")
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
def fullscreen_callback(self, action, parameter):
|
|
Packit |
1470ea |
is_fullscreen = self.get_window().get_state(
|
|
Packit |
1470ea |
) & Gdk.WindowState.FULLSCREEN != 0
|
|
Packit |
1470ea |
if not is_fullscreen:
|
|
Packit |
1470ea |
self.fullscreen_button.set_stock_id(Gtk.STOCK_LEAVE_FULLSCREEN)
|
|
Packit |
1470ea |
self.fullscreen()
|
|
Packit |
1470ea |
else:
|
|
Packit |
1470ea |
self.fullscreen_button.set_stock_id(Gtk.STOCK_FULLSCREEN)
|
|
Packit |
1470ea |
self.unfullscreen()
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
class MyApplication(Gtk.Application):
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
def __init__(self):
|
|
Packit |
1470ea |
Gtk.Application.__init__(self)
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
def do_activate(self):
|
|
Packit |
1470ea |
win = MyWindow(self)
|
|
Packit |
1470ea |
win.show_all()
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
def do_startup(self):
|
|
Packit |
1470ea |
Gtk.Application.do_startup(self)
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
new_action = Gio.SimpleAction.new("new", None)
|
|
Packit |
1470ea |
new_action.connect("activate", self.new_callback)
|
|
Packit |
1470ea |
app.add_action(new_action)
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
open_action = Gio.SimpleAction.new("open", None)
|
|
Packit |
1470ea |
open_action.connect("activate", self.open_callback)
|
|
Packit |
1470ea |
app.add_action(open_action)
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
def new_callback(self, action, parameter):
|
|
Packit |
1470ea |
print("You clicked \"New\".")
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
def open_callback(self, action, parameter):
|
|
Packit |
1470ea |
print("You clicked \"Open\".")
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
app = MyApplication()
|
|
Packit |
1470ea |
exit_status = app.run(sys.argv)
|
|
Packit |
1470ea |
sys.exit(exit_status)
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
</section>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
<section id="methods">
|
|
Packit |
1470ea |
<title>Tooltip 위젯에 쓸만한 메서드</title>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
set_tooltip_text(text) 함수와 set_tooltip_markup(text) 함수는 일반 텍스트(또는 팡고 마크업 언어 텍스트) 풍선 도움말을 위젯에 추가할 때 활용할 수 있습니다.
|
|
Packit |
1470ea |
더 복잡한 풍선 도움말은, 그림 위의 풍선 도움말을 예로 들 수 있습니다:
|
|
Packit |
1470ea |
<steps>
|
|
Packit |
1470ea |
<item>위젯의 "has-tooltip" 속성을 True 값으로 설정하십시오. GTK+에서 풍선 도움말을 보여줄 때와 위치를 결정할 때 필요한 위젯의 움직임과 관련 이벤트를 지겨보게합니다. </item>
|
|
Packit |
1470ea |
<item>"query-tooltip" 시그널에 연결하십시오. 이 시그널은 풍선 도움말을 나타낼 때 내보냅니다. 시그널 핸들러에 보내는 인자 중 하나는 GtkTooptip 객체입니다. 우리가 풍선 도움말로 나타내려는 객체고, set_icon() 같은 함수로 다룰 수 있습니다. 풍선 도움말의 마크업을 설정(set_markup(text) ), 스톡 아이콘으로 그림을 설정(set_icon_from_stock(stock_id, size) ), 또는 개별 위젯을 두는(set_custom(widget) ) 몇가지 함수가 있습니다. </item>
|
|
Packit |
1470ea |
<item>query-tooltip 핸들러에서 True 값을 반환하십시오. 풍선 도움말을 나타냅니다. False 값을 반환하면 풍선 도움말이 나타나지 않습니다. </item>
|
|
Packit |
1470ea |
</steps>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
풍선 도움말이 나타날 때 즈음에 풍선 도움말에 대해 뭔가를 더 다루는 경우는 흔하지 않는데, 이 경우 풍선 도움말 창으로 활용할 GtkWindow를 설정할 수 있습니다. 다음과 같이 하시면 됩니다:
|
|
Packit |
1470ea |
<steps>
|
|
Packit |
1470ea |
<item>"has-tooltip" 을 설정하고 이전과 같이 "query-tooltip" 에 연결하십시오. </item>
|
|
Packit |
1470ea |
<item>풍선 도움말 창으로 만든 GTKWindow를 설정하려면 set_tooltip_window() 함수를 위젯에서 사용하십시오. </item>
|
|
Packit |
1470ea |
<item>"query-tooltip" 콜백에서는 get_tooltip_window() 함수로 창에 접근할 수 있고 원하는대로 조절할 수 있습니다. 반환값 의미는 이전에 언급한 바와 같습니다. True 반환 값은 창을 나타내고 False 값은 창을 나타내지 않습니다. </item>
|
|
Packit |
1470ea |
</steps>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
</section>
|
|
Packit |
1470ea |
|
|
Packit |
1470ea |
<section id="references">
|
|
Packit |
1470ea |
<title>API 참고서</title>
|
|
Packit |
1470ea |
이 예제는 다음 참고자료가 필요합니다:
|
|
Packit |
1470ea |
<list>
|
|
Packit |
1470ea |
<item><link href="http://developer.gnome.org/gtk3/stable/GtkTooltip.html">GtkTooltip</link> </item>
|
|
Packit |
1470ea |
<item><link href="http://developer.gnome.org/gtk3/stable/GtkToolbar.html">GtkToolbar</link> </item>
|
|
Packit |
1470ea |
<item><link href="http://developer.gnome.org/gtk3/stable/GtkWidget.html">GtkWidget</link> </item>
|
|
Packit |
1470ea |
<item><link href="http://developer.gnome.org/gtk3/stable/gtk3-Stock-Items.html">취급 항목</link> </item>
|
|
Packit |
1470ea |
</list>
|
|
Packit |
1470ea |
</section>
|
|
Packit |
1470ea |
</page>
|