- Home ›
- Android入門 ›
- WebViewクラス ›
- HERE
画面の拡大縮小表示
WebViewに表示された画面の拡大や縮小して表示する方法を確認します。
拡大して表示するには「WebView」クラスで用意されている「zoomIn」メソッドを使います。
zoomIn public void zoomIn()
1段階拡大して表示します。
現在表示されているページを1段階拡大して表示します。実際に試してみたところ100%表示の状態から2段階まで拡大可能です。
縮小して表示するには「WebView」クラスで用意されている「zoomOut」メソッドを使います。
zoomOut public void zoomOut()
1段階縮小して表示します。
現在表示されているページを1段階縮小して表示します。実際に試してみたところ100%表示の状態から3段階まで縮小可能です。
また拡大や縮小された状態をリセットし、標準の倍率で表示するメソッドも用意されています。拡大率をリセットするには「WebView」クラスで用意されている「resetZoom」メソッドを使います。
resetZoom public void resetZoom()
拡大率をリセットします。
拡大や縮小が行われたいた場合には拡大率をリセットし100%の表示倍率で表示します。
具体的には次のように記述します。
@Override protected void onCreate(Bundle icicle) { super.onCreate(icicle); WebView webview = new WebView(this); /* ... */ webview.zoomOut(); }
サンプルプログラム
それでは実際に試してみます。プロジェクトを作成しソースコードを次のように変更しました。
package jp.javadrive.android; import android.app.Activity; import android.os.Bundle; import android.widget.LinearLayout; import android.view.View; import android.view.ViewGroup; import android.webkit.WebView; import android.widget.Button; import android.view.View.OnClickListener; public class Test05_01 extends Activity implements OnClickListener{ private final int FP = ViewGroup.LayoutParams.FILL_PARENT; private final int WC = ViewGroup.LayoutParams.WRAP_CONTENT; private Button buttonZoomin; private Button buttonZoomout; private Button buttonReset; private WebView webview; @Override protected void onCreate(Bundle icicle) { super.onCreate(icicle); LinearLayout linearLayout = new LinearLayout(this); linearLayout.setOrientation(LinearLayout.VERTICAL); setContentView(linearLayout); LinearLayout btnLinearLayout = new LinearLayout(this); btnLinearLayout.setOrientation(LinearLayout.HORIZONTAL); buttonZoomin = new Button(this); buttonZoomin.setText("Zoomin"); buttonZoomin.setOnClickListener(this); buttonZoomout = new Button(this); buttonZoomout.setText("Zoomout"); buttonZoomout.setOnClickListener(this); buttonReset = new Button(this); buttonReset.setText("Reset"); buttonReset.setOnClickListener(this); btnLinearLayout.addView(buttonZoomin, createParam(WC, WC)); btnLinearLayout.addView(buttonZoomout, createParam(WC, WC)); btnLinearLayout.addView(buttonReset, createParam(WC, WC)); webview = new WebView(this); webview.loadUrl("http://www.google.co.jp/"); linearLayout.addView(btnLinearLayout, createParam(FP, WC)); linearLayout.addView(webview, createParam(WC, WC)); } private LinearLayout.LayoutParams createParam(int w, int h){ return new LinearLayout.LayoutParams(w, h); } public void onClick(View v) { if (v == buttonZoomin){ webview.zoomIn(); }else if (v == buttonZoomout){ webview.zoomOut(); }else if (v == buttonReset){ webview.resetZoom(); } } }
ビルド後にエミュレーター上で実行します。
初期値として指定したURLが表示されます。
ではまず拡大から試していきます。「Zoomin」ボタンをクリックするたびに拡大されていきます。
「Reset」ボタンをクリックすると拡大されていない標準の倍率に戻ります。
次に縮小を試していきます。「Zoomout」ボタンをクリックするたびに縮小されていきます。
( Written by Tatsuo Ikura )