elm_entry: fix a bug in moving the magnifier

Summary:
When moving the magnifier in elm_entry, _magnifier_move
function occured infinite loop problem by calling
evas_object_move twice with different positions.
So, I changed it to call evas_object_move once.

ref T7202

Test Plan:
1. Set profile to "mobile"
2. elementary_test
3. entry
4. long press mouse button on elm_entry
5. when the magnifier is shown, try to move it

Reviewers: zmike, bu5hm4n, bowonryu, id213sin

Reviewed By: zmike

Subscribers: cedric, #reviewers, #committers

Tags: #efl

Maniphest Tasks: T7202

Differential Revision: https://phab.enlightenment.org/D8462
This commit is contained in:
WooHyun Jung 2019-03-25 08:52:10 -04:00 committed by Mike Blumenkrantz
parent 620eb070f4
commit d761658985
1 changed files with 4 additions and 3 deletions

View File

@ -1891,9 +1891,8 @@ _magnifier_move(void *data)
cx += ex;
cy += ey;
//Move the Magnifier
// calculate the position of the magnifier
edje_object_parts_extends_calc(sd->mgf_bg, &x, &y, &w, &h);
evas_object_move(sd->mgf_bg, cx - x - (w / 2), cy - y - h);
mx = cx - x - (w / 2);
my = cy - y - h;
@ -1920,9 +1919,11 @@ _magnifier_move(void *data)
my = 0;
if (my + mh > wh)
my = wh - mh;
evas_object_move(sd->mgf_bg, mx, my);
}
// move the magnifier to the proper position
evas_object_move(sd->mgf_bg, mx, my);
//Set the Proxy Render Area
evas_object_geometry_get(data, &x, &y, &w, &h);
evas_object_geometry_get(sd->mgf_proxy, &px, &py, &pw, &ph);