web-dev-qa-db-ja.com

フラグメントにAsyncTaskを実装するandroid

Jsonデータをリストとして出力するアクティビティがあります。しかし今、私はそれを断片的に実装したいと思います。このフラグメントでは、それをgridviewとして表示します。そして、両方のファイルは正常に動作します。しかし、AsyncTaskを実装しようとすると、到達不能コードとしていくつかのレッドフラグが表示されます。誰かがこれを手伝ってくれませんか?

編集済み:新規

    public class SalesFragment extends Fragment {
        GridView gridView;

        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container,
                Bundle savedInstanceState) {
            View gv = inflater.inflate(R.layout.hot_sales, null);
            gridView = (GridView) gv.findViewById(R.id.grid_view);
            bindGridview();
            return gv;
        }

        public void bindGridview() {

           new MyAsyncTask(getActivity(),gridView).execute("");
        }

        class MyAsyncTask extends AsyncTask<String, String, String> {
            GridView mGridView;
            Activity mContext;
            Response response;
           public  MyAsyncTask(Activity context,GridView gview) {
             this.mGridView=gview;
             this.mContext=context;
            }

           protected String doInBackground(String... params)  {

               File file = new File( Environment.getExternalStorageDirectory().getAbsolutePath() + "/Android/data/sample.txt");
                if(file.exists()) {
                    try{
                           Reader inputStreamReader = new InputStreamReader(new FileInputStream(file));

                           Gson gson = new Gson();
                           this.response = gson.fromJson(inputStreamReader, Response.class);
                        } catch (FileNotFoundException e) {
                           e.printStackTrace();
                        } catch (@SuppressWarnings("hiding") IOException e){
                           e.printStackTrace();
                        }
                }else{
                    System.out.println("Error");
                }
                return null;
                }

           @Override
           protected void onPostExecute(String result) {

                super.onPostExecute(result);

                //List<HashMap<String,String>> aList = new ArrayList<HashMap<String,String>>();

                for(Sales sales : this.response.sales){
                    HashMap<String, String> hm = new HashMap<String,String>();

                    if (sales.getCategories1().contains("12")){
                        //hm.put("sale_title", "" + sales.getShort_title());
                        for(Shop shop : this.response.shops){
                            String image_file = new String( Environment.getExternalStorageDirectory().getAbsolutePath()
                                    + "/images/" + shop.getImage());
                            if(shop.getId().equals(sales.getShop_id())){
                                hm.put("shop_image", image_file );
                                System.out.println(shop_image);
                            }
                        }

                  if(hm.size()>0){
                        gridView.setAdapter(new ImageAdapter(MainActivity.this,R.layout.grid_layout , imgArray, titleArray));
                             }
                    }
                }



           }
        }
    }

上記の画像のグリッドビューに画像を呼び出す方法は?助けてください。

11
Kabe

フラグメント内で非同期タスクを作成する簡単なステップがあります

フラグメントのコードでactivityCreateview

_new MyAsyncTask(getActivity(), mListView).execute("");
_

getActivity()は、フラグメントおよびアクティビティと通信するためのメソッドです

ポストのasynstakで

_context.mListView.setArrayAdapter(...........)
_

ここは

_public class SalesFragment extends Fragment {
GridView gridView;
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        View gv = inflater.inflate(R.layout.hot_sales, null);
       gridView = (GridView) gv.findViewById(R.id.grid_view);
        bindGridView()
        return gv;
        //return super.onCreateView(inflater, container, savedInstanceState);
    }

public void bindGridview()
{

   new MyAsyncTask(getActivity(), gridView).execute("");
}

class MyAsyncTask extends AsyncTask<String, String, String>
{
    GridView mGridView;
    Activity mContex;
   public  MyAsyncTask(Activity contex,GridView gview)
    {
     this.mGridView=gview;
     this.mContex=contex;
    }

   protected String doInBackground(String... params)
    {

       //fetch data
    }

   @Override
    protected void onPostExecute(String result) {
      {   

        for(Sales sales : this.response.sales){
            HashMap<String, String> hm = new HashMap<String,String>();

            if (sales.getCategories1().contains("12")){
                //hm.put("sale_title", "" + sales.getShort_title());
                for(Shop shop : this.response.shops){
                    String image_file = new String(        Environment.getExternalStorageDirectory().getAbsolutePath()
                            + "/images/" + shop.getImage());
                    if(shop.getId().equals(sales.getShop_id())){
                        hm.put("shop_image", image_file );
                        System.out.println(shop_image);
                    }
                }
            }
        }
               if(hm.size()>0)
              mcontext.mGridView.setAdapter(new ImageAdapter(mContext),hm);
      }
_

データをフェッチする前に、それを次のようなモデルにします

_public class ImageModel
    {
        String title;
        String img;
    }


ArrayList<ImageModel> arrayList=new ArrayList<ImageModel>();
_

次に、配列リストに必要なデータを入力します

_mcontext.mGridView.setAdapter(new ImageAdapter(mContext),hm,arrayList);

//in image adapter

public class ImageAdapter extends ArrayAdapter<String> {

public ImageAdapter(Context context, HashMap<String, String> hm,ArrayList<ImageModel> images ) 
        {
            super(context, R.layout.activity_t);

        }
//--code
   }
_

アダプターでハッシュマップを使用し、位置セットデータを使用して画像を割り当て、モデルから値をフェッチする

23
Sumeet kumar