Увеличение изображения на GWT в определенном месте - PullRequest
0 голосов
/ 09 января 2019

Есть ли способ увеличить изображение GWT в определенном месте. Как на Google Maps. Если вы прокрутите ту часть, где находится указатель мыши, изображение будет увеличиваться в этом месте. Большое спасибо!

1 Ответ

0 голосов
/ 16 января 2019

Это делает трюк. На основании этого ответа JS . Полный исходный код здесь .

EventType.bind(document, wheel, new EventCallbackFn<WheelEvent>() {
    double[] pos = {0, 0};
    double scale = 1;
    @Override
    public void onEvent(WheelEvent ev) {
        ev.preventDefault();
        // cap the delta to [-1,1] for cross browser consistency
        double delta = Math.max(-1, Math.min(1, ev.deltaY / 200.));
        // determine the point on where the img is zoomed in
        double[] zoomTarget = {(ev.pageX - pos[0]) / scale, (ev.pageY - pos[1]) / scale};
        // calculate zoom and x and y based on it
        scale = Math.max(.1, Math.min(10, scale + delta * scale));
        pos[0] = -zoomTarget[0] * scale + ev.pageX;
        pos[1] = -zoomTarget[1] * scale + ev.pageY;
        target.style.transform = "translate(" + pos[0] + "px ," + pos[1] + "px) scale(" + scale + ")";
    }
});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...