Android ViewPager y TabLayout no funcionan rápido

Hay fragmentos anidados con TabLayout y ViewPager . Cada fragmento tiene listview dentro de él así que consiguen la llamada junto y ahora estoy consiguiendo un problema del procesamiento lento de app. He probado algunas soluciones como volley biblioteca, pero no funcionó para mí. Para más estoy publicando mi código también así que por favor guíame para hacerlo mejor.

MainTabFragment.java

 public class MainTabFragment extends Fragment { public static int position_child_tab = 0, three_childs_tab_position = 0; static int count = -1; int position_tab = 0; Bundle args; MyTabLayout myTabLayout; public MainTabFragment() { // Required empty public constructor } /** * Use this factory method to create a new instance of * this fragment using the provided parameters. * * @param param1 Parameter 1. * @param param2 Parameter 2. * @return A new instance of fragment MainTabFragment. */ // TODO: Rename and change types and number of parameters public static MainTabFragment newInstance(String param1, String param2) { return new MainTabFragment(); } @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.main_tab_fragment, container, false); myTabLayout = (MyTabLayout) view.findViewById(R.id.mainTabLayout); NonSiwpablePager pager = (NonSiwpablePager) view.findViewById(R.id.pager); args = getArguments(); if (args != null && args.containsKey("pos_next")) position_tab = args.getInt("pos_next"); if (args != null && args.containsKey("pos_end")) position_child_tab = args.getInt("pos_end"); if (position_child_tab != 3) { three_childs_tab_position = position_child_tab; } else { three_childs_tab_position = 0; } args = new Bundle(); args.putInt("pos_end", position_child_tab); ViewPagerAdapter mAdapter = getViewPagerAdapter(); pager.setAdapter(mAdapter); pager.setOffscreenPageLimit(4); myTabLayout.setupWithViewPager(pager); for (int i = 0; i < mAdapter.getCount(); i++) { View customView = mAdapter.getCustomeView(getActivity(), i); myTabLayout.getTabAt(i).setCustomView(customView); } pager.setCurrentItem(position_tab); return view; } @Override public void onViewCreated(View view, Bundle savedInstanceState) { super.onViewCreated(view, savedInstanceState); myTabLayout.getTabAt(position_tab).getCustomView().setSelected(true); } private ViewPagerAdapter getViewPagerAdapter() { ViewPagerAdapter mAdapter = new ViewPagerAdapter(getChildFragmentManager()); String title_arr[] = {"ADVISORY", "TOP ADVISORS", "EXPERT VIEW"}; for (int i = 0; i < title_arr.length; i++) { Map<String, Object> map = new Hashtable<>(); map.put(ViewPagerAdapter.KEY_TITLE, title_arr[i]); if (i == 0) { map.put(ViewPagerAdapter.KEY_FRAGMENT, AdvisoryPagerFragment.newInstance()); } else if (i == 1) { map.put(ViewPagerAdapter.KEY_FRAGMENT, TopAdvisoryPagerFragment.newInstance()); } else if (i == 2) { map.put(ViewPagerAdapter.KEY_FRAGMENT, ExperViewPagerFragment.newInstance()); } mAdapter.addFragmentAndTitle(map); } return mAdapter; } public static class ViewPagerAdapter extends FragmentStatePagerAdapter { private static final String KEY_TITLE = "fragment_title"; private static final String KEY_FRAGMENT = "fragment"; boolean abc = false; private int[] drawables = new int[]{R.drawable.advisory_selector, R.drawable.top_advisors_selector, R.drawable.expertview_selector}; private List<Map<String, Object>> maps = new ArrayList<>(); public ViewPagerAdapter(FragmentManager fm) { super(fm); } public View getCustomeView(Context context, int pos) { View mView = LayoutInflater.from(context).inflate(R.layout.custom_tab_view, null); TextView mTextView = (TextView) mView.findViewById(R.id.textView); mTextView.setTypeface(Typeface.createFromAsset(context.getAssets(), "fonts/ufonts.com_cambria.ttf")); ImageView mImageView = (ImageView) mView.findViewById(R.id.imageView2); mImageView.setTag(pos); /*if(count >0) { Toast.makeText(context,"Count Is "+count,Toast.LENGTH_SHORT).show(); mImageView = (ImageView) mImageView.getTag(0); mImageView.setSelected(false); } */ mImageView.setImageResource(drawables[pos]); mTextView.setText(getPageTitle(pos)); return mView; } public void addFragmentAndTitle(Map<String, Object> map) { maps.add(map); } @Override public CharSequence getPageTitle(int position) { return (CharSequence) maps.get(position).get(KEY_TITLE); } @Override public Fragment getItem(int position) { return (Fragment) maps.get(position).get(KEY_FRAGMENT); } @Override public int getCount() { return maps.size(); } } } 

Fragmento de niño de MainTabFragment es como:

AdvisoryPagerFragment.java

 public class AdvisoryPagerFragment extends Fragment { static String advisory_child_fragments[]; int myID = 0; Bundle bundle; TabLayout mTabLayout; public AdvisoryPagerFragment() { // Required empty public constructor } /** * Use this factory method to create a new instance of * this fragment using the provided parameters. * * @return A new instance of fragment AdvisoryPagerFragment. */ public static AdvisoryPagerFragment newInstance() { return new AdvisoryPagerFragment(); } @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View inflate = inflater.inflate(R.layout.fragment_app_pager, container, false); /*Bundle args = getArguments(); if (args != null && args.containsKey("pos_end")) myID = args.getInt("pos_end");*/ myID = MainTabFragment.position_child_tab; mTabLayout = (TabLayout) inflate.findViewById(R.id.fragmentTabLayout); advisory_child_fragments = new String[]{"EQUITY", "INDICES", "COMMODITY", "CURRENCY"}; ViewPager pager = (ViewPager) inflate.findViewById(R.id.fragment_pager); FragmentViewPagerAdapter mPagerAdapter = new FragmentViewPagerAdapter(getChildFragmentManager()); pager.setAdapter(mPagerAdapter); mTabLayout.setupWithViewPager(pager); for (int i = 0; i < mPagerAdapter.getCount(); i++) { View customView = mPagerAdapter.getCustomeView(getActivity(), i); mTabLayout.getTabAt(i).setCustomView(customView); } pager.setCurrentItem(myID); return inflate; } @Override public void onViewCreated(View view, Bundle savedInstanceState) { super.onViewCreated(view, savedInstanceState); mTabLayout.getTabAt(myID).getCustomView().setSelected(true); } public static class FragmentViewPagerAdapter extends FragmentStatePagerAdapter { public FragmentViewPagerAdapter(FragmentManager fm) { super(fm); } public View getCustomeView(Context context, int pos) { View mView = LayoutInflater.from(context).inflate(R.layout.custom_view, null); TextView mTextView = (TextView) mView.findViewById(R.id.belowTab_textview); mTextView.setTypeface(Typeface.createFromAsset(context.getAssets(), "fonts/ufonts.com_cambria.ttf")); mTextView.setText(getPageTitle(pos)); return mView; } // @Override public CharSequence getPageTitle(int position) { return advisory_child_fragments[position]; } @Override public Fragment getItem(int position) { switch (position) { case 0: return new EquityFragment(); case 1: return new IndicesFragment(); case 2: return new CommodityFragment(); case 3: return new CurrencyFragment(); } return null; } @Override public int getCount() { return 4; } } } 

Y el fragmento secundario de arriba AdvisoryPagerFragment es

EquityFragment.java

 public class EquityFragment extends android.support.v4.app.Fragment implements SearchView.OnQueryTextListener { public static String imagepath = null; static ArrayList<EquityDetails> catListDao = new ArrayList<EquityDetails>(); static ArrayList<EquityDetails> catListDao1 = new ArrayList<EquityDetails>(); static int count = 0; static int count1 = 0; ListView list; View view; Activity act; AdvisorsAdapter adapter; TextView empty_text; private boolean isViewShown = false; ProgressBar progressBar; public static EquityFragment newInstance() { return new EquityFragment(); } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { view = inflater.inflate(R.layout.equity_activity, container, false); act = this.getActivity(); Log.d("Callled ", "" + count); count++; return view; } public void onActivityCreated(Bundle savedInstanceState1) { super.onActivityCreated(savedInstanceState1); if (android.os.Build.VERSION.SDK_INT > 9) { StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build(); StrictMode.setThreadPolicy(policy); } list = (ListView) view.findViewById(R.id.list_equity); setHasOptionsMenu(true); empty_text = (TextView) view.findViewById(R.id.empty); progressBar = (ProgressBar) view.findViewById(R.id.progressBar); if (Utils.isNetworkAvailable(getActivity())) { if (catListDao.size() > 0) { adapter = new AdvisorsAdapter(act, R.layout.custom_equity, catListDao, 5); list.setAdapter(adapter); } else { new Thread(new Runnable() { @Override public void run() { // do some work here getActivity().runOnUiThread(new Runnable() { @Override public void run() { // if (!isViewShown) { new FetchAllData(getActivity(), 5).executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR); // } } }); } }).start(); } } else { CustomToast toast = new CustomToast(getActivity(), "There is no internet connection!"); } } 

FetchdataClass que FetchdataClass los datos del servicio y los agrega a ListView

 public class FetchAllData extends AsyncTask<Void, Void, String> { ProgressDialog pDialog; int typeId; private Context cont; public FetchAllData(Context con, int typeId) { // TODO Auto-generated constructor stub this.cont = con; this.typeId = typeId; Log.d("Constructor Called", "yes"); } @Override protected void onPreExecute() { // TODO Auto-generated method stub super.onPreExecute(); progressBar.setVisibility(View.VISIBLE); } @Override protected String doInBackground(Void... params) { // TODO Auto-generated method stub return getString(); } private String getString() { // TODO Auto-generated method stub URL obj = null; HttpURLConnection con = null; try { obj = new URL(Constants.AppBaseUrl + "/call_listing/" + typeId); String userPassword = "oi" + ":" + "kl"; String header = "Basic " + new String(android.util.Base64.encode(userPassword.getBytes(), android.util.Base64.NO_WRAP)); con = (HttpURLConnection) obj.openConnection(); con.addRequestProperty("Authorization", header); con.setRequestProperty("Content-type", "application/x-www-form-urlencoded"); con.setRequestMethod("POST"); // For POST only - BEGIN con.setDoOutput(true); OutputStream os = con.getOutputStream(); os.flush(); os.close(); // For POST only - END int responseCode = con.getResponseCode(); if (responseCode == HttpURLConnection.HTTP_OK) { //success BufferedReader in = new BufferedReader(new InputStreamReader(con.getInputStream())); String inputLine; StringBuffer response = new StringBuffer(); while ((inputLine = in.readLine()) != null) { response.append(inputLine); } in.close(); Log.i("TAG", response.toString()); return response.toString(); } else { Log.i("TAG", "POST request did not work."); } } catch (IOException e) { e.printStackTrace(); } return null; } @Override protected void onPostExecute(String result) { // TODO Auto-generated method stub super.onPostExecute(result); if (result != null) { // pDialog.dismiss(); progressBar.setVisibility(View.GONE); JSONObject jsonObject; try { catListDao = new ArrayList<EquityDetails>(); jsonObject = new JSONObject(result); JSONArray jsonArray = jsonObject.getJSONArray("list"); Log.d("Length ", "" + jsonArray.length()); for (int i = 0; i < jsonArray.length(); i++) { EquityDetails allDirectory = new EquityDetails(); allDirectory.setEntry_value(jsonArray.getJSONObject(i).getString("entry")); allDirectory.setSerial_value(jsonArray.getJSONObject(i).getString("sl")); allDirectory.setTg_value1(jsonArray.getJSONObject(i).getString("tgt_1")); allDirectory.setTg_value2(jsonArray.getJSONObject(i).getString("tgt_2")); allDirectory.setMainTitle_value(jsonArray.getJSONObject(i).getString("script")); allDirectory.setMain_subTitle_value(jsonArray.getJSONObject(i).getString("exchange")); allDirectory.setRating_value(jsonArray.getJSONObject(i).getString("rating")); allDirectory.setReview_value(jsonArray.getJSONObject(i).getString("review")); allDirectory.setImage1(jsonArray.getJSONObject(i).getString("advisor_image")); allDirectory.setPosted_by(jsonArray.getJSONObject(i).getString("posted_by")); allDirectory.setImage2(jsonArray.getJSONObject(i).getString("script_image")); allDirectory.setCall_id(jsonArray.getJSONObject(i).getString("call_id")); allDirectory.setBuy(jsonArray.getJSONObject(i).getString("buy_sentiment")); allDirectory.setSell(jsonArray.getJSONObject(i).getString("sell_sentiment")); allDirectory.setRecommend(jsonArray.getJSONObject(i).getString("recommendation")); allDirectory.setPosted_date(jsonArray.getJSONObject(i).getString("posted_date")); allDirectory.setExpiry_date(jsonArray.getJSONObject(i).getString("expiry_date")); catListDao.add(allDirectory); } catListDao1 = catListDao; ab = true; adapter = new AdvisorsAdapter(act, R.layout.custom_equity, catListDao, 0); list.setAdapter(adapter); } catch (JSONException e) { e.printStackTrace(); } } //pDialog.dismiss(); progressBar.setVisibility(View.GONE); } } 

Tratar de establecer

 pager.setOffscreenPageLimit(no_of_fragments or pages); 

Hacer toda su tarea en asyctask sobre la creación de fragmentos

Le sugeriré que agregue el otro método.

 @Override public void setMenuVisibility(boolean menuVisible) { super.setMenuVisibility(menuVisible); if (menuVisible) { Log.e("SetMenuVisibleFragmentA" , menuVisible + " "); } } 

Public void setMenuVisibility (boolean menuVisible)

Establecer una pista para saber si el menú de este fragmento debe ser visible. Esto es útil si sabes que se ha colocado un fragmento en la jerarquía de la vista para que el usuario no pueda verlo en ese momento, así que tampoco se mostrará ningún elemento de menú que tenga.

Parámetros

MenuVisible :: El valor predeterminado es true, lo que significa que el menú del fragmento se mostrará como de costumbre. Si es falso, el usuario no verá el menú.

Tu

OnActivityCreated (Bundle savedInstanceState1) "

En EquityFragment.java es raro. En primer lugar, no desactivar el StrictMode (porque ignorar el lanzado "NetworkOnMainThread" excepción que es más probable es la razón de su código para ser lento …)

Entonces mira el otro Parte:

  } else { new Thread(new Runnable() { @Override public void run() { // do some work here getActivity().runOnUiThread(new Runnable() { @Override public void run() { // if (!isViewShown) { new FetchAllData(getActivity(), 5).executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR); // } } }); } }).start(); } 

Usted comienza un nuevo hilo, donde debe hacer sus cosas de red. En lugar de hacerlo, regresas al hilo de ui (si haces cosas de red aquí la aplicación se bloquea) en tu nuevo hilo y lo haces en el hilo de ui. (No sé qué es exactamente FetchAllData).

 } else { new FetchAllData(getActivity(), 5).executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR); } 

Debe hacer el mismo trabajo.

En su clase FetchAllData, realiza todo el análisis JSON en onPostExecute. Realice el análisis en doInBackground y sólo configure el adaptador en onPostExecute.

Parece que usted hace demasiado trabajo en el método onPostExecute. Trate de analizar JSON y establecer los datos en segundo plano y notificar el cambio en UIthread puede ser viable.

  1. Mueva el código de OnActivityCreated() a onViewCreated() .

  2. Utilice Gson si es posible (había ahorrado segundos valiosos en mi proyecto.)

  3. Publique su código de adaptadores si es posible. Si usted está haciendo demasiada operación en getView() evítelo.

  4. En su AsyncTask, está utilizando elementos de la interfaz de usuario. Sé que podemos acceder a los componentes de la interfaz de usuario en onPostExecute() , pero probar ro ejecutar ese código en el hilo de la interfaz de usuario mediante el uso de runOnUIThread() . Mejora el rendimiento.

  • Múltiples montajes en un cuerpo o múltiples cuerpos?
  • Rendimiento de Scala para Android
  • Android y OOP - Variables globales vs heredados Getters en fragmentos
  • Cómo dibujar varias líneas con el dedo? (Androide)
  • Mover instancias de Set a otro en Scala
  • ¿Qué es EGL y GL mtrack en Android Memory Dump
  • Android: dibujar fondo sin GPU OverDraw como WhatsApp
  • ¿Cuál es el punto de `Content_main.xml`?
  • Cómo reducir el tamaño de WebView dinámicamente de acuerdo a su contenido?
  • Android - Prevenga la pantalla blanca al inicio
  • Eficacia de la consulta con Parse que utiliza una tienda local en Android
  • FlipAndroid es un fan de Google para Android, Todo sobre Android Phones, Android Wear, Android Dev y Aplicaciones para Android Aplicaciones.