- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
启动时,会执行一个异步类,该类会抓取网站以获取信息。在此期间,在收集的信息填充到 ListView 之前,屏幕保持空白。有什么办法可以在这段时间添加加载屏幕吗?
我查看了这个( Add the loading screen in starting of the android application ),但我认为这不是我需要的,因为我不知道请求需要多长时间。
感谢您的宝贵时间。
看到一些答案后,我修改了代码,但两者都不可见。这是我的 Activity main 的 xml 文件。还有一个用于 ListView 中默认 TextView 元素的 TextView 布局 xml 文件。
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin"
tools:context=".MainActivity">
<ProgressBar
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/progressBar"
style="?android:attr/progressBarStyleLarge"
android:layout_centerInParent="true"/>
<ListView
android:layout_width="match_parent"
android:layout_height="507dp"
android:id="@+id/listView"
android:smoothScrollbar="true" />
</RelativeLayout>
这是主要 Activity 的代码:
package adam.example.com.stockexample;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.ProgressBar;
import android.widget.TextView;
import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.ExecutionException;
public class MainActivity extends Activity {
private int index=-1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final ListView ListStock= (ListView)findViewById(R.id.listView);
final ArrayList<String>symbols= new ArrayList<String>();
final ProgressBar pb= (ProgressBar)findViewById(R.id.progressBar);
List<StockElement> stats= new ArrayList<StockElement>();
List<String> StringList= new ArrayList<String>();
pb.setVisibility(View.VISIBLE);
try {
InputStream inputStream = openFileInput("stocks.txt");
if ( inputStream != null ) {
InputStreamReader inputStreamReader = new InputStreamReader(inputStream);
BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
String receiveString = "";
StringBuilder stringBuilder = new StringBuilder();
while ( (receiveString = bufferedReader.readLine()) != null ) {
stringBuilder.append(receiveString);
}
inputStream.close();
String []ret = stringBuilder.toString().split(",");
for(int x=0;x<ret.length;x++){
symbols.add(ret[x]);
}
}
}
catch (FileNotFoundException e) {
Log.e("login activity", "File not found: " + e.toString());
} catch (IOException e) {
Log.e("login activity", "Can not read file: " + e.toString());
}
for(int x=0;x<symbols.size();x++){
stats.add(addStock(symbols.get(x)));
}
for(int x=0;x<stats.size();x++){
StringList.add(stats.get(x).toString());
}
final ArrayAdapter<String> stockAdapter=
new ArrayAdapter<String>(
getApplicationContext(),
R.layout.list_item_textview,
R.id.list_item_textview,
StringList);
pb.setVisibility(View.GONE);
ListStock.setAdapter(stockAdapter);
final AlertDialog.Builder builder= new AlertDialog.Builder(this);
builder.setMessage("Are you sure you would like to delete this?")
.setTitle("Warning")
.setPositiveButton("No", null)
.setNegativeButton("Delete", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) {
stockAdapter.remove(stockAdapter.getItem(index));
symbols.remove(index);
WriteBack(symbols);
stockAdapter.notifyDataSetChanged();
}
});
OnItemClickListener itemClickListener = new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View container, int position, long id) {
// Getting the Container Layout of the ListView
TextView ItemText = (TextView) container;
String selectedItemText=(String)ItemText.getText();
String symbol =selectedItemText.substring(selectedItemText.indexOf(":")+1,selectedItemText.lastIndexOf(")"));
Intent browserIntent = new Intent(Intent.ACTION_VIEW, Uri.parse("http://www.google.com/finance?q="+symbol));
startActivity(browserIntent);
}
};
AdapterView.OnItemLongClickListener itemLongClickListener= new AdapterView.OnItemLongClickListener() {
@Override
public boolean onItemLongClick(AdapterView<?>parent, View container, final int position, long id){
TextView ItemText= (TextView) container;
String selectedItemText= (String) ItemText.getText();
index=position;
builder.show();
return true;
}
};
ListStock.setOnItemClickListener(itemClickListener);
ListStock.setOnItemLongClickListener(itemLongClickListener);
}
public void WriteBack(ArrayList <String> list){
try {
OutputStreamWriter outputStreamWriter = new OutputStreamWriter(openFileOutput("stocks.txt", Context.MODE_PRIVATE));
for(int x=0;x<list.size()-1;x++){
outputStreamWriter.append(list.get(x)+",");
}
outputStreamWriter.append(list.get(list.size()-1));
outputStreamWriter.close();
}
catch (IOException e) {
Log.e("Exception", "File write failed: " + e.toString());
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
public StockElement addStock(String sym){
try {
String s = new HTTPRequest().execute("http://www.google.com/finance?q="+sym).get();
String symbol= s.substring(s.indexOf("<title>")+7,s.indexOf("</title>"));
String name= symbol.substring(0,symbol.indexOf(":"));
symbol=symbol.substring(symbol.indexOf(":")+2,symbol.indexOf(" quotes"));
String price= s.substring(s.indexOf("<meta itemprop=\"price\"")+25,s.indexOf("<meta itemprop=\"price\"")+50);
price= price.substring(price.indexOf("\"")+1,price.lastIndexOf("\""));
String priceChange= s.substring(s.indexOf("<meta itemprop=\"priceChange\"")+36,s.indexOf("<meta itemprop=\"priceChange\"")+60);
priceChange=priceChange.substring(priceChange.indexOf("\"")+1,priceChange.lastIndexOf("\""));
String percent= s.substring(s.indexOf("<meta itemprop=\"priceChangePercent\"")+36,s.indexOf("<meta itemprop=\"priceChangePercent\"")+60);
percent=percent.substring(percent.indexOf("\"")+1,percent.lastIndexOf("\""));
return new StockElement(name,symbol,price,priceChange,percent);
} catch (InterruptedException e) {
e.printStackTrace();
} catch (ExecutionException e) {
e.printStackTrace();
}catch (NullPointerException e){
e.printStackTrace();
}catch (Exception e){
e.printStackTrace();
}
return null;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
}
最佳答案
您可以在 Activity 的布局中添加一个 ProgresBar
(圆圈)。为了将加载圆圈设置在屏幕中间,您可以将布局设置为如下所示。
<ListView
android:id="@+id/list"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:divider="@null"
android:listSelector="@android:color/transparent"
android:layout_alignParentTop="true"/>
<ProgressBar
android:id="@+id/progress"
style="?android:attr/progressBarStyleLarge"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"/> //to make it appear in the middle of screen
现在在您的 Activity
中
ProgressBar pb;
pb = (ProgressBar) findViewById(R.id.progress);
现在,当任务正在进行时,即联系您的网站时,您可以设置 pb.setVisibility(View.VISIBLE);
一旦你的任务完成就可以设置pb.setVisibility(View.GONE);
希望有帮助。
关于java - 在异步 http 请求下加载屏幕,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25633508/
据我了解,HTTP POST 请求的正文大小没有限制。因此,客户端可能会在一个 HTTP 请求中发送 千兆字节 的数据。现在我想知道 HTTP 服务器应该如何处理此类请求。 Tomcat 和 Jett
在了解Web Deploy我遇到了一些讨论 http://+:80 和 http://*:80 的 netsh.exe 命令。这些是什么意思? 最佳答案 引自URLPrefix Strings (Wi
假设我有一个负载均衡器,然后是 2 个 Web 服务器,然后是一个负载均衡器,然后是 4 个应用程序服务器。 HTTP 响应是否遵循与 HTTP 请求服务相同的路径? 最佳答案 按路径,我假设您是网络
我有一个带有 uri /api/books/122 的资源,如果在客户端为此资源发送 HTTP Delete 时该资源不存在,那么相应的响应代码是什么这个 Action ?是不是404 Not Fou
是否有特定的(或约定的)HTTP 响应消息(或除断开连接之外的其他操作)来阐明服务器不接受 pipelined HTTP requests ? 我正在寻找能让客户端停止流水线化它的请求并分别发送每个请
在了解Web Deploy我遇到了一些讨论 http://+:80 和 http://*:80 的 netsh.exe 命令。这些是什么意思? 最佳答案 引自URLPrefix Strings (Wi
我有一个带有 uri /api/books/122 的资源,如果在客户端为此资源发送 HTTP Delete 时该资源不存在,那么相应的响应代码是什么这个 Action ?是不是404 Not Fou
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this qu
我使用 Mule 作为 REST API AMQP。我必须发送自定义请求方法:“PRINT”,但我收到: Status Code: 400 Bad Request The request could
我需要针对具有不同 HTTP 响应代码的 URL 测试我的脚本。我如何获取响应代码 300、303 或 307 等的示例/示例现有 URL? 谢谢! 最佳答案 您可以使用 httpbin为此目的。 例
我正在尝试编写一个程序来匹配 HTTP 请求及其相应的响应。似乎在大多数情况下一切都运行良好(当传输完全有序时,即使不是,通过使用 TCP 序列号)。 我发现的唯一问题是当我有流水线请求时。在那之后,
RESTful Web Services鼓励使用 HTTP 303将客户端重定向到资源的规范表示。它仅在 HTTP GET 的上下文中讨论主题。 这是否也适用于其他 HTTP 方法?如果客户端尝试对非
当使用chunked HTTP传输编码时,为什么服务器需要同时写出chunk的字节大小并且后续的chunk数据以CRLF结尾? 这不会使发送二进制数据“CRLF-unclean”和方法有点多余吗? 如
这个问题在这里已经有了答案: Is it acceptable for a server to send a HTTP response before the entire request has
如果我向同一台服务器发出多个 HTTP Get 请求并收到每个请求的 HTTP 200 OK 响应,我如何使用 Wireshark 判断哪个请求映射到哪个响应? 目前看起来像是发出了一个 http 请
func main() { http.HandleFunc("/", handler) } func handler(w http.ResponseWriter, r http.Request
我找不到有值(value)的 NodeJS with Typescript 教程,所以我在无指导下潜入水中,果然我有一个问题。 我不明白这两行之间的区别: import * as http from
问一个关于Are HTTP headers case-sensitive?的问题,如果 HTTP 方法区分大小写,大多数服务器如何处理“get”或“post”与“GET”或“POST”? 例如,看起来
我正在使用ASP.NET,在其中我通过动词GET接收查询,该应用程序专用于该URL。 该代码有效,但是如果用户发送的密码使http 200无效,请回答我,并在消息的正文中显示“Fail user or
Closed. This question needs details or clarity。它当前不接受答案。 想改善这个问题吗?添加详细信息,并通过editing this post阐明问题。 9
我是一名优秀的程序员,十分优秀!