作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有谁知道标签页的内容在切换时是如何更新的?换句话说,当我更改选项卡时,我想要内容,在我正在更改的选项卡中刷新或重新创建。
我将此代码作为 TabActivity:
package com.example.HelloTabWidget;
import android.app.TabActivity;
import android.content.Intent;
import android.content.res.Resources;
import android.os.Bundle;
import android.widget.TabHost;
import android.widget.TabHost.OnTabChangeListener;
public class Bussruter extends TabActivity implements OnTabChangeListener {
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
Resources res = getResources(); // Resource object to get Drawables
TabHost tabHost = getTabHost(); // The activity TabHost
TabHost.TabSpec spec; // Resusable TabSpec for each tab
Intent intent; // Reusable Intent for each tab
// Create an Intent to launch an Activity for the tab (to be reused)
intent = new Intent().setClass(this, NedlastetBussruter.class);
// Initialize a TabSpec for each tab and add it to the TabHost
spec = tabHost.newTabSpec("Nedlastet bussruter").setIndicator("Nedlastet bussruter",
res.getDrawable(R.drawable.ic_tab_nedlastet))
.setContent(intent);
tabHost.addTab(spec);
// Do the same for the other tabs
intent = new Intent().setClass(this, AlleBussruter.class);
spec = tabHost.newTabSpec("Alle bussruter").setIndicator("Alle bussruter",
res.getDrawable(R.drawable.ic_tab_alle))
.setContent(intent)
;
tabHost.addTab(spec);
tabHost.setCurrentTab(2);
tabHost.setOnTabChangedListener(this);
}
@Override
public void onTabChanged(String tabId) {
TabHost th = getTabHost();
th.getCurrentTabView().destroyDrawingCache();//i know this is wrong :S
th.getCurrentTabView().buildDrawingCache();//and this is also wrong....
}
}
现在假设我正在切换到标签“NedlassetBussruter”,其中包含代码:
package com.example.HelloTabWidget;
import java.io.File;
import java.util.ArrayList;
import android.app.AlertDialog;
import android.app.ListActivity;
import android.content.ActivityNotFoundException;
import android.content.DialogInterface;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.AdapterView.OnItemLongClickListener;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.Toast;
public class NedlastetBussruter extends ListActivity {
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
String[] listName = this.getListNameNedlastet();
setListAdapter(new ArrayAdapter<String>(this, R.layout.list_item, listName));
ListView lv = getListView();
lv.setTextFilterEnabled(true);
if(!listName[0].equals("Ingen bussruter er lastet ned.")){
lv.setOnItemClickListener(this.createClickListenerNedlastet());
lv.setOnItemLongClickListener(this.createLongClickListener());
lv.setClickable(true);
lv.setLongClickable(true);
}else{
lv.setClickable(false);
lv.setLongClickable(false);
}
/*new OnItemClickListener() {
public void onItemClick(AdapterView<?> parent, View view,
int position, long id) {
// When clicked, show a toast with the TextView text
Toast.makeText(getApplicationContext(), ((TextView) view).getText(),
Toast.LENGTH_SHORT).show();
}
});*/
/*TextView textview = new TextView(this);
textview.setText("This is the Artists tab");
setContentView(textview);*/
}
private OnItemLongClickListener createLongClickListener() {
return
new OnItemLongClickListener() {
public boolean onItemLongClick(AdapterView<?> parent, final View view,
final int position, long id) {
if(isAvailable(position)){
try{
new AlertDialog.Builder(parent.getContext())
.setMessage("Vil du slette bussruten?")
.setCancelable(false)
.setPositiveButton("Yes", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int id) {
deleteFile(view, position);
StorageHandler.availability[position] = false;
}
})
.setNegativeButton("No", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int id) {
dialog.cancel();
}
})
.show();
}catch(Exception e){
toastText("ERROR: "+e.getMessage(), Toast.LENGTH_LONG);
}
return true;
}else return false;
}
};
}
private OnItemClickListener createClickListenerNedlastet(){
return
new OnItemClickListener() {
public void onItemClick(AdapterView<?> parent, View view,
int position, long id){
boolean temp = StorageHandler.availability[position];
if(temp == true){
if(Environment.getExternalStorageState().equals(
Environment.MEDIA_MOUNTED)){
File file = new File(StorageHandler.sdcardUrl+ StorageHandler.uniqueBussFilename[position]);
if (file.exists()) {//open the file
Uri path = Uri.fromFile(file);
Intent intent = new Intent(Intent.ACTION_VIEW);
intent.setDataAndType(path, "application/pdf");
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
try {
startActivity(intent);
}
catch (ActivityNotFoundException e) {
toastText("No Application Available for viewing PDF", Toast.LENGTH_LONG);
}
}else{
toastText("The file "+file.getAbsolutePath()+" was not found.", Toast.LENGTH_LONG);
}
}else{
toastText("sdkort er ikke tilgjengelig.", Toast.LENGTH_LONG);
}
}
};
};
}
private void toastText(String t, int l){
final String text = t;
final int length = l;
Toast.makeText(getApplicationContext(), text, length).show();
}
private void deleteFile(View view, int index){
try{
File f = new File(StorageHandler.sdcardUrl + StorageHandler.uniqueBussFilename[index]);
f.delete();
}catch(Exception e){
toastText("ERROR: "+e.getMessage(), Toast.LENGTH_LONG);
}
}
private boolean isAvailable(int position){
File f = new File(StorageHandler.sdcardUrl + StorageHandler.uniqueBussFilename[position]);
if(f.exists()){
return true;
}
return false;
}
private String[] getListNameNedlastet() {
this.checkAvaliablePdfs();
ArrayList<String> al = new ArrayList<String>();
for(int i = 0;i<StorageHandler.uniqueId.length-1;i++){
if(StorageHandler.availability[i]){
//String br = bussRuter[i]; //used for debugging...
al.add(StorageHandler.uniqueId[i] + " - " + StorageHandler.bussRuter[i]);
}
}
String[] output = new String[al.size()];
if(output.length == 0){
output = new String[]{"Ingen bussruter er lastet ned."};
}else{
for(int i=0;i < al.size();i++){
output[i] = al.get(i);
}
}
return output;
}
private void checkAvaliablePdfs(){
for(int i = 0;i<StorageHandler.uniqueBussFilename.length;i++){
File f = new File(StorageHandler.sdcardUrl + StorageHandler.uniqueBussFilename[i]);
if(f.exists()){
StorageHandler.availability[i] = true;
}
}
}
}
如何让“nedlasset bussruter”选项卡在每次切换到时重新创建内容?有可用的简单命令吗?
最佳答案
当您切换选项卡时,将调用“onResume”方法(在 Activity 中,NedlassetBussruter)。在该方法中,您可以“重新加载”您的数据。所以添加 onResume 方法。此外,您可能需要调用 yourAdapter.notifyDataSetChanged();
关于android - 如何更新选项卡 Change 上的内容 (Android),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4748236/
我是一名优秀的程序员,十分优秀!