如何以固定的宽度和高度显示Webview

时间:2014-08-28 13:55:53

标签: java android layout webview

抱歉,我一直在搜索这个论坛并且没有得到确切答案。所以我问自己。

我有一个显示两个布局的类,glView和webview,目标人像屏幕为640x960。我打算拆分布局。所以看起来我的背景画在(0,0,640,480)或画像屏幕的一半。 ,我希望我的webview绘制在(0,481,640,479),从中间到底部占据另一半。然而,我失败了,无法弄清楚如何实现我想要的布局。如何设置webView大小&位置?

PS:如果我将布局设置为对齐底部,那么webview确实处于中间到底部的位置,但是我需要指定确切的位置..而且最差..当它加载url时,它将使用整个屏幕,覆盖我的所有第一个布局,我迷路了。那么如何让webview将加载的url显示到webview指定的宽度和高度。

谢谢你...抱歉我的英语不好。

无论如何,这是我的代码(我以编程方式创建,我没有使用任何xml布局)

    glView = new GLSurfaceView(this);
    glView.setRenderer(this);
    glView.setZOrderMediaOverlay(false);
    layout = new RelativeLayout(this);
    layout.addView(glView);
    webView = new WebView(this);    
    this.showWV(false); //handler message , i hide it in certain screen.

    //webView.getSettings().setJavaScriptEnabled(true);
    webView.getSettings().setLoadWithOverviewMode(true);
    webView.getSettings().setUseWideViewPort(true);

    webView.loadUrl("http://stackoverflow.com");

    RelativeLayout.LayoutParams params =
       new RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.WRAP_CONTENT,
             RelativeLayout.LayoutParams.WRAP_CONTENT);

    params.addRule(RelativeLayout.ALIGN_PARENT_BOTTOM);

    layout.addView(webView, params);

    setContentView(layout);

2 个答案:

答案 0 :(得分:1)

您可以使用LinearLayout代替RelativeLayout来分割屏幕。只需设置{= 1}}和GLSurfaceView的高度= 0和权重= 1。在您的情况下,代码将是:

WebView

或者您可以将LinearLayout layout = new LinearLayout(this); // Use LinearLayout instead of Relative glView = new GLSurfaceView(this); glView.setRenderer(this); glView.setZOrderMediaOverlay(false); // height is 0, weight is 1 LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, 0, 1); layout.addView(glView, params); webView = new WebView(this); this.showWV(false); //handler message , i hide it in certain screen. webView.getSettings().setJavaScriptEnabled(true); webView.getSettings().setLoadWithOverviewMode(true); webView.getSettings().setUseWideViewPort(true); // height is 0, weight is 1 params = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, 0, 1); layout.addView(webView, params); webView.loadUrl("http://stackoverflow.com"); setContentView(layout); 与硬编码的高度和宽度值结合使用:

RelativeLayout

<强> UPD: 没有硬编码值,使用不可见的视图:

RelativeLayout layout = new RelativeLayout(this); // Use LinearLayout instead of Relative

glView = new GLSurfaceView(this);
glView.setRenderer(this);
glView.setZOrderMediaOverlay(false);
glView.setId(123); // set id

RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams(640, 480);
layout.addView(glView, params);

webView = new WebView(this);
this.showWV(false); //handler message , i hide it in certain screen.
webView.getSettings().setJavaScriptEnabled(true);
webView.getSettings().setLoadWithOverviewMode(true);
webView.getSettings().setUseWideViewPort(true);

params = new RelativeLayout.LayoutParams(640, 480);
params.addRule(RelativeLayout.BELOW, glView.getId()); // set WebView position is below GLSurfaceView
layout.addView(webView, params);

webView.loadUrl("http://stackoverflow.com");

setContentView(layout);

答案 1 :(得分:1)

您可以使用RelativeLayout.LayoutParams类:

执行此操作
RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams(640, 480);
params.addRule(RelativeLayout.ALIGN_PARENT_TOP, RelativeLayout.TRUE);
webView.setLayoutParams(params);

然后将webview添加到布局中。您可以使用新的LayoutParams实例和addRule(RelativeLayout.ALIGN_PARENT_BOTTOM, RelativeLayout.TRUE);

在屏幕底部找到另一个视图