Форум программистов, компьютерный форум, киберфорум
Наши страницы

WebView белое поле снизу - Программирование Android

Войти
Регистрация
Восстановить пароль
Другие темы раздела
Программирование Android AttributeSet http://www.cyberforum.ru/android-dev/thread1617611.html
что означает класс AttributeSet в java под андроид?
Программирование Android Хочу попробовать писать под Android - выбор языка? Языков особо не знаю никаких, так что в каком-то смысле все равно с чего начинать :) Понимаю, что нативная Java. Но, честно говоря, ее не хочется изучать, да и ООП вообще как таковое. C# не... http://www.cyberforum.ru/android-dev/thread1617396.html
Программа для прямого эфира Программирование Android
сложно ли создать программу для прямого эфира на андроид подскажите пожалуйста Добавлено через 6 минут очень надо если кто сделает готов заплатить
Программирование Android Delphi XE5 Android
Здравствуйте, создала приложение на свой планшет в Delphi XE5, суть приложения заключается в том, что выполняет арифметические действия с числами в разных сс.При компиляции этого приложения на ПК всё...
Программирование Android Парсинг JSON-строки и вывод данных из строки http://www.cyberforum.ru/android-dev/thread1617051.html
Добрый день! Я разрабатываю Android-клиент, который мог бы обмениваться данными с размещенной WCf-службой. Для чтения данных из службы в клиенте, я конвертирую данные из службы в json-строку, как...
Программирование Android Push уведомления Добрый день, я полный новиЧег в программировании.И мне необходимо сделать так что бы приложение выбирало 1 пуш из нескольких и выводило его на экран. Все что мне удалось сделать это выводить один... подробнее

Показать сообщение отдельно
Никита Гриб
2 / 2 / 0
Регистрация: 10.08.2014
Сообщений: 36

WebView белое поле снизу - Программирование Android

18.12.2015, 13:59. Просмотров 616. Ответов 21
Метки (Все метки)

Здравствуйте форумчане. Прошу у вас помощи так как сам уже два дня не могу понять в чём проблема.
Проблема в следующем. Есть WebView. Как только я кладу туда html всё хорошо красиво укладывается. Но вот если повернуть экран или поменять шрифт с крупного на мелкий. То снизу появляется много белого пространства. В чём может быть проблема . Спасибо за помощь
Скриншоты
http://cs3-3.4pda.to/7263278/Screens...c62ff3b885e0a0
http://cs3-2.4pda.to/7263282/Screens...dc50cae7db118f
http://cs4-1.4pda.to/7263285/Screens...1beb499669adb1
Код
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
public class NewsActivity extends AppCompatActivity {
 
    private VideoEnabledWebView web;
    private Toolbar toolbar;
    private String mime = "text/html";
    private String encoding = "utf-8";
    private VideoEnabledWebChromeClient webChromeClient;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_news);
 
        toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
        getSupportActionBar().setDisplayShowTitleEnabled(false);
        web = (VideoEnabledWebView) findViewById(R.id.webView);
        View nonVideoLayout = findViewById(R.id.nonVideoLayout);
        ViewGroup videoLayout = (ViewGroup) findViewById(R.id.videoLayout);
        View loadingView = getLayoutInflater().inflate(R.layout.view_loading_video, null);
 
        webChromeClient = new VideoEnabledWebChromeClient(nonVideoLayout, videoLayout, loadingView, web)
        {
            @Override
            public void onProgressChanged(WebView view, int progress) {
            }
        };
        webChromeClient.setOnToggledFullscreen(new VideoEnabledWebChromeClient.ToggledFullscreenCallback() {
            @Override
            public void toggledFullscreen(boolean fullscreen) {
                // Your code to handle the full-screen change, for example showing and hiding the title bar. Example:
                if (fullscreen) {
                    getSupportActionBar().hide();
                    WindowManager.LayoutParams attrs = getWindow().getAttributes();
                    attrs.flags |= WindowManager.LayoutParams.FLAG_FULLSCREEN;
                    attrs.flags |= WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON;
                    getWindow().setAttributes(attrs);
                    if (android.os.Build.VERSION.SDK_INT >= 14) {
                        //noinspection all
                        getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LOW_PROFILE);
                    }
                } else {
                    getSupportActionBar().show();
                    WindowManager.LayoutParams attrs = getWindow().getAttributes();
                    attrs.flags &= ~WindowManager.LayoutParams.FLAG_FULLSCREEN;
                    attrs.flags &= ~WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON;
                    getWindow().setAttributes(attrs);
                    if (android.os.Build.VERSION.SDK_INT >= 14) {
                        //noinspection all
                        getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_VISIBLE);
                    }
                }
 
            }
        });
        web.setWebChromeClient(webChromeClient);
        web.getSettings().setPluginState(WebSettings.PluginState.ON);
        web.getSettings().setJavaScriptEnabled(true);
        setTextSizeWebView(getTextSize());
 
        MineAsynctask as = new MineAsynctask();
        as.execute("http://www.eminem.pro/eproapi/get_post/?id=" + getUrlFromIntent());
 
 
    }
 
    public void setTextSizeWebView(int textSize) {
        switch (textSize) {
            case Constants.TEXT_SIZE_SMALL:
                web.getSettings().setTextSize(WebSettings.TextSize.SMALLEST);
                break;
            case Constants.TEXT_SIZE_NORMAL:
                web.getSettings().setTextSize(WebSettings.TextSize.NORMAL);
                break;
            case Constants.TEXT_SIZE_LARGE:
                web.getSettings().setTextSize(WebSettings.TextSize.LARGER);
                break;
        }
    }
 
    public int getTextSize() {
        int textSize = SharedPrefTextFormat.getInstance(this).getTextSize();
        if (textSize == 0) {
            SharedPrefTextFormat.getInstance(this).putNextTextSize();
            return SharedPrefTextFormat.getInstance(this).getTextSize();
        } else {
            return textSize;
        }
    }
 
    @Override
    public void onBackPressed() {
        // Notify the VideoEnabledWebChromeClient, and handle it ourselves if it doesn't handle it
        if (!webChromeClient.onBackPressed()) {
            if (web.canGoBack()) {
                web.goBack();
            } else {
                // Standard back button implementation (for example this could close the app)
                super.onBackPressed();
            }
        }
    }
 
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        MenuInflater inflater = getMenuInflater();
        inflater.inflate(R.menu.menu_web, menu);
        return true;
    }
 
    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        switch (item.getItemId()) {
            case R.id.action_text_format:
                SharedPrefTextFormat.getInstance(this).putNextTextSize();
                setTextSizeWebView(getTextSize());
                return false;
            case R.id.action_link:
                Intent sharingIntent = new Intent(android.content.Intent.ACTION_SEND);
                sharingIntent.setType("text/plain");
                String shareBody = "Here is the share content body";
                sharingIntent.putExtra(android.content.Intent.EXTRA_SUBJECT, "Subject Here");
                sharingIntent.putExtra(android.content.Intent.EXTRA_TEXT, shareBody);
                startActivity(Intent.createChooser(sharingIntent, "Share via"));
                return false;
            default:
                break;
        }
 
        return false;
    }
 
 
    private int getUrlFromIntent() {
        Bundle extras = getIntent().getExtras();
        int idNews = 0;
        if (extras != null) {
            idNews = extras.getInt("KEY_ID");
        }
        return idNews;
    }
 
    class MineAsynctask extends AsyncTask<String, Void, Void> {
 
        String parseHtml = null;
 
        @Override
        protected void onPreExecute() {
            Log.d("Asynctask", "Start");
 
        }
 
        @Override
        protected Void doInBackground(String... params) {
 
            downloadListNews(params[0]);
 
            return null;
        }
 
 
        public void downloadListNews(String url) {
 
            JSONArray array = null;
            JSONObject obj = null;
            try {
                obj = new JSONObject(makeServiceCall(url)); //Jsoup.connect("http://www.eminem.pro/eproapi/get_post/?id=21659").get().toString()
                array = obj.getJSONArray("content");
 
            } catch (JSONException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
 
            for (int i = 0; i < array.length(); i++) {
 
                try {
                    parseHtml = array.getJSONObject(i).get("content").toString();
                    Log.d("PARSER2", parseHtml);
                } catch (JSONException e) {
                    e.printStackTrace();
                }
            }
        }
 
        public String makeServiceCall(String url1) throws IOException {
            InputStream is = null;
 
            URL url = new URL(url1);
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            conn.setReadTimeout(10000 /* milliseconds */);
            conn.setConnectTimeout(15000 /* milliseconds */);
            conn.setRequestMethod("GET");
            conn.setDoInput(true);
            // Starts the query
            conn.connect();
            is = conn.getInputStream();
            StringWriter writer = new StringWriter();
            IOUtils.copy(is, writer, encoding);
            String contentAsString = writer.toString();
 
            return contentAsString;
        }
 
        @Override
        protected void onPostExecute(Void ignore) {
            parseHtml = "<link rel="stylesheet" type="text/css" href="style.css" />" + parseHtml;
            web.loadDataWithBaseURL("file:///android_asset/", parseHtml, mime, encoding, null);
        }
    }
 
 
}
XML
XML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.themobilebakery.isus.gui.WebViewActivity">
 
 
 
    <android.support.v4.widget.NestedScrollView
        android:id="@+id/nonVideoLayout"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">
 
 
        <example.kinder.eminem_pro.VideoEnabledWebView
            android:id="@+id/webView"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
 
    </android.support.v4.widget.NestedScrollView>
 
    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
 
 
        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="?attr/colorPrimary"
            android:minHeight="0dp"
            app:layout_scrollFlags="scroll|enterAlways">
 
 
            <ImageView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:background="@drawable/ic_back_api" />
 
        </android.support.v7.widget.Toolbar>
 
    </android.support.design.widget.AppBarLayout>
 
    <RelativeLayout
        android:id="@+id/videoLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        >
 
        <!-- View that will be shown while the fullscreen video loads. For example you could include
        a "Loading..." message. However, in this particular example this view is actually defined in
        view_loading_video.xml and inflated programmatically in ExampleActivity.java. The reason for
        this is to keep the main layout (this file) cleaner. -->
        <!-- <View
            android:id="@+id/videoLoading"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerInParent="true"
            android:visibility="invisible" /> -->
 
    </RelativeLayout>
 
 
</android.support.design.widget.CoordinatorLayout>
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru