diff options
Diffstat (limited to 'libview/ev-view.c')
| -rw-r--r-- | libview/ev-view.c | 48 | 
1 files changed, 37 insertions, 11 deletions
| diff --git a/libview/ev-view.c b/libview/ev-view.c index 3f90d610..118d51d3 100644 --- a/libview/ev-view.c +++ b/libview/ev-view.c @@ -4232,7 +4232,7 @@ position_caret_cursor_at_location (EvView *view,  	gint         offset = -1 ;  	gint         doc_x, doc_y;  	EvRectangle *rect; -	guint        i; +	guint        i, j;  	if (!view->caret_enabled || view->rotation != 0)  		return FALSE; @@ -4248,24 +4248,50 @@ position_caret_cursor_at_location (EvView *view,  	if (!areas)  		return FALSE; +	/* First look for the line of text at location */  	for (i = 0; i < n_areas; i++) {  		rect = areas + i; -		if (doc_x >= rect->x1 && doc_x <= rect->x2 && -		    doc_y >= rect->y1 && doc_y <= rect->y2) { -			/* Position the caret before or after the character, depending on whether -			   the point falls within the left or right half of the bounding box. */ -			if (doc_x <= rect->x1 + (rect->x2 - rect->x1) / 2) -				offset = i; -			else -				offset = i + 1; +		if (doc_y >= rect->y1 && doc_y <= rect->y2)  			break; -		}  	} -	if (offset == -1) +	if (i == n_areas)  		return FALSE; +	if (doc_x <= rect->x1) { +		/* Location is before the start of the line */ +		offset = i; +	} else { +		for (j = i; j < n_areas; j++) { +			rect = areas + j; + +			if (doc_y < rect->y1) { +				/* Location is after the end of the line */ +				offset = j; +				break; +			} + +			if (doc_x >= rect->x1 && doc_x <= rect->x2) { +				/* Location is inside the line. Position the caret before +				 * or after the character, depending on whether the point +				 * falls within the left or right half of the bounding box. +				 */ +				if (doc_x <= rect->x1 + (rect->x2 - rect->x1) / 2) +					offset = j; +				else +					offset = j + 1; +				break; +			} + +		} +	} + +	if (offset == -1) { +		/* This is the last line and loocation is after the end of the line */ +		offset = n_areas; +	} +  	if (view->cursor_offset != offset || view->cursor_page != page) {  		view->cursor_offset = offset;  		view->cursor_page = page; | 
