但是用android webview运行它有点麻烦.
>启动应用程序的时间需要5秒或更长时间(我认为这有点慢,但也许这是正常的?)
>在游戏菜单中,我有一个方法:
this.showCredits = function() { document.getElementById('core-credits-layer').style.display = 'block'; document.getElementById('core-credits').style.display = 'block'; var parent = this; $.ajax({ url: 'content/credits.html',dataType: 'html',success: function(data,status,response) { var now = new Date(); var s = now.getSeconds()-parent.test.getSeconds(); console.log('success ajax: '+s); document.getElementById('core-credits').scrollTop = 0; document.getElementById('core-credits').innerHTML = response.responseText; console.log('finished'); },error: function() { console.error('Failed fetch credits'); } }); }
因此,在单击“信用”菜单后立即出现控制台日志(“已完成”,成功的最后一行()).但是在我看到div #core-credits之前,它可能需要6s(或多或少).
在我的浏览器中,我点击后立即看到#core-credits.
但第二次点击该菜单点我在1-2s之后得到了div.
我现在不知道那是什么,我不这么认为,这是一个缓存的事情,因为我很快就进入了success()回调.
Java方面:
public void onCreate(Bundle savedInstanceState) { requestWindowFeature(Window.FEATURE_NO_TITLE); super.onCreate(savedInstanceState); setContentView(R.layout.main); Context context = this.getApplicationContext(); SharedPreferences wmbPreference = PreferenceManager.getDefaultSharedPreferences(this); boolean isFirstRun = wmbPreference.getBoolean("FIRSTRUN",true); if(isFirstRun) { this.copyAudioFiles(context); } WebView mWebView = (WebView) findViewById(R.id.webview); mWebView.getSettings().setJavaScriptEnabled(true); mWebView.getSettings().setDomStorageEnabled(true); mWebView.getSettings().setJavaScriptCanOpenWindowsAutomatically(true); String data = context.getFilesDir().getPath(); mWebView.getSettings().setDatabasePath(data+"data/"+this.getPackageName()+"/databases/"); mWebView.getSettings().setAllowFileAccess(true); mWebView.setWebChromeClient(new WebChromeClient()); String data_root = Environment.getExternalStorageDirectory()+"/" +this.getPackageName(); mWebView.loadUrl("file:///android_asset/www/index.html?system=android&" + "data_root="+data_root); }
我在Eclipse中的虚拟平板设备上以及我真正的华硕平板电脑上都存在性能问题.
动画(jquery show(‘slow’))有时真的很慢或很破碎.例如(这是纸牌游戏),玩家变成9张带有节目(‘慢’)动画的牌,每2或3次我得到3或8张牌而不是9 ^^.
以上所有这些都适用于Chrome或firefox等浏览器.
我正在使用Android 4.1.
激活硬件加速没有帮助.关于webview的渲染问题有各种各样的帖子,但只有硬件加速解决方案,这没有帮助.
解决方法
但是你可以优化很多小东西:
写更快的javascript
>在适用的情况下,始终使用选择器缓存(在代码中只应出现一次document.getElementById(‘core-credits’)
>分组/解耦(参见下一点或直接使用setTimeout)代码执行和DOM操作(总是触发单个元素的重绘或 – 更糟糕的是 – 文档的重排)
>在某些应用程序中,我看到使用requestAnimationFrame Polyfill进行dom操作的良好结果 – 不一定会导致更高的帧速率,但在我的情况下,它允许我正确地“抛弃”openlayers地图(而不是设备只是没有对touchmove)
对Android友好
>就像intel appframework(以前的jqmobi ui)那样,大量使用css3转换而不是尝试jquery风格的“tick”动画
>删除border-radius,而是使用透明的png方法
> Android上其他昂贵的效果图应该是:(-webkit-)box-shadow
,文本阴影和各种渐变(再次可以用于交换旧学校的png)
希望这有所帮助 – 将尝试详细说明,分别说明.纠正信息,因为我现在继续在我自己的应用程序中对抗web webview缓慢.