Backendless: я не могу получить доступ к полученным данным
Используя проект Android здесь, RestaurantListActivity
показывает список полученных Restaurants
от Restaurant
стол в Backendless и проблем пока нет.
Проблема: я два дня пытался найти список ресторанов где-нибудь еще в коде или использовать totalRestaurants
список.
Я старался:
1- Этот код вызывает исключение NullPointerException:
Backendless.Data.of( Restaurant.class ).findFirst();
2 - используя тот же код в Github: я могу получить доступ totalRestaurants
список в скобках, но после этого блока кода он показывает мне, что totalRestaurants
список пуст.
Backendless.Data.of( Restaurant.class ).find( query, new LoadingCallback<BackendlessCollection<Restaurant>>( this, getString( R.string.loading_restaurants ), true )
{
@Override
public void handleResponse( BackendlessCollection<Restaurant> restaurantsBackendlessCollection )
{
restaurants = restaurantsBackendlessCollection;
addMoreItems( restaurantsBackendlessCollection );
super.handleResponse( restaurantsBackendlessCollection );
}
} );
3 - Использование подхода автоматической загрузки на сайте Backendless с небольшими правками: то же самое происходит снова. Внутри обратного вызова я могу напечатать имя Restaurant
объект, и я добавляю каждый объект в copylist
, но в конце кода copylist
пустой!
LoadingCallback<BackendlessCollection<Restaurant>> callback=new LoadingCallback<BackendlessCollection<Restaurant>>(this, getString( R.string.loading_restaurants ), true)
{
@Override
public void handleResponse( BackendlessCollection<Restaurant> restaurants )
{
System.out.println( "Loaded " + restaurants.getCurrentPage().size() + " restaurant objects" );
System.out.println( "Total restaurants in the Backendless storage - " + restaurants.getTotalObjects() );
Iterator<Restaurant> iterator=restaurants.getCurrentPage().iterator();
while( iterator.hasNext() )
{
Restaurant restaurant=iterator.next();
copylist.add(restaurant);
System.out.println( "\nRestaurant name = " + restaurant.getName() );
}
}
};
Backendless.Data.of( Restaurant.class ).find( callback );
Ваша помощь очень ценится!
3 ответа
Хорошо, вот что я сделал:
Класс TaxiList с геттерами и сеттерами
public class TaxiList {
private String ime; //in database
private String telefon1; //in database
private String telefon2; //in database
public String getIme(String ime) {
return this.ime;
}
public void setIme(String ime) {
this.ime = ime;
}
public String getTelefon1(String telefon1) {
return this.telefon1;
}
public void setTelefon1(String telefon1) {
this.telefon1 = telefon1;
}
public String getTelefon2(String telefon2) {
return this.telefon2;
}
public void setTelefon2(String telefon2) {
this.telefon2 = telefon2;
}
}
Далее идет адаптер
public class TaxiAdapter extends BaseAdapter {
private final LayoutInflater inflater;
private List<TaxiList> taxiLists = null;
public TaxiAdapter(Context context,List<TaxiList> taxiLists) {
Context mContext = context;
this.taxiLists = taxiLists;
inflater = LayoutInflater.from(mContext);
}
public class ViewHolder {
TextView ime;
TextView telefon1;
TextView telefon2;
}
@Override
public int getCount() {
return taxiLists.size();
}
@Override
public TaxiList getItem(int position) {
return taxiLists.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
public View getView(final int position, View view, ViewGroup parent) {
final ViewHolder holder;
if (view == null) {
holder = new ViewHolder();
view = inflater.inflate(R.layout.one_row_taxi, parent, false);
holder.ime = (TextView) view.findViewById(R.id.textIme);
holder.telefon1 = (TextView) view.findViewById(R.id.textTelefon1);
holder.telefon2 = (TextView) view.findViewById(R.id.textTelefon2);
view.setTag(holder);
} else {
holder = (ViewHolder) view.getTag();
}
holder.ime.setText(taxiLists.get(position).getIme("ime"));
holder.telefon1.setText(taxiLists.get(position).getTelefon1("telefon1"));
holder.telefon2.setText(taxiLists.get(position).getTelefon2("telefon2"));
return view;
}
}
И, наконец, это то, как вы получаете материал из Backendless (для меня, во фрагменте)
public class Taxi extends Fragment {
private ListView listview;
private ProgressBar progressBar;
private List<TaxiList> taxiLists = new ArrayList<>();
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View rootView = inflater.inflate(R.layout.fragment_taxi, container, false);
listview = (ListView) rootView.findViewById(R.id.listview);
progressBar = (ProgressBar) rootView.findViewById(R.id.progressBar);
progressBar.setVisibility(View.VISIBLE);
BackendlessDataQuery query = new BackendlessDataQuery();
QueryOptions queryOptions = new QueryOptions();
String whereClause = "created";
queryOptions.addSortByOption(whereClause);
query.setQueryOptions(queryOptions);
Backendless.Data.of(TaxiList.class).find(query, new AsyncCallback<BackendlessCollection<TaxiList>>() {
@Override
public void handleResponse(BackendlessCollection<TaxiList> taxiListBackendlessCollection) {
TaxiList taxiList;
for (TaxiList total : taxiListBackendlessCollection.getCurrentPage()) {
taxiList = new TaxiList();
taxiList.setIme(total.getIme("ime"));
taxiList.setTelefon1(total.getTelefon1("telefon1"));
taxiList.setTelefon2(total.getTelefon2("telefon2"));
taxiLists.add(taxiList);
TaxiAdapter adapter = new TaxiAdapter(getActivity(), taxiLists);
listview.setAdapter(adapter);
progressBar.setVisibility(View.GONE);
}
}
@Override
public void handleFault(BackendlessFault backendlessFault) {
}
});
return rootView;
}
}
Надеюсь, это поможет вам:)
(1) Пожалуйста, предоставьте трассировку стека, было бы трудно диагностировать проблему без каких-либо подробностей
(2) и (3) Имейте в виду, что выполнение метода handleResponse является асинхронным. Если вы попытаетесь получить доступ к "Restaurants" или "CopyList" до вызова метода "handleResponse", данных просто не будет там.
Создайте сериализуемый класс
public class SharedClass implements Serializable{
public List<String> copylist = new ArrayList<>();
void additem(String s){
copylist.add(s);
}
}
поскольку handleResponse
в (2) звонки добавить addMoreItems
, Отредактируйте его, чтобы заполнить copylist
и перейти к другой деятельности под названием NewActivity
,
private void addMoreItems( BackendlessCollection<Restaurant> nextPage )
{
totalRestaurants.addAll( nextPage.getCurrentPage() );
Intent restaurantListingIntent = new Intent( this, NewActivity.class );
SharedClass sharedlist=new SharedClass();
for(int i=0;i<totalRestaurants.size();i++){
sharedlist.additem(totalRestaurants.get(i).getName());
System.out.println("Added "+totalRestaurants.get(i).getName());
}
restaurantListingIntent.putExtra("sharedlist", sharedlist);
startActivity(restaurantListingIntent);
}
внутри NewActivity
Я печатаю copylist
размер
Intent intent=getIntent();
SharedClass sharedObject= (SharedClass) intent.getSerializableExtra("sharedlist");
System.out.println("copy list size"+ sharedObject.copylist.size());