Разъединенный рисунок WebView в ICS - PullRequest
5 голосов
/ 05 декабря 2011

Я делаю приложение, в котором Webview встроен в другие элементы, вложенные в ScrollView.Я заметил, что в ICS при тестировании на устройстве Galaxy Nexus WebView, по-видимому, не отделяется от остальных отображаемых элементов при перемещении страницы, в результате чего WebView кажется плавающим из-за пары мсотставание в рисовании.Этого не происходит в 2.x версиях Android (не тестировался в 3.x).Вот видео с плавающим эффектом http://www.youtube.com/watch?v=avfBoWmooM4 (вы можете ясно видеть, если вы установите полноэкранный режим на 1080p)

Кто-нибудь может подсказать, почему это может произойти, или исправить?

Ниже я настроил тестовый проект, чтобы продемонстрировать:

package com.martynhaigh.floating_web_view;

import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.webkit.WebView;
import android.widget.FrameLayout;
import android.widget.LinearLayout;
import android.widget.ScrollView;
import android.widget.TextView;

public class FloatingWebViewTestActivity extends FragmentActivity {
    public final int viewId = 0x12345678;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        FrameLayout.LayoutParams lp = new FrameLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);
        FrameLayout frame = new FrameLayout(this);
        frame.setId(viewId);
        setContentView(frame, lp);

        FloatingWebViewICSFragment fragment = new FloatingWebViewICSFragment();
        getSupportFragmentManager().beginTransaction().add(viewId, fragment).commit();
    }

    public static class FloatingWebViewICSFragment extends Fragment {

        private final String htmlBody = "<html><body><p style=\"font-size:1.5em\">This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. This is a test document. </body></html>";

        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
        }

        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {

            TextView textView = new TextView(getActivity().getApplicationContext());
            textView.setText("Test Activity");

            WebView webView = new WebView(getActivity().getApplicationContext());
            webView.loadDataWithBaseURL("file:///android_asset/", htmlBody, "text/html", "UTF-8", "about:blank");
            webView.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY);
            webView.setScrollContainer(false);

            TextView textView2 = new TextView(getActivity().getApplicationContext());
            textView2.setText("Test Activity");

            FrameLayout.LayoutParams lp = new FrameLayout.LayoutParams(ViewGroup.LayoutParams.FILL_PARENT, ViewGroup.LayoutParams.FILL_PARENT);

            LinearLayout layout = new LinearLayout(getActivity().getApplicationContext());
            layout.setLayoutParams(lp);
            layout.setOrientation(LinearLayout.VERTICAL);

            layout.addView(textView);
            layout.addView(webView);
            layout.addView(textView2);

            ScrollView scrollView = new ScrollView(getActivity().getApplicationContext());
            scrollView.setLayoutParams(lp);
            scrollView.addView(layout);

            return scrollView;
        }

    }
}

1 Ответ

1 голос
/ 17 февраля 2012

Я не знаю, как это исправить, но я теперь причина.Содержимое WebView отображается в android.webkit.WebViewCore в отдельном рабочем потоке.Они общаются друг с другом.Когда WebView требуется повторный рендеринг, он отправляет сообщение «пожалуйста, рендеринг» в WebViewCore, а когда WVC готов, отправляет результат обратно.Дело в том, что их рендеринг не синхронизирован с рендерингом других элементов пользовательского интерфейса - как это делается в отдельном потоке, не являющемся пользовательским интерфейсом.

Я думаю, что они хотели избежать блокировки потока пользовательского интерфейса всемирендеринг усилий.Это очень добро.Но это вызывает другие проблемы ... как у вас.

...