私が提供する Unicode フォントをサポートするシンプルな Android Web ブラウザー アプリを開発したいと考えています。私はいくつかの調査を行いましたが、 android のカスタム フォントを追加する成功した方法を見つけることができませんでしたWebView
。にカスタム フォントを追加するための解決策がいくつかありますがWebView
、それらはすべて にフォントを追加することに基づいていCSS
ます。しかし、私は WebView 内にロードするページを制御できないため、..のWebView
likesetTypaFace()
メソッドにフォントを直接追加する方法はありTextView
ますか?
これまでにwebviewのカスタムフォントを追加するために使用したコードは次のとおりです。
package com.example.sinhalafontrendering;
import android.app.Activity;
import android.graphics.Typeface;
import android.os.Bundle;
import android.view.Menu;
import android.webkit.WebView;
import android.widget.TextView;
import com.example.sinhalafontrendering.R.id;
public class MainActivity extends Activity {
WebView mWebView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
FontUtils.setCustomFont(findViewById(id.txtHelloWorld), getAssets());
Typeface tf = Typeface.createFromAsset(getAssets(), "iskpota.ttf");
TextView tv = (TextView) findViewById(id.txtHelloWorld);
tv.setText("ශ්රී ලංකා, \n ");
//tv.setTypeface(tf,0);
String html = "<html><head><style type=\"text/css\">@font-face { font-family: MyCustomFont; src: url(\"Bamini.eot\") /* EOT file for IE */}@font-face { font-family: MyCustomFont; src: url(\"file:///android_asset/iskpota.ttf\") /* TTF file for CSS3 browsers */}body { font-family: MyCustomFont, Verdana, Arial, sans-serif;font-size: medium;color: black}</style></head><body><LI><a href=\"http://www.thelastrow.lk/\">ශ්රී ලංකා;</a></LI></UL></div></body></html>";
mWebView = (WebView) findViewById(R.id.webGoogle);
mWebView.getSettings().setJavaScriptEnabled(true);
mWebView.getSettings().setBuiltInZoomControls(true);
mWebView.getSettings().setSupportZoom(true);
//mWebView.loadUrl("file:///android_asset/a.html");
mWebView.loadDataWithBaseURL("www.thelastrow.lk", html, "text/html", "UTF-8", null);
mWebView.setWebViewClient(new HelloWebViewClient());
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
}