Кнопка меню долго зависает при нажатии - PullRequest
0 голосов
/ 01 августа 2011

У меня проблема с кнопкой меню «Обновить», которая долго нажимается при нажатии.По сути, я запускаю асинхронную задачу, которая загружает xml с веб-страницы, обрабатывает ее и, наконец, обновляет текущий список.Есть ли какой-нибудь способ предотвратить эту задержку или изменить мой код, чтобы сделать его более эффективным?

Вот мое действие, в котором возникает проблема обновления:

public class RouteView extends ListActivity implements ActivityUpdater {
private static ArrayList<String> mRouteNames;
private final String TAG = getClass().getName();
private TextView mTv;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.route_view);

    ListView lv = getListView();
    LayoutInflater inflater = getLayoutInflater();
    ViewGroup header = (ViewGroup) inflater.inflate(R.layout.header, lv, false);
    lv.addHeaderView(header, null, false);
    mTv = (TextView) findViewById(R.id.refresh_status);
    long start = System.nanoTime();
    fetchFeed();
    Log.i("MagicBusV2", "Time: " + (System.nanoTime() - start));
}

@Override
protected void onResume() {
    super.onResume();
    fetchFeed();
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    boolean result = super.onCreateOptionsMenu(menu);
    menu.add(0, Constants.REFRESH_MENU_ID, 0, R.string.refresh).setIcon(R.drawable.refresh);
    return result;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    boolean result = super.onOptionsItemSelected(item);
    switch (item.getItemId()) {
    case Constants.REFRESH_MENU_ID:
        long start = System.nanoTime();
        fetchFeed();
        Log.i("MagicBusV2", "Refresh time: " + (System.nanoTime() - start));
        break;
    }
    return result;
}

@Override
protected void onListItemClick(ListView l, View v, int position, long id) {
    super.onListItemClick(l, v, position, id);
    Log.i(TAG, "id: " + (int) id);
    Log.i(TAG, "num_routes: " + mRouteNames.size());
    String routeName = mRouteNames.get((int) id);
    Intent intent = new Intent(this, StopView.class);
    intent.putExtra(Constants.ROUTE_NAME, routeName);
    intent.putExtra(Constants.STOP_VIEW_TYPE, Constants.STOPS_ROUTE);
    startActivity(intent);
}

public void refreshUI() {
    setListAdapter(new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, mRouteNames));
    getListView().setTextFilterEnabled(true); // allows users to type to filter results, need to inform them of this some way

    mTv.setText("Refreshed!");
}

public static void setRouteNames(ArrayList<String> route_names) {
    mRouteNames = route_names;
}

private void fetchFeed() {
    mTv.setText("Refreshing...");

    new RefreshFeedTask(this).execute("null");      
}

А вот мой код AsyncTask:

public class RefreshFeedTask extends AsyncTask<String, Integer, Void> {
private ArrayList<Route> routes;
private TimeFeed feed;
private ActivityUpdater updater;
private Context mCtx;

public RefreshFeedTask(Context ctx) {
    mCtx = ctx;
    updater = (ActivityUpdater) mCtx;
    routes = new ArrayList<Route>();
    try {
        feed = new TimeFeed();
    } catch (MBusDataException e) {
        e.printStackTrace();
    }
}

protected Void doInBackground(String... route_name) {
    routes = feed.getRoutes();
    int num_routes = routes.size();
    if(route_name[0].equals("null")) {
        ArrayList<String> route_names_list = new ArrayList<String>(num_routes);
        for (int i = 0; i < num_routes; i++) {
            route_names_list.add(routes.get(i).getName());
        }
        RouteView.setRouteNames(route_names_list);
    } else if(route_name[0].equals("all_stops")) {
        ArrayList<Stop> stops = new ArrayList<Stop>();
        for (Route route : routes) {
            for (Stop stop : route.getStops()) {
                if(!stops.contains(stop)) {
                    stops.add(stop);
                }
            }
        }
        StopView.setStops(stops);
    } else if(route_name.length > 1) {
        Route route = feed.getRouteWithName(route_name[0]);
        StopDetailsView.setStop(route.getStopWithName(route_name[1]));
    } else if(route_name[0].equals("favorites")) {
        ArrayList<Stop> fav_stops = new ArrayList<Stop>();
        ArrayList<Favorite> allFavs = FavoritesStore.getInstance(mCtx).getAllFavorites();
        for (Favorite fav : allFavs) {
            Route route = feed.getRouteWithName(fav.getRouteName());
            if (route != null) {
                Stop stop = route.getStopWithName(fav.getStopName());
                if (stop != null) {
                    fav_stops.add(stop);
                }
            }
        }
        StopView.setStops(fav_stops);
    } else {
        StopView.setStops(feed.getRouteWithName(route_name[0]).getStops());
    }
    return null;
}

protected void onPostExecute(Void ignore) {
    updater.refreshUI();
}

Спасибо за любую помощь, которую вы можете оказать.Я прошу прощения, если я разместил слишком много кода;Я не был уверен, сколько нужно, чтобы найти потенциальные проблемы.

1 Ответ

2 голосов
/ 04 августа 2011

Посмотрите на конструктор класса TimeFeed.Поскольку вы сказали, что загружаете и анализируете что-то, и я полагаю, что вы, возможно, делаете эти вещи в конструкторе, очевидно, потребуется некоторое время, чтобы выполнить это утверждение.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...