- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试使用 asyntask 在后台加载 webview,同时显示启动画面,当 webview 加载完成时,我希望启动画面消失并显示 webview。出于某种原因,当我尝试在模拟器中编译和运行代码时,我在 LogCat 中遇到了很多错误。
主 Activity .java
package dk.zerone.vuc;
import android.net.ConnectivityManager;
import android.net.NetworkInfo;
import android.os.AsyncTask;
import android.os.Bundle;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.util.Log;
import android.view.Menu;
import android.webkit.WebView;
import android.webkit.WebViewClient;
public class MainActivity extends Activity {
public final boolean networkCheck() {
ConnectivityManager connec = (ConnectivityManager)getSystemService(Context.CONNECTIVITY_SERVICE);
if ( connec.getNetworkInfo(0).getState() == NetworkInfo.State.CONNECTED ||
connec.getNetworkInfo(0).getState() == NetworkInfo.State.CONNECTING ||
connec.getNetworkInfo(1).getState() == NetworkInfo.State.CONNECTING ||
connec.getNetworkInfo(1).getState() == NetworkInfo.State.CONNECTED ) {
return true;
} else if (connec.getNetworkInfo(0).getState() == NetworkInfo.State.DISCONNECTED || connec.getNetworkInfo(1).getState() == NetworkInfo.State.DISCONNECTED ) {
return false;
}
return false;
}
// The definition of our task class
private class LoadWebView extends AsyncTask<String, Integer, String> {
@Override
protected void onPreExecute() {
super.onPreExecute();
}
protected String doInBackground(String... params) {
String url = params[0];
WebView webview = new WebView(MainActivity.this);
webview.loadUrl(url);
Log.i("WebView", "doInBackground: Done loading url.");
return "";
}
protected void onPostExecute(String result) {
super.onPostExecute(result);
}
}
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
/* Splash screen */
setContentView(R.layout.splash);
if(networkCheck()) {
//Instantiating the webview, occupies the whole screen.
//WebView webview = new WebView(this);
//webview.loadUrl("http://mobil.vucfyn.dk/mobil");
new LoadWebView().execute("http://mobil.vucfyn.dk/mobil");
setContentView(R.layout.webview);
Log.i("WebView", "Execute asyntask");
/*webview.setWebViewClient(new WebViewClient() {
@Override
public void onPageFinished(WebView view, String url) {
//super.onPageFinished(view, url);
Log.i("WebView", "Finished loading.");
setContentView(R.layout.webview);
}
});*/
} else {
AlertDialog alertDialog = new AlertDialog.Builder(MainActivity.this).create();
alertDialog.setTitle("Fejl");
alertDialog.setMessage("Ingen forbindelse til internettet");
alertDialog.setButton("OK", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
}
});
alertDialog.show();
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}
}
来自 LogCat 的错误消息:
08-25 11:32:11.544: D/dalvikvm(549): GC_FOR_ALLOC freed 67K, 3% free 10191K/10503K, paused 60ms
08-25 11:32:11.563: I/dalvikvm-heap(549): Grow heap (frag case) to 11.036MB for 1048592-byte allocation
08-25 11:32:11.633: D/dalvikvm(549): GC_CONCURRENT freed 1K, 4% free 11214K/11591K, paused 6ms+3ms
08-25 11:32:11.713: I/WebView(549): SetContentView webview
08-25 11:32:11.733: I/WebView(549): Execute asyntask
08-25 11:32:11.923: D/gralloc_goldfish(549): Emulator without GPU emulation detected.
08-25 11:32:12.593: W/dalvikvm(549): threadid=11: thread exiting with uncaught exception (group=0x409961f8)
08-25 11:32:12.646: E/AndroidRuntime(549): FATAL EXCEPTION: AsyncTask #1
08-25 11:32:12.646: E/AndroidRuntime(549): java.lang.RuntimeException: An error occured while executing doInBackground()
08-25 11:32:12.646: E/AndroidRuntime(549): at android.os.AsyncTask$3.done(AsyncTask.java:278)
08-25 11:32:12.646: E/AndroidRuntime(549): at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
08-25 11:32:12.646: E/AndroidRuntime(549): at java.util.concurrent.FutureTask.setException(FutureTask.java:124)
08-25 11:32:12.646: E/AndroidRuntime(549): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
08-25 11:32:12.646: E/AndroidRuntime(549): at java.util.concurrent.FutureTask.run(FutureTask.java:137)
08-25 11:32:12.646: E/AndroidRuntime(549): at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:208)
08-25 11:32:12.646: E/AndroidRuntime(549): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
08-25 11:32:12.646: E/AndroidRuntime(549): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
08-25 11:32:12.646: E/AndroidRuntime(549): at java.lang.Thread.run(Thread.java:856)
08-25 11:32:12.646: E/AndroidRuntime(549): Caused by: java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare()
08-25 11:32:12.646: E/AndroidRuntime(549): at android.os.Handler.<init>(Handler.java:121)
08-25 11:32:12.646: E/AndroidRuntime(549): at android.webkit.WebView$PrivateHandler.<init>(WebView.java:8211)
08-25 11:32:12.646: E/AndroidRuntime(549): at android.webkit.WebView.<init>(WebView.java:437)
08-25 11:32:12.646: E/AndroidRuntime(549): at android.webkit.WebView.<init>(WebView.java:1040)
08-25 11:32:12.646: E/AndroidRuntime(549): at android.webkit.WebView.<init>(WebView.java:1029)
08-25 11:32:12.646: E/AndroidRuntime(549): at android.webkit.WebView.<init>(WebView.java:1019)
08-25 11:32:12.646: E/AndroidRuntime(549): at android.webkit.WebView.<init>(WebView.java:1010)
08-25 11:32:12.646: E/AndroidRuntime(549): at dk.zerone.vuc.MainActivity$LoadWebView.doInBackground(MainActivity.java:42)
08-25 11:32:12.646: E/AndroidRuntime(549): at dk.zerone.vuc.MainActivity$LoadWebView.doInBackground(MainActivity.java:1)
08-25 11:32:12.646: E/AndroidRuntime(549): at android.os.AsyncTask$2.call(AsyncTask.java:264)
08-25 11:32:12.646: E/AndroidRuntime(549): at java.util.concurrent.FutureTask$Sync.innerRun (FutureTask.java:305)
08-25 11:32:12.646: E/AndroidRuntime(549): ... 5 more
08-25 11:32:16.363: I/Process(549): Sending signal. PID: 549 SIG: 9
我不知道出了什么问题,非常感谢任何帮助。
更新:
package dk.zerone.vuc;
import android.net.ConnectivityManager;
import android.net.NetworkInfo;
import android.os.Bundle;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.graphics.Color;
import android.view.Menu;
import android.view.View;
import android.webkit.WebView;
import android.webkit.WebViewClient;
public class MainActivity extends Activity {
public final boolean networkCheck() {
ConnectivityManager connec = (ConnectivityManager)getSystemService(Context.CONNECTIVITY_SERVICE);
if ( connec.getNetworkInfo(0).getState() == NetworkInfo.State.CONNECTED ||
connec.getNetworkInfo(0).getState() == NetworkInfo.State.CONNECTING ||
connec.getNetworkInfo(1).getState() == NetworkInfo.State.CONNECTING ||
connec.getNetworkInfo(1).getState() == NetworkInfo.State.CONNECTED ) {
return true;
} else if (connec.getNetworkInfo(0).getState() == NetworkInfo.State.DISCONNECTED || connec.getNetworkInfo(1).getState() == NetworkInfo.State.DISCONNECTED ) {
return false;
}
return false;
}
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
/* Splash screen */
setContentView(R.layout.splash);
if(networkCheck()) {
String url = "http://mobil.vucfyn.dk/mobil";
final WebView webview;
webview = new WebView(MainActivity.this);
webview.loadUrl(url);
webview.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
//view.loadUrl(url);
return false;
}
@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
setContentView(webview);
}
});
} else {
AlertDialog alertDialog = new AlertDialog.Builder(MainActivity.this).create();
alertDialog.setTitle("Fejl");
alertDialog.setMessage("Ingen forbindelse til internettet");
alertDialog.setButton("OK", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
}
});
alertDialog.show();
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}
}
最佳答案
为什么要使用 AsyncTask
这可以很容易地实现...
最好用这个
WebView webview = new WebView(MainActivity.this);
webview.loadUrl(url);
webview.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return false;
}
@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
//------>> EXIT YOUR SPLASH SCREEN HERE
}
});
关于android - WebView LoadUrl() 在后台使用 asynctask -,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12121702/
从 0 开始搭建一套后台管理系统,成本巨大,所以都会选择一套成熟的组件库,基于此,再堆叠业务逻辑。我们公司的组件库基于 Ant Design。Ant Design 包含一套完整的后台解决方案,不仅
在我的 IOS 应用程序中,我有一个标记为 retain 的 NSDate* 属性 当我的应用程序再次激活时,属性值已被释放。 我是否误解了属性和内存管理的工作原理,我该如何防范? 最佳答案 很明显,
我有一个使用 BackgroundWorker 组件的示例 WinForms 应用程序。它工作正常,但是当我点击 Cancel 按钮取消后台线程时,它并没有取消线程。当我点击 Cancel 按钮调用
我目前正在开发一个应用程序,该应用程序在启动时会对服务器执行 ping 操作,该服务器会为每个连接的设备返回一个唯一标识符。设备每 5 秒从服务器检索另一页以获取一组不同的数据。这个唯一的 ID 可以
我正在开发一个应用程序,当它通过主页按钮在后台按下时,计时器应该启动,当应用程序返回前台并且计时器已经过了一定时间时,应该是执行。 我的问题是 当我的应用程序转到背景/前景? 是否有特殊的方法或其他技
我有 map View ,其中几乎没有 MKPointAnnotation。 一切正常,但是, View 的 MKPoiintAnnotation 的“背景”是“不可见的”,因此不是很“可见”。 我想
我在 iOS 中开发广告数据应用程序。我的应用程序广告数据在前台很好。但我想在 ios 后台宣传信标数据。我设置了背景外设设置。和广告数据 advertisingData = [CBAdvertise
如果我有一组操作,我想根据特定条件在后台工作程序中运行,例如,我有 10 个条件 if(a) BackgroundWorker doA = new backgroundworker() if(
我想独立运行一个函数。从我调用的函数中,我想在不等待其他函数结束的情况下返回。 我试过用 threadind,但这会等待,结束。 thread = threading.Thread(target=my
我想在用户在线时立即执行一些任务,即使他在后台也是如此。我正在使用 Reachability 类来检查互联网。但是当我在后台时,这个类没有通知我。我知道有人早些时候问过这个问题,但没有找到任何解决方案
我在后台播放文本转语音时出现间歇性(哎呀!)问题,由 Apple Watch 触发。我已经正确设置了后台模式、AVSession 类别和 WatchKitExtensionRequest 处理程序。
我有一个相当复杂的程序,所以我不会在这里转储整个程序。这是一个简化版本: class Report { private BackgroundWorker worker; public
我有一个任务在 backgroundworker 中运行。单击开始按钮,用户将启动该过程,并获得一个取消按钮来取消处理。 当用户点击取消时,我想显示一个消息框“进程尚未完成,你想继续吗”。 这里我希望
我有一个按以下方式编码的脚本。我想将它作为后台/守护进程运行,但是一旦我启动脚本,如果我关闭它从程序运行的终端窗口终止。我需要做什么来保持程序运行 loop do pid = fork do
我正在制作一个使用 ActivityRecognition API 在后台跟踪用户 Activity 的应用,如果用户在指定时间段(例如 1 小时)内停留在同一个地方,系统就会推送通知告诉用户去散步.
当尝试使用 URLSession 的 dataTaskPublisher 方法发送后台请求时: URLSession(configuration: URLSessionConfiguration.ba
当我编译这段代码时,我得到了他的错误,对象引用设置为null,错误位置在Dowork中,argumenttest.valueone = 8; public partial class Form1 :
有什么方法可以使用最小化或不活动的应用程序吗?我可以打开我的应用程序,然后打开并使用另一个应用程序,然后按一个按钮来激活我的程序吗? 例如,打开我的应用程序,打开 Safari,按下按钮(F1 或任何
我的具体要求是一个在后台运行的应用程序,被通知显示器即将进入休眠状态或者设备已经或即将达到空闲超时 - 然后唤醒并执行一些(简短的)一段代码。 我在这里找到了有关应用程序被置于后台或暂停的通知的引用:
我有一个 LSUIElement 设置为 1 的应用程序。它有一个内置编辑器,因此我希望该应用程序在编辑器打开时出现在 Cmd+Tab 循环中。 -(void)stepIntoForegrou
我是一名优秀的程序员,十分优秀!