Fix #111031, reported by Padraig O'Briain:

2004-12-08  Matthias Clasen  <mclasen@redhat.com>

	Fix #111031, reported by Padraig O'Briain:

	* gtk/gtktextlayout.h:
	* gtk/gtktextlayout.c (gtk_text_layout_get_iter_at_position):
	Add a variant of gtk_text_layout_get_iter_at_pixel() which
	returns the character at the position, not the closest
	cursor position.

	* gtk/gtktextview.h:
	* gtk/gtktextview.c (gtk_text_view_get_iter_at_position):
	Add a variant of gtk_text_view_get_iter_at_location() which
	returns the character at the position, not the closest
	cursor position.
This commit is contained in:
Matthias Clasen 2004-12-08 21:25:08 +00:00 committed by Matthias Clasen
parent 456ebcea28
commit 057ab5a4df
10 changed files with 138 additions and 9 deletions

View File

@ -1,3 +1,19 @@
2004-12-08 Matthias Clasen <mclasen@redhat.com>
Fix #111031, reported by Padraig O'Briain:
* gtk/gtktextlayout.h:
* gtk/gtktextlayout.c (gtk_text_layout_get_iter_at_position):
Add a variant of gtk_text_layout_get_iter_at_pixel() which
returns the character at the position, not the closest
cursor position.
* gtk/gtktextview.h:
* gtk/gtktextview.c (gtk_text_view_get_iter_at_position):
Add a variant of gtk_text_view_get_iter_at_location() which
returns the character at the position, not the closest
cursor position.
2004-12-08 Matthias Clasen <mclasen@redhat.com> 2004-12-08 Matthias Clasen <mclasen@redhat.com>
* gtk/gtkaccelmap.c (internal_change_entry): Remove all * gtk/gtkaccelmap.c (internal_change_entry): Remove all

View File

@ -1,3 +1,19 @@
2004-12-08 Matthias Clasen <mclasen@redhat.com>
Fix #111031, reported by Padraig O'Briain:
* gtk/gtktextlayout.h:
* gtk/gtktextlayout.c (gtk_text_layout_get_iter_at_position):
Add a variant of gtk_text_layout_get_iter_at_pixel() which
returns the character at the position, not the closest
cursor position.
* gtk/gtktextview.h:
* gtk/gtktextview.c (gtk_text_view_get_iter_at_position):
Add a variant of gtk_text_view_get_iter_at_location() which
returns the character at the position, not the closest
cursor position.
2004-12-08 Matthias Clasen <mclasen@redhat.com> 2004-12-08 Matthias Clasen <mclasen@redhat.com>
* gtk/gtkaccelmap.c (internal_change_entry): Remove all * gtk/gtkaccelmap.c (internal_change_entry): Remove all

View File

@ -1,3 +1,19 @@
2004-12-08 Matthias Clasen <mclasen@redhat.com>
Fix #111031, reported by Padraig O'Briain:
* gtk/gtktextlayout.h:
* gtk/gtktextlayout.c (gtk_text_layout_get_iter_at_position):
Add a variant of gtk_text_layout_get_iter_at_pixel() which
returns the character at the position, not the closest
cursor position.
* gtk/gtktextview.h:
* gtk/gtktextview.c (gtk_text_view_get_iter_at_position):
Add a variant of gtk_text_view_get_iter_at_location() which
returns the character at the position, not the closest
cursor position.
2004-12-08 Matthias Clasen <mclasen@redhat.com> 2004-12-08 Matthias Clasen <mclasen@redhat.com>
* gtk/gtkaccelmap.c (internal_change_entry): Remove all * gtk/gtkaccelmap.c (internal_change_entry): Remove all

View File

@ -1,3 +1,19 @@
2004-12-08 Matthias Clasen <mclasen@redhat.com>
Fix #111031, reported by Padraig O'Briain:
* gtk/gtktextlayout.h:
* gtk/gtktextlayout.c (gtk_text_layout_get_iter_at_position):
Add a variant of gtk_text_layout_get_iter_at_pixel() which
returns the character at the position, not the closest
cursor position.
* gtk/gtktextview.h:
* gtk/gtktextview.c (gtk_text_view_get_iter_at_position):
Add a variant of gtk_text_view_get_iter_at_location() which
returns the character at the position, not the closest
cursor position.
2004-12-08 Matthias Clasen <mclasen@redhat.com> 2004-12-08 Matthias Clasen <mclasen@redhat.com>
* gtk/gtkaccelmap.c (internal_change_entry): Remove all * gtk/gtkaccelmap.c (internal_change_entry): Remove all

View File

@ -1,3 +1,7 @@
2004-12-08 Matthias Clasen <mclasen@redhat.com>
* gtk/gtk-sections.txt: Add gtk_text_view_get_iter_at_position.
2004-12-07 Matthias Clasen <mclasen@redhat.com> 2004-12-07 Matthias Clasen <mclasen@redhat.com>
* gtk/images/colorsel.png: * gtk/images/colorsel.png:

View File

@ -3216,6 +3216,7 @@ gtk_text_view_get_iter_location
gtk_text_view_get_line_at_y gtk_text_view_get_line_at_y
gtk_text_view_get_line_yrange gtk_text_view_get_line_yrange
gtk_text_view_get_iter_at_location gtk_text_view_get_iter_at_location
gtk_text_view_get_iter_at_position
gtk_text_view_buffer_to_window_coords gtk_text_view_buffer_to_window_coords
gtk_text_view_window_to_buffer_coords gtk_text_view_window_to_buffer_coords
gtk_text_view_get_window gtk_text_view_get_window

View File

@ -2277,11 +2277,25 @@ gtk_text_layout_get_line_at_y (GtkTextLayout *layout,
void void
gtk_text_layout_get_iter_at_pixel (GtkTextLayout *layout, gtk_text_layout_get_iter_at_pixel (GtkTextLayout *layout,
GtkTextIter *target_iter, GtkTextIter *target_iter,
gint x, gint y) gint x,
gint y)
{
gint trailing;
gtk_text_layout_get_iter_at_position (layout, target_iter, &trailing, x, y);
gtk_text_iter_forward_chars (target_iter, trailing);
}
void gtk_text_layout_get_iter_at_position (GtkTextLayout *layout,
GtkTextIter *target_iter,
gint *trailing,
gint x,
gint y)
{ {
GtkTextLine *line; GtkTextLine *line;
gint byte_index, trailing; gint byte_index;
gint line_top; gint line_top;
GtkTextLineDisplay *display; GtkTextLineDisplay *display;
@ -2301,7 +2315,7 @@ gtk_text_layout_get_iter_at_pixel (GtkTextLayout *layout,
if (y > display->height - display->top_margin - display->bottom_margin) if (y > display->height - display->top_margin - display->bottom_margin)
{ {
byte_index = _gtk_text_line_byte_count (line); byte_index = _gtk_text_line_byte_count (line);
trailing = 0; *trailing = 0;
} }
else else
{ {
@ -2310,14 +2324,15 @@ gtk_text_layout_get_iter_at_pixel (GtkTextLayout *layout,
* x-direction. * x-direction.
*/ */
pango_layout_xy_to_index (display->layout, x * PANGO_SCALE, y * PANGO_SCALE, pango_layout_xy_to_index (display->layout, x * PANGO_SCALE, y * PANGO_SCALE,
&byte_index, &trailing); &byte_index, trailing);
} }
line_display_index_to_iter (layout, display, target_iter, byte_index, trailing); line_display_index_to_iter (layout, display, target_iter, byte_index, 0);
gtk_text_layout_free_line_display (layout, display); gtk_text_layout_free_line_display (layout, display);
} }
/** /**
* gtk_text_layout_get_cursor_locations: * gtk_text_layout_get_cursor_locations:
* @layout: a #GtkTextLayout * @layout: a #GtkTextLayout

View File

@ -319,6 +319,11 @@ void gtk_text_layout_get_iter_at_pixel (GtkTextLayout *layout,
GtkTextIter *iter, GtkTextIter *iter,
gint x, gint x,
gint y); gint y);
void gtk_text_layout_get_iter_at_position (GtkTextLayout *layout,
GtkTextIter *iter,
gint *trailing,
gint x,
gint y);
void gtk_text_layout_invalidate (GtkTextLayout *layout, void gtk_text_layout_invalidate (GtkTextLayout *layout,
const GtkTextIter *start, const GtkTextIter *start,
const GtkTextIter *end); const GtkTextIter *end);

View File

@ -1297,9 +1297,44 @@ gtk_text_view_get_iter_at_location (GtkTextView *text_view,
gtk_text_view_ensure_layout (text_view); gtk_text_view_ensure_layout (text_view);
gtk_text_layout_get_iter_at_pixel (text_view->layout, gtk_text_layout_get_iter_at_pixel (text_view->layout,
iter, iter, x, y);
x, }
y);
/**
* gtk_text_view_get_iter_at_position:
* @text_view: a #GtkTextView
* @iter: a #GtkTextIter
* @trailing:
* @x: x position, in buffer coordinates
* @y: y position, in buffer coordinates
*
* Retrieves the iterator pointing to the character at buffer
* coordinates @x and @y. Buffer coordinates are coordinates for
* the entire buffer, not just the currently-displayed portion.
* If you have coordinates from an event, you have to convert
* those to buffer coordinates with
* gtk_text_view_window_to_buffer_coords().
*
* Note that this is diffferent from gtk_text_view_get_iter_at_location(),
* which returns cursor locations, i.e. positions <emphasis>between</emphasis>
* characters.
*
* Since: 2.6
**/
void
gtk_text_view_get_iter_at_position (GtkTextView *text_view,
GtkTextIter *iter,
gint *trailing,
gint x,
gint y)
{
g_return_if_fail (GTK_IS_TEXT_VIEW (text_view));
g_return_if_fail (iter != NULL);
gtk_text_view_ensure_layout (text_view);
gtk_text_layout_get_iter_at_position (text_view->layout,
iter, trailing, x, y);
} }
/** /**

View File

@ -250,6 +250,11 @@ void gtk_text_view_get_iter_at_location (GtkTextView *text_view,
GtkTextIter *iter, GtkTextIter *iter,
gint x, gint x,
gint y); gint y);
void gtk_text_view_get_iter_at_position (GtkTextView *text_view,
GtkTextIter *iter,
gint *trailing,
gint x,
gint y);
void gtk_text_view_get_line_yrange (GtkTextView *text_view, void gtk_text_view_get_line_yrange (GtkTextView *text_view,
const GtkTextIter *iter, const GtkTextIter *iter,
gint *y, gint *y,