- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我创建了一个 Android 应用程序,它从 Web 服务下载数据库记录。我希望在出现启动画面时执行此下载操作。我已经创建了启动画面并在其中编写了下载代码,但我的问题是启动画面直到下载结束才显示。任何帮助将不胜感激。
作为引用,我在下面包含了初始屏幕 Activity 类。
public class SplashScreen extends AppCompatActivity{
private static JSONObject jsonResponse;
private static List<customerList> customerLists = new ArrayList<>();
private static List<productList> productLists = new ArrayList<>();
private static List<loginHistoryList> loginHistoryLists = new ArrayList<>();
private static List<salesOrderList> salesOrderLists = new ArrayList<>();
private static List<userList> userLists = new ArrayList<>();
public static Context mContext;
private String TAG = getClass().getSimpleName();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_splash);
mContext = this;
if(ConnectivityChecker.CheckConnection(mContext)) {
ServerDataFetch mServerDataFetch = new ServerDataFetch();
mServerDataFetch.execute();
}else{
Log.e(TAG,"There is no internet connection");
}
}
/**
* Created by abhilash on 4/3/2016.
*/
private class ServerDataFetch extends AsyncTask<Void,Void,Void> {
UpdateLocalFeeds mUpdateLocalFeeds ;
public String TAG = getClass().getSimpleName();
@Override
protected Void doInBackground(Void... params) {
try {
mUpdateLocalFeeds = new UpdateLocalFeeds(SplashScreen.mContext);
Log.i(TAG, "Streaming data from network: ");
downloadUrl(new VolleyCallback() {
@Override
public void onSuccessResponse(JSONObject result) {
try {
if (result != null) {
Log.d(TAG, result.get("customerList").toString());
Log.i(TAG, "Parsing stream as Atom feed");
Type listType = new TypeToken<Collection<customerList>>() {
}.getType();
customerLists = new GsonBuilder().create().fromJson(result.get("customerList").toString(), listType);
Log.i(TAG, "Customers found " + customerLists.size());
listType = new TypeToken<Collection<loginHistoryList>>() {
}.getType();
loginHistoryLists = new GsonBuilder().create().fromJson(result.get("loginHistoryList").toString(), listType);
Log.i(TAG, "Login History found " + loginHistoryLists.size());
listType = new TypeToken<Collection<productList>>() {
}.getType();
productLists = new GsonBuilder().create().fromJson(result.get("productList").toString(), listType);
Log.i(TAG, "Product found " + productLists.size());
listType = new TypeToken<Collection<salesOrderList>>() {
}.getType();
salesOrderLists = new GsonBuilder().create().fromJson(result.get("salesOrderList").toString(), listType);
Log.i(TAG, "Sales found " + productLists.size());
listType = new TypeToken<Collection<userList>>() {
}.getType();
userLists = new GsonBuilder().create().fromJson(result.get("userList").toString(), listType);
Log.i(TAG, "Users found " + userLists.size());
mUpdateLocalFeeds.updateLocalUserData(userLists);
mUpdateLocalFeeds.updateLocalCustomerData(customerLists);
mUpdateLocalFeeds.updateLocalProductData(productLists);
mUpdateLocalFeeds.updateLocalSalesData(salesOrderLists);
mUpdateLocalFeeds.updateLocalLoginData(loginHistoryLists);
}
} catch (Exception ex) {
Log.e(TAG, ex.getMessage());
}
}
});
}catch (Exception e){
Log.e(TAG,e.getMessage());
}
return null;
}
@Override
protected void onPostExecute(Void aVoid) {
super.onPostExecute(aVoid);
Log.d(TAG,"Downloading completed");
Intent intent = new Intent(SplashScreen.this, LoginActivity.class);
startActivity(intent);
finish();
}
private void downloadUrl(final VolleyCallback volleyCallback) throws IOException {
final JsonObjectRequest jsObjRequest = new JsonObjectRequest
(Request.Method.GET, Constants.SERVER_DATA, new Response.Listener<JSONObject>() {
@Override
public void onResponse(JSONObject response) {
Log.d(TAG, "Response: " + response.toString());
jsonResponse = response;
volleyCallback.onSuccessResponse(response);
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
NetworkResponse networkResponse = error.networkResponse;
if (networkResponse != null) {
// HTTP Status Code: 401 Unauthorized
Log.e("SyncAdapter", networkResponse.statusCode+"");
Log.e("SyncAdapter", error.getMessage());
}
}
});
AppController.getInstance().addToRequestQueue(jsObjRequest,"JObject");
}
}
interface VolleyCallback{
void onSuccessResponse(JSONObject result);
}
最佳答案
在
中显示启动画面protected void onPreExecute()
回调并将其隐藏在
protected void onPostExecute(String result)
关于android - 网络下载时创建android启动画面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36429958/
每当我运行命令以将 Virtualbox 驱动程序启动 Minishift 到操作系统主机时,它都需要一段疯狂的时间,而且它永远不会结束。有时我什至收到有关达到存储限制的错误消息。 不知道是不是描述h
您好,我正在使用 npm 运行一个基本的 React 项目,我正尝试在 docker 容器中启动它。但是我实际上无法让项目运行。我的 dockerfile 看起来像这样: FROM node:7.8.
所以我想从我的 SSH 终端开始游戏。 这真的很奇怪,当我直接从 Linux GUI 执行此操作时,它可以工作。但是当我使用 SSH 客户端进行远程连接时,它就崩溃了。似乎与我的显示驱动程序有关。 U
我有一个显示图像的动态壁纸。我在 Activity 中更改了该图像。然后我需要通知动态壁纸,以便它知道重新加载资源。 Intent 似乎是完美、简单的解决方案: Intent intent = new
我有一个似乎无法解决的问题。我在 Boot Dashboard 中使用 STS 3.9.2 从 Eclipse (Oxygen) 启动 Spring Boot 应用程序没有任何问题: 但是,当我尝试从
全新的 Python,在我开始摆弄东西之前先设置和安装东西。我的理解是 Python 2.7 和 Python 3.3 之间存在一些显着差异/不兼容,尽管这两个版本都得到了很好的使用,所以我认为最好安
在使用了很长时间的 jQuery 之后,我有一个问题,我正在使用 jQuery 模式(样式)编写一个简单的代码, (function(window, undefined) { var jQu
我正在尝试在 spring boot 应用程序下的非 spring 托管类中配置 Autowired。我在 tomcat 服务器下部署的 Web 应用程序下成功运行了这个。但是当我想在 spring
我对 xmonad 完全陌生,但我想开始使用它来提高我的工作效率。 这是我一直在使用的指南(我使用的是 Apple OS X Snow Leopard) http://xmonad.org/tour.
我试图将Spring Boot指南中的Managing Transactions示例扩展到两个数据源,但是@Transaction注释似乎仅对其中一个数据源有效。 在“Application.java
conEmu 有没有办法默认打开多个不同的选项卡? 我看到这个页面解释了如何使用 splits , 我意识到我可以按 Ctrl + T, 1, Enter,但我希望有一种方法可以自动执行此操作! "%
我正在寻找快速而肮脏的答案。我当时脑子一片空白,盯着屏幕看了 12 个小时以上,我想我中枪了。 我想做一个简单的 SignalR 应用程序作为教程。我找到了这个example ,但我不断收到票证未定义
我正在使用 Azure Powershell cmdlet 来启动/停止 VM。 Start-AzureVM [-ServiceName] [-Name] [ ] Stop-AzureVM [-S
我想使用Powershell脚本代码启动/停止iis和mssql 意味着当我运行ps脚本时,我想启动/停止iis和mssql 我在网上搜索了它,发现了一些代码,但按照我的要求无法正常工作 码: $ii
我在 liferay 工作。我们在我们的项目中使用一个模块来创建 liferay 主题。我使用命令 ant -Ddeploy.war=true 将它部署在服务器中。 war 文件在 liferay 部
我想在已安装 Python 2.7 的 Windows XP 计算机上运行 IPython(版本 0.12)。 我通过 Windows 二进制安装程序安装,但安装后 IPython 没有显示在菜单中,
我从创建了自己的简单图片。 FROM python:2.7.11 RUN mkdir /extra/later/ \ && mkdir /yyy 现在,我可以执行以下步骤: docker run
$(document).ready(function () { setTimeout(function() { window.location.reload(); }, 2000); // 2
我刚刚创建了一个帐户 OpenWeatherMap 我想通过城市 ID API 调用获取当前位置的天气: http://api.openweathermap.org/data/2.5/weather?
我注意到,如果我更改 xcasset 中的图像,启动 Storyboard不会更新。 例如,假设您的启动 Storyboard中有一个 UIImage View ,其中包含一个名为“logo”的蓝色图
我是一名优秀的程序员,十分优秀!