我有一个带有按钮,图像和webview的活动。 我的目标是加载页面,然后在其上执行javascript以使用HTML5等绘制图形。
html5绘制的图像高度未知/可变,但宽度应始终与手机的宽度/或浏览器窗口相同。
我有一个javascript界面来获取一个包含信息的回调,它现在已经完成了调用绘图功能,它给了我高度。
以下是网络视图的设置
mWeb = (WebView) findViewById(R.id.webView1);
mWeb.clearCache(true);
mWeb.addJavascriptInterface(new IJavascriptHandler(), "cpjs");
mWeb.getSettings().setJavaScriptEnabled(true);
mWeb.loadUrl(" http://theURL.com ");
mWeb.setInitialScale(100);
mWeb.getSettings().setDefaultZoom(WebSettings.ZoomDensity.FAR);
mWeb.setWebViewClient(new WebViewClient() {
public void onPageFinished(WebView view, String url){
mWidth = mWeb.getWidth();
mHeight = mWeb.getHeight();
view.loadUrl("javascript: Tools.adjustWidth(" + mWidth + " )");
String javaCouponRender = "renderCoupon(" + kupongJson + ", 0); void(0)";
view.loadUrl("javascript: " + javaCouponRender);
}
});
}
我在视图中的按钮,我已经习惯使用此功能将我的webview渲染为纹理:
void renderCoupon(int width,int height){
bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
final Canvas c =new Canvas(bitmap);
mWeb.draw(c);
imgView.setMinimumWidth(width);
imgView.setMinimumHeight(height);
imgView.setImageBitmap(bitmap);
imgView.setVisibility(View.VISIBLE);
}
这很有效。按下按钮,将绘制的内容呈现给纹理,并且imageview具有正确的结果。唯一的cavaet是我必须等到页面加载/绘制之后再按下按钮。
现在,我已经实现了我从javascript中得到的回调:
final class IJavascriptHandler {
IJavascriptHandler() {
}
public void couponRenderedCallback(final int height){
mHasGotRenderCallback = true;
mHeight = height;
Toast t = Toast.makeText(getApplicationContext(), "see if it helps sleeping", 2000);
t.show();
try{
Thread.sleep(5000);
}
catch(InterruptedException ex){
}
runOnUiThread(new Runnable() {
@Override
public void run() {
Toast t2 = Toast.makeText(getApplicationContext(), "and now we render to texture", 2000);
t2.show();
renderCoupon(mWidth, mHeight);
}
});
}
}
每次,此回调函数都会呈现白页。有趣的是,如果我在看到此回调被调用后立即按下渲染到纹理按钮,它会显示预期结果。是不是以某种方式失败的runOnUiThread?
睡眠是我添加的东西,看看是否存在某种有趣的webview渲染延迟和我从javascript获得的回调。
我也尝试将睡眠转移到runOnUiThread,这也没有帮助。
我希望有人知道我应该朝哪个方向解决这个问题。任何帮助表示赞赏。
答案 0 :(得分:7)
找到一个解决方案,即将renderCoupon更改为:
void renderCoupon(final int width,final int height){
mWeb.postDelayed(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
final Canvas c =new Canvas(bitmap);
mWeb.draw(c);
imgView.setMinimumWidth(width);
imgView.setMinimumHeight(height);
imgView.setImageBitmap(bitmap);
imgView.setVisibility(View.VISIBLE);
}
}, 100);
}
当然我在回调中删除了Sleep内容。感谢我的同事给我这个问题。 :)