mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2024-12-25 05:01:09 +00:00
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:
parent
456ebcea28
commit
057ab5a4df
16
ChangeLog
16
ChangeLog
@ -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>
|
||||
|
||||
* gtk/gtkaccelmap.c (internal_change_entry): Remove all
|
||||
|
@ -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>
|
||||
|
||||
* gtk/gtkaccelmap.c (internal_change_entry): Remove all
|
||||
|
@ -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>
|
||||
|
||||
* gtk/gtkaccelmap.c (internal_change_entry): Remove all
|
||||
|
@ -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>
|
||||
|
||||
* gtk/gtkaccelmap.c (internal_change_entry): Remove all
|
||||
|
@ -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>
|
||||
|
||||
* gtk/images/colorsel.png:
|
||||
|
@ -3216,6 +3216,7 @@ gtk_text_view_get_iter_location
|
||||
gtk_text_view_get_line_at_y
|
||||
gtk_text_view_get_line_yrange
|
||||
gtk_text_view_get_iter_at_location
|
||||
gtk_text_view_get_iter_at_position
|
||||
gtk_text_view_buffer_to_window_coords
|
||||
gtk_text_view_window_to_buffer_coords
|
||||
gtk_text_view_get_window
|
||||
|
@ -2277,11 +2277,25 @@ gtk_text_layout_get_line_at_y (GtkTextLayout *layout,
|
||||
|
||||
void
|
||||
gtk_text_layout_get_iter_at_pixel (GtkTextLayout *layout,
|
||||
GtkTextIter *target_iter,
|
||||
gint x, gint y)
|
||||
GtkTextIter *target_iter,
|
||||
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;
|
||||
gint byte_index, trailing;
|
||||
gint byte_index;
|
||||
gint line_top;
|
||||
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)
|
||||
{
|
||||
byte_index = _gtk_text_line_byte_count (line);
|
||||
trailing = 0;
|
||||
*trailing = 0;
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -2310,14 +2324,15 @@ gtk_text_layout_get_iter_at_pixel (GtkTextLayout *layout,
|
||||
* x-direction.
|
||||
*/
|
||||
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_get_cursor_locations:
|
||||
* @layout: a #GtkTextLayout
|
||||
|
@ -319,6 +319,11 @@ void gtk_text_layout_get_iter_at_pixel (GtkTextLayout *layout,
|
||||
GtkTextIter *iter,
|
||||
gint x,
|
||||
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,
|
||||
const GtkTextIter *start,
|
||||
const GtkTextIter *end);
|
||||
|
@ -1297,9 +1297,44 @@ gtk_text_view_get_iter_at_location (GtkTextView *text_view,
|
||||
gtk_text_view_ensure_layout (text_view);
|
||||
|
||||
gtk_text_layout_get_iter_at_pixel (text_view->layout,
|
||||
iter,
|
||||
x,
|
||||
y);
|
||||
iter, 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);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -250,6 +250,11 @@ void gtk_text_view_get_iter_at_location (GtkTextView *text_view,
|
||||
GtkTextIter *iter,
|
||||
gint x,
|
||||
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,
|
||||
const GtkTextIter *iter,
|
||||
gint *y,
|
||||
|
Loading…
Reference in New Issue
Block a user