26

There's a method for altering background color but not font.
Any ideas?

Tim Cooper
  • 151,519
  • 37
  • 317
  • 271
yanchenko
  • 55,355
  • 33
  • 144
  • 163

8 Answers8

38

something like

String text = "<html><head>"
          + "<style type=\"text/css\">body{color: #fff; background-color: #000;}"
          + "</style></head>"
          + "<body>"                          
          + your_string_text_here
          + "</body></html>";

webview1.loadData(text, "text/html", "utf-8");
OWADVL
  • 9,777
  • 6
  • 53
  • 67
21

I had to put it in the onPageFinished method.

_webView.setWebViewClient(new WebViewClient() {
    public void onPageFinished(WebView view, String url) {
        _webView.loadUrl(
            "javascript:document.body.style.setProperty(\"color\", \"white\");"
        );
    }
});
djunod
  • 4,698
  • 2
  • 29
  • 28
12

I'm not sure I understand. The WebView just displays the HTML you give it so you would just use normal HTML/CSS to modify the content displayed within.

MattC
  • 12,193
  • 10
  • 53
  • 77
  • Sure, but I'd like to do that w/o modifying the underlying html. – yanchenko Aug 10 '09 at 17:14
  • Is the underlying HTML something from a third party? You could always inject javascript at the end that will modify it and then call the javascript from the Activity itself doing wvMyWebView.loadUrl("call javascript function here"); – MattC Aug 10 '09 at 18:05
  • @MattC what if you change the app theme and you want to see changes instantly. – Faisal Shaikh Jul 08 '20 at 00:52
11

This worked for me

myWebView.getSettings().setJavaScriptEnabled(true);
myWebView.setWebViewClient(new WebViewClient() {
public void onPageFinished(WebView view, String url) {
    view.loadUrl(
        "javascript:document.body.style.setProperty(\"color\", \"white\");"
    );
  }
});
Ismail Iqbal
  • 2,512
  • 1
  • 22
  • 44
6

This is the easiest way I found (change the text color to white for example):

webview.loadUrl("javascript:document.body.style.color=\"white\";");
RafaelJan
  • 2,314
  • 23
  • 36
2

@rafraph's answer didn't work for me. I had to use

webView.loadUrl("javascript:document.body.style.setProperty(\"color\", \"white\");");
Jess Smith
  • 167
  • 1
  • 8
2

When the buffer is SPANNABLE, modifying the HTML directly is an ideal solution. The font, color, typeface, style can all be affected through HTML:

String szMessage = "<font face='trebuchet' size=30><a href=zz><b>click me</b></a></font>";

TextView tv = (TextView)findViewById(R.id.tv_message);
tv.setText(Html.fromHtml(szMessage), BufferType.SPANNABLE);
paiego
  • 3,495
  • 32
  • 38
1

You can concatenate your answer one body tag HTML with CSS style hex color, this is an example using a JSON response

First: function for decode JSON to HTML format

public String stripHtml(String html) {
    return Html.fromHtml(html).toString();
}

Second: Load data in WebView (no url)

 String string_html;
 string_html = "&lt;body style=&quot;color:#535362;&quot;&gt;" + youStringHTML + "&lt;/body&gt;";
 webView.loadDataWithBaseURL(null, stripHtml(string_html), "text/html", "utf-8", null);
Vladimir Salguero
  • 5,057
  • 3
  • 40
  • 44