WebView设置最大高度

项目中遇到各种蛋疼的需求,但是不解决也不行。
我们项目里增加了一个广告横幅,用户使用的时候,有的被拦截掉,直接换成了他们的广告:

给大家上两张图片看下效果,当时用户发来的图片没有保存,我自己模拟了一下:
【WebView设置最大高度】WebView设置最大高度
文章图片

WebView设置最大高度
文章图片

可以明显的看出来,广告被拦截之后,已经把自己的布局顶下去了!
效果大家都看到了就直接上代码吧,WebView本身并没有给我们提供控制自身高度的方法,所以我们要自己写 :
直接把项目里的代码贴出来,希望老大发现以后不会干我import android.content.Context; import android.util.AttributeSet; import android.webkit.WebView; import android.widget.ProgressBar; /** * 带进度条的WebView */ @SuppressWarnings("deprecation") public class ProgressWebView extends WebView {private ProgressBar progressbar; private int maxHeight = -1; public ProgressWebView(Context context, AttributeSet attrs) { super(context, attrs); progressbar = new ProgressBar(context, null, android.R.attr.progressBarStyleHorizontal); progressbar.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, 3, 0, 0)); addView(progressbar); // setWebViewClient(new WebViewClient(){}); setWebChromeClient(new WebChromeClient()); }public class WebChromeClient extends android.webkit.WebChromeClient { @Override public void onProgressChanged(WebView view, int newProgress) { if (newProgress == 100) { progressbar.setVisibility(GONE); } else { if (progressbar.getVisibility() == GONE) progressbar.setVisibility(VISIBLE); progressbar.setProgress(newProgress); } super.onProgressChanged(view, newProgress); }}public void setMaxHeight(int height) { maxHeight = height; }@Override protected void onScrollChanged(int l, int t, int oldl, int oldt) { LayoutParams lp = (LayoutParams) progressbar.getLayoutParams(); lp.x = l; lp.y = t; progressbar.setLayoutParams(lp); super.onScrollChanged(l, t, oldl, oldt); }@Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { // TODO Auto-generated method stub super.onMeasure(widthMeasureSpec, heightMeasureSpec); if (maxHeight > -1 && getMeasuredHeight() > maxHeight) { setMeasuredDimension(getMeasuredWidth(), maxHeight); } } }

使用的时候直接 web.setMaxHeight(高度) 就可以了,记得要写在webview数据加载以前,在看下效果:
WebView设置最大高度
文章图片

至于网站的广告被谁拦截了,又怎么解决的,这个问题就不是我们的事了,咱们只要设置好最大高度不超过多少,不影响到咱们的自己的布局就可以了。

    推荐阅读