#java #android #android-listview #android-adapter
#java — язык #Android #android-listview #android-адаптер
Вопрос:
Я работаю над приложением для Android для обработки заказов для технических специалистов на местах Сначала позвольте мне объяснить макет моего приложения:
Основная часть приложения содержит 3 вкладки
Вкладка 1 — Начальная вкладка
— содержит сводку текущих рабочих заданий, которые открыты
Вкладка 2 — Вкладка «Назначенные рабочие задания»
— содержит список рабочих заданий, которые в данный момент назначены пользователю, вошедшему в систему
Вкладка 3 — Неназначенные рабочие задания
— содержит список рабочих заданий, которые назначены команде пользователя, но не конкретному лицу
Я использую класс под названием «Database», который представляет собой одноэлементный класс, являющийся частью контекста приложения, так что к нему можно получить доступ во всем приложении. Я включу некоторый код из него ниже
Вот проблема:
Когда пользователь нажимает на определенный рабочий заказ в списке, запускается действие с подробным описанием рабочего заказа, отображающее все виды информации о рабочем заказе. Если workorder является «неназначенным», он также отображает кнопку «Принять владельца», которая изменяет поле «владелец» на текущего пользователя, удаляет его из списка неназначенных и добавляет в список назначенных для этого пользователя. Однако, как только пользователь нажимает кнопку «Назад», чтобы закрыть экран сведений о рабочем порядке (действие), и возвращается к просмотру вкладок, списки не обновляются до тех пор, пока вы каким-либо образом не заставите представление обновиться (например, прокрутите список дальше вниз, чтобы рабочий порядок, который только что сменил владельца, исчез с экрана).
Я пробовал:
-перемещение пользовательского ListAdapter в класс Database (singleton) и доступ к нему через него -вызов «notifyDataSetChanged()» в адаптерах списка
Есть ли у кого-нибудь идеи о том, как заставить его обновляться при каждом выборе вкладки (или при отключении экрана сведений о рабочем порядке нажатием кнопки «Назад»)?? Я рыскал по Интернету, пытаясь найти решение, и мне не удалось ничего из того, что я нашел, поэтому я публикую здесь еще раз, зная, что большинство людей здесь умнее меня!
Заранее спасибо за вашу помощь! Я включил соответствующий код ниже:
Класс базы данных:
public class Database extends Application {
private static Database instance = null;
private ArrayList<Workorder> assignedwolist;
private ArrayList<Workorder> unassignedwolist;
private Credentials creds;
private WOListAdapter assignedadapter;
private WOListAdapter unassignedadapter;
private static void checkInstance() {
if(instance==null) {
throw new IllegalStateException("Database class not created yet!");
}
}
@Override
public void onCreate() {
super.onCreate();
instance=this;
}
public Database() {
this.creds=null;
this.assignedwolist = getAssignedWorkorders();
this.unassignedwolist = getUnassignedWorkorders();
this.assignedadapter=new WOListAdapter(this,getAssignedWorkorders());
this.unassignedadapter=new WOListAdapter(this,getUnassignedWorkorders());
}
public ArrayList<String> getSummary() {
int numassigned = assignedwolist.size();
int assignedp1 = 0;
for(Workorder wo:assignedwolist) {
if(wo.getPriority().equalsIgnoreCase("1")) {
assignedp1 ;
}
}
int numunassigned = unassignedwolist.size();
int unassignedp1 = 0;
for(Workorder wo:unassignedwolist) {
if(wo.getPriority().equalsIgnoreCase("1")) {
unassignedp1 ;
}
}
ArrayList<String> summary = new ArrayList<String>();
summary.add(Integer.toString(numassigned));
summary.add(Integer.toString(assignedp1));
summary.add(Integer.toString(numunassigned));
summary.add(Integer.toString(unassignedp1));
return summary;
}
public Workorder getWO(String id) {
for(Workorder wo:assignedwolist) {
if(wo.getId().equalsIgnoreCase(id)) {
return wo;
}
}
for(Workorder wo:unassignedwolist) {
if(wo.getId().equalsIgnoreCase(id)) {
return wo;
}
}
return null;
}
public ArrayList<Workorder> getAssignedWorkorders() {
return assignedwolist;
}
public ArrayList<Workorder> getUnassignedWorkorders() {
return unassignedwolist;
}
public void setValidated(boolean validated) {
this.validated = validated;
}
public boolean isValidated() {
return validated;
}
public void takeOwnership(String wonum) {
Workorder wo;
for(int i=0;i<unassignedwolist.size();i ) {
if(unassignedwolist.get(i).getId().equalsIgnoreCase(wonum)) {
wo = unassignedwolist.remove(i);
wo.setOwner(creds.getUsername());
assignedwolist.add(wo);
Collections.sort(assignedwolist);
return;
}
}
this.assignedadapter.notifyDataSetChanged();
this.unassignedadapter.notifyDataSetChanged();
}
public WOListAdapter getAssignedAdapter() {
return assignedadapter;
}
public WOListAdapter getUnassignedAdapter() {
return unassignedadapter;
}
}
Main App (contains Tabs):
public class MainApp extends TabActivity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.tab);
/*Tab host for tabs */
TabHost tabHost = (TabHost)findViewById(android.R.id.tabhost);// The activity TabHost
TabSpec hometabspec = tabHost.newTabSpec("Home");
TabSpec assignedtabspec = tabHost.newTabSpec("Assigned");
TabSpec unassignedtabspec = tabHost.newTabSpec("Unassigned");
hometabspec.setIndicator("Home",getResources().getDrawable(R.drawable.ic_tab_home)).setContent(new Intent(this,HomeActivity.class));
assignedtabspec.setIndicator("Assigned",getResources().getDrawable(R.drawable.ic_tab_assigned)).setContent(new Intent(this,AssignedActivity.class));
unassignedtabspec.setIndicator("Unassigned",getResources().getDrawable(R.drawable.ic_tab_unassigned)).setContent(new Intent(this,UnassignedActivity.class));
tabHost.addTab(hometabspec);
tabHost.addTab(assignedtabspec);
tabHost.addTab(unassignedtabspec);
tabHost.getTabWidget().setCurrentTab(0);
}
}
AssignedActivity:
public class AssignedActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Database db = (Database)getApplicationContext();
setContentView(R.layout.wolist);
ListView listview =(ListView)findViewById(R.id.wolistview);
listview.setTextFilterEnabled(false);
WOListAdapter wolistadapter = db.getAssignedAdapter();
listview.setAdapter(wolistadapter);
listview.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterview, View view, int position,
long arg3) {
Workorder wo = (Workorder)adapterview.getItemAtPosition(position);
Intent i = new Intent();
i.setClass(AssignedActivity.this,WorkorderDetailActivity.class);
i.putExtra("wonum",wo.getId());
startActivity(i);
}
});
}
}
Неназначенная активность:
public class UnassignedActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Database db = (Database)getApplicationContext();
setContentView(R.layout.wolist);
ListView listview =(ListView)findViewById(R.id.wolistview);
listview.setTextFilterEnabled(false);
WOListAdapter wolistadapter = db.getUnassignedAdapter();
listview.setAdapter(wolistadapter);
listview.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterview, View view, int position,
long arg3) {
Workorder wo = (Workorder)adapterview.getItemAtPosition(position);
Intent i = new Intent();
i.setClass(UnassignedActivity.this,WorkorderDetailActivity.class);
i.putExtra("wonum",wo.getId());
startActivity(i);
}
});
}
}
WorkorderDetailActivity Рабочий порядок:
public class WorkorderDetailActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Database db = (Database)getApplicationContext();
final Workorder wo;
Bundle extras = getIntent().getExtras();
if(extras!=null) {
//Set Fields
wo = db.getWO(extras.getString("wonum"));
setContentView(R.layout.wodetail);
TextView tv=(TextView)findViewById(R.id.wonumview);
tv.setTextSize(20);
tv.setText(wo.getId());
tv=(TextView)findViewById(R.id.wodescriptionview);
tv.setTextSize(18);
tv.setText(wo.getDescription());
tv=(TextView)findViewById(R.id.wolocationview);
tv.setTextSize(18);
tv.setText(wo.getLocation());
tv=(TextView)findViewById(R.id.wostatusview);
tv.setTextSize(18);
tv.setText(wo.getStatus());
tv=(TextView)findViewById(R.id.woreporteddateview);
tv.setTextSize(18);
tv.setText(wo.getReportdate().substring(0, 19));
tv=(TextView)findViewById(R.id.wotypeview);
tv.setTextSize(18);
tv.setText(wo.getType());
//Assigned or Unassigned adjustments
tv=(TextView)findViewById(R.id.woownerview);
Button b = (Button)findViewById(R.id.TakeOwnershipButton);
if(wo.getOwner().equalsIgnoreCase("none")) { //Display TakeOwnership button
b.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Database db = (Database)getApplicationContext();
db.takeOwnership(wo.getId());
Button b = (Button)findViewById(R.id.TakeOwnershipButton);
TextView tv=(TextView)findViewById(R.id.woownerview);
b.setVisibility(View.INVISIBLE);
tv.setVisibility(View.VISIBLE);
tv.setTextSize(18);
tv.setText(wo.getOwner());
}
});
b.setVisibility(View.VISIBLE);
tv.setVisibility(View.INVISIBLE);
} else { //Display owner
b.setVisibility(View.INVISIBLE);
tv.setVisibility(View.VISIBLE);
tv.setTextSize(18);
tv.setText(wo.getOwner());
}
//Icon color adjustment based on priority
ImageView icon = (ImageView)findViewById(R.id.woiconview);
switch(wo.getPriorityNum()) {
case 1: icon.setColorFilter(Color.RED); break;
case 2: icon.setColorFilter(Color.YELLOW); break;
case 3: icon.setColorFilter(Color.GREEN); break;
case 4: icon.setColorFilter(Color.BLUE); break;
default: icon.setColorFilter(Color.TRANSPARENT); break;
}
//Status change options
Spinner s = (Spinner)findViewById(R.id.wostatusselector);
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, db.getValidStatuses(wo.getStatus()));
adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
s.setAdapter(adapter);
} else { //No wonum was passed in!
TextView tv = new TextView(this);
tv.setText("Error Retrieving Workorder");
setContentView(tv);
}
}
}
Комментарии:
1. Если бы здесь были XML-файлы макета, я бы попытался запустить приложение, чтобы посмотреть, смогу ли я что-нибудь придумать.
2. Я мог бы опубликовать их, я просто не думал, что они будут необходимы. Ошибок нет, просто они не обновляются. Есть ли метод, который вызывается при нажатии кнопки «Назад» или при переключении вкладок, который я мог бы каким-то образом принудительно обновить??
Ответ №1:
Я использую setOnTabChanged () для обновления Google Analytics и запроса нового добавления у AdMob:
tabHost.setOnTabChangedListener(new OnTabChangeListener(){
public void onTabChanged(String tabId) {
tracker.dispatch();
adView.requestFreshAd();
}});
Комментарии:
1. Будет ли этот метод выполняться, когда кто-то нажимает клавишу возврата с экрана сведений о рабочем порядке и возвращается к просмотру вкладок? Или это будет просто обновляться, как только пользователь фактически перейдет на другую вкладку?
2. Это сработает только при смене вкладки с одной вкладки на другую.