0

追加した

@Override
    protected void onStart() {
        super.onStart();
        FlurryAgent.onStartSession(this, "my id");
    }

    @Override
    protected void onStop() {
        super.onStop();
        FlurryAgent.onEndSession(this);
    }

そして、私のアプリは次のエラーでクラッシュし始めました:

07-30 11:49:40.049: E/AndroidRuntime(20178): FATAL EXCEPTION: FlurryAgent
07-30 11:49:40.049: E/AndroidRuntime(20178): android.view.ViewRoot$CalledFromWrongThreadException: Only the original thread that created a view hierarchy can touch its views.
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.view.ViewRoot.checkThread(ViewRoot.java:3165)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.view.ViewRoot.invalidateChild(ViewRoot.java:690)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.view.ViewRoot.invalidateChildInParent(ViewRoot.java:716)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.view.ViewGroup.invalidateChild(ViewGroup.java:2628)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.view.View.invalidate(View.java:5342)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.widget.TextView.checkForRelayout(TextView.java:5832)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.widget.TextView.setText(TextView.java:2871)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.widget.TextView.setText(TextView.java:2739)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.widget.TextView.setText(TextView.java:2714)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at ua.mirkvartir.android.frontend.ResultViewActivity$AsyncLoad.onPostExecute(ResultViewActivity.java:435)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at ua.mirkvartir.android.frontend.ResultViewActivity$AsyncLoad.onPostExecute(ResultViewActivity.java:1)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.os.AsyncTask.finish(AsyncTask.java:417)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.os.AsyncTask.access$300(AsyncTask.java:127)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:429)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.os.Handler.dispatchMessage(Handler.java:99)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.os.Looper.loop(Looper.java:150)
07-30 11:49:40.049: E/AndroidRuntime(20178):    at android.os.HandlerThread.run(HandlerThread.java:60)

prodavetc_label_tv.setText(Html.fromHtml(prodavetc_label));onPostExecute メソッドの435 行目

asynctask のすべてのビュー操作を RunOnUIThread に配置することで、簡単に修正できます。Flury がスレッドとどのように相互作用するか、および onPostexecute が UI スレッドと見なされない理由を知りたいです。

class AsyncLoad extends AsyncTask<String, Void, JSONObject> {
        ProgressDialog pd;

        @Override
        protected void onPreExecute() {
            pd = new ProgressDialog(app);
            pd.setOwnerActivity(app);
            pd.setTitle("Идет загрузка..");
            pd.setCancelable(true);
            pd.show();
        }

        @Override
        protected JSONObject doInBackground(String... arg0) {
            JSONObject json = JSONParser.getJSONfromURL(RequestStringCreater
                    .idSearchString());
            saveJSON = json;
            return json;
        }

        @Override
        protected void onPostExecute(JSONObject result) {
            pd.dismiss();
            saveJSON = result;
            if (result == null) {

                AlertDialog.Builder builder = new AlertDialog.Builder(context);
                builder.setMessage(
                        "Потеряна связь с сервером. Попробуйте позже.")
                        .setCancelable(false)
                        .setPositiveButton("закрыть",
                                new DialogInterface.OnClickListener() {
                                    public void onClick(DialogInterface dialog,
                                            int id) {
                                        // do things
                                        Intent home = new Intent(context,
                                                ChooserActivity.class);
                                        home.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
                                        home.putExtra("user_id", "0");
                                        startActivity(home);
                                        finish();
                                    }
                                });
                AlertDialog alert = builder.create();
                alert.show();
            } else {
                try {

                    JSONArray results = result.getJSONArray("results");
                    JSONObject e = results.getJSONObject(0);
                    description = e.getString("description");
                    prodavetc_label = e.getString("user_contact");
                    price_title = e.getString("price") + " "
                            + e.getString("currency_title") + " "
                            + e.getString("pricefor_title");
                    item_title = e.getString("title");
                    ids = e.getString("id");
                    href = e.getString("href");
                    chg_data = e.getString("upddate");
                    user_firm = e.getString("user_firm");
                    phone1 = e.getString("phone1");
                    phone2 = e.getString("phone2");
                    country_title = e.getString("country_title");
                    region_title = e.getString("region_title");
                    district_title = e.getString("district_title");
                    settle_title = e.getString("settle_title");
                    street = e.getString("street");
                    rooms = e.getString("rooms");
                    floor = e.getString("floor");
                    floors = e.getString("floors");
                    sqTotal = e.getString("sqTotal");
                    sqLiving = e.getString("sqLiving");
                    sqKitchen = e.getString("sqKitchen");
                    sqLand = e.getString("sqLand");
                    not_photo = e.getString("not_photo");
                    email = e.getString("email");
                    UILApplication.coords = e.getString("coords");
                } catch (JSONException e) {
                    Log.e("log_tag", "Error parsing data" + e.toString());
                }
                UILApplication.photo_buffer = delimitary_parse(); // saving
                                                                        // data
                // for
                // photoshowintent
                TextView prodavetc_label1_tv = (TextView) findViewById(R.id.prodavetc_label1);
                TextView prodavetc_label_tv = (TextView) findViewById(R.id.prodavetc_label);
                if (prodavetc_label == null
                        || prodavetc_label.trim().length() <= 0
                        || prodavetc_label.equalsIgnoreCase("null")) {
                    prodavetc_label1_tv.setVisibility(View.GONE);
                    prodavetc_label_tv.setVisibility(View.GONE);
                } else {
                    prodavetc_label_tv.setText(Html.fromHtml(prodavetc_label));
                }
                TextView user_firm1_tv = (TextView) findViewById(R.id.user_firm1);
                TextView user_firm_tv = (TextView) findViewById(R.id.user_firm);
                if (user_firm == null || user_firm.trim().length() <= 0
                        || user_firm.equalsIgnoreCase("null")) {
                    user_firm1_tv.setVisibility(View.GONE);
                    user_firm_tv.setVisibility(View.GONE);
                } else {
                    user_firm_tv.setText(Html.fromHtml(user_firm));
                }

                Button mail_btn = (Button) findViewById(R.id.mail_btn);
                if (email == null || email.trim().length() <= 0
                        || email.equalsIgnoreCase("null")) {
                    mail_btn.setVisibility(View.GONE);
                } else {
                    mail_btn.setOnClickListener(new OnClickListener() {

                        @Override
                        public void onClick(View arg0) {
                            Intent emailIntent = new Intent(
                                    android.content.Intent.ACTION_SEND);
                            String[] recipients = new String[] { email, "" };
                            emailIntent.putExtra(
                                    android.content.Intent.EXTRA_EMAIL,
                                    recipients);

                            emailIntent.putExtra(
                                    android.content.Intent.EXTRA_SUBJECT,
                                    "Объявление :" + item_title);

                            emailIntent.putExtra(
                                    android.content.Intent.EXTRA_TEXT,
                                    "Здравствуйте, хотел бы связаться с Вами по поводу объявления #"
                                            + ids + ".");

                            emailIntent.setType("message/rfc822");
                            startActivity(Intent.createChooser(emailIntent,
                                    "Отправить e-mail..."));
                        }
                    });
                }

                TextView photo_count = (TextView) findViewById(R.id.photo_count);
                if (empty_image_flag) {
                    photo_count.setText("0");
                } else {
                    photo_count.setText(UILApplication.photo_buffer.length
                            + "");
                }
                TextView phones1_tv = (TextView) findViewById(R.id.phones1);
                TextView phones_tv = (TextView) findViewById(R.id.phones);
                ImageView call_phome1_iv = (ImageView) findViewById(R.id.img_call_phone1);
                TableRow table_row_phone1 = (TableRow) findViewById(R.id.table_row_phone1);
                if (phone1 == null || phone1.trim().length() <= 0
                        || phone1.equalsIgnoreCase("null")) {
                    phones1_tv.setVisibility(View.GONE);
                    phones_tv.setVisibility(View.GONE);
                    call_phome1_iv.setVisibility(View.GONE);
                } else {
                    phones_tv.setText(Html.fromHtml(phone1));
                    table_row_phone1.setOnClickListener(new OnClickListener() {

                        @Override
                        public void onClick(View v) {
                            String number = "tel:" + phone1.toString().trim();
                            Intent callIntent = new Intent(Intent.ACTION_CALL,
                                    Uri.parse(number));
                            startActivity(callIntent);
                        }
                    });
                }
                TextView phone21_tv = (TextView) findViewById(R.id.phones21);
                TextView phone2_tv = (TextView) findViewById(R.id.phones2);
                ImageView call_phone2_iv = (ImageView) findViewById(R.id.img_call_phone2);
                TableRow table_row_phone2 = (TableRow) findViewById(R.id.table_row_phone2);
                if (phone2 == null || phone2.trim().length() <= 0
                        || phone2.equalsIgnoreCase("null")) {
                    phone21_tv.setVisibility(View.GONE);
                    phone2_tv.setVisibility(View.GONE);
                    call_phone2_iv.setVisibility(View.GONE);
                } else {
                    phone2_tv.setText(Html.fromHtml(phone2));
                    table_row_phone2.setOnClickListener(new OnClickListener() {

                        @Override
                        public void onClick(View arg0) {
                            String number = "tel:" + phone2.toString().trim();
                            Intent callIntent = new Intent(Intent.ACTION_CALL,
                                    Uri.parse(number));
                            startActivity(callIntent);
                        }
                    });
                }

                TextView description_tv = (TextView) findViewById(R.id.result_description);
                if (description == null || description.trim().length() <= 0
                        || description.equalsIgnoreCase("null")) {
                    description_tv.setVisibility(View.GONE);
                } else {
                    description_tv.setText(Html.fromHtml(description));
                }

                TextView country_title1_tv = (TextView) findViewById(R.id.country_title1);
                TextView country_title_tv = (TextView) findViewById(R.id.country_title);
                if (country_title == null || country_title.trim().length() <= 0
                        || country_title.equalsIgnoreCase("null")) {
                    country_title1_tv.setVisibility(View.GONE);
                    country_title_tv.setVisibility(View.GONE);
                } else {
                    country_title_tv.setText(Html.fromHtml(country_title));
                }

                TextView region_title1_tv = (TextView) findViewById(R.id.region_title1);
                TextView region_title_tv = (TextView) findViewById(R.id.region_title);
                if (region_title == null || region_title.trim().length() <= 0
                        || region_title.equalsIgnoreCase("null")) {
                    region_title1_tv.setVisibility(View.GONE);
                    region_title_tv.setVisibility(View.GONE);
                } else {
                    region_title_tv.setText(Html.fromHtml(region_title));
                }

                TextView district_title1_tv = (TextView) findViewById(R.id.district_title1);
                TextView district_title_tv = (TextView) findViewById(R.id.district_title);
                if (district_title == null
                        || district_title.trim().length() <= 0
                        || district_title.equalsIgnoreCase("null")) {
                    district_title1_tv.setVisibility(View.GONE);
                    district_title_tv.setVisibility(View.GONE);
                } else {
                    district_title_tv.setText(Html.fromHtml(district_title));
                }

                TextView settle_title1_tv = (TextView) findViewById(R.id.settle_title1);
                TextView settle_title_tv = (TextView) findViewById(R.id.settle_title);
                if (settle_title == null || settle_title.trim().length() <= 0
                        || settle_title.equalsIgnoreCase("null")) {
                    settle_title1_tv.setVisibility(View.GONE);
                    settle_title_tv.setVisibility(View.GONE);
                } else {
                    settle_title_tv.setText(Html.fromHtml(settle_title));
                }

                TextView street1_tv = (TextView) findViewById(R.id.street1);
                TextView street_tv = (TextView) findViewById(R.id.street);
                if (street == null || street.trim().length() <= 0
                        || street.equalsIgnoreCase("null")) {
                    street1_tv.setVisibility(View.GONE);
                    street_tv.setVisibility(View.GONE);
                } else {
                    street_tv.setText(Html.fromHtml(street));
                }

                TextView rooms1_tv = (TextView) findViewById(R.id.rooms1);
                TextView rooms_tv = (TextView) findViewById(R.id.rooms);
                if (rooms == null || rooms.trim().length() <= 0
                        || rooms.equalsIgnoreCase("null")
                        || rooms.equalsIgnoreCase("0")) {
                    rooms1_tv.setVisibility(View.GONE);
                    rooms_tv.setVisibility(View.GONE);
                } else {
                    rooms_tv.setText(Html.fromHtml(rooms));
                }

                TextView floor1_tv = (TextView) findViewById(R.id.floor1);
                TextView floor_tv = (TextView) findViewById(R.id.floor);
                if (floor == null || floor.trim().length() <= 0
                        || floor.equalsIgnoreCase("null")
                        || rooms.equalsIgnoreCase("0")) {
                    floor1_tv.setVisibility(View.GONE);
                    floor_tv.setVisibility(View.GONE);
                } else {
                    floor_tv.setText(Html.fromHtml(floor));
                }
                TextView floors1_tv = (TextView) findViewById(R.id.floors1);
                TextView floors_tv = (TextView) findViewById(R.id.floors);
                if (floors == null || floors.trim().length() <= 0
                        || floors.equalsIgnoreCase("null")
                        || rooms.equalsIgnoreCase("0")) {
                    floors1_tv.setVisibility(View.GONE);
                    floors_tv.setVisibility(View.GONE);
                } else {
                    floors_tv.setText(Html.fromHtml(floors));
                }
                TextView sqTotal1_tv = (TextView) findViewById(R.id.sqTotal1);
                TextView sqTotal_tv = (TextView) findViewById(R.id.sqTotal);
                if (sqTotal == null || sqTotal.trim().length() <= 0
                        || sqTotal.equalsIgnoreCase("null")
                        || sqTotal.equalsIgnoreCase("0")) {
                    sqTotal1_tv.setVisibility(View.GONE);
                    sqTotal_tv.setVisibility(View.GONE);
                } else {
                    sqTotal_tv.setText(Html.fromHtml(sqTotal) + " кв.м");
                }

                TextView sqLiving1_tv = (TextView) findViewById(R.id.sqLiving1);
                TextView sqLiving_tv = (TextView) findViewById(R.id.sqLiving);
                if (sqLiving == null || sqLiving.trim().length() <= 0
                        || sqLiving.equalsIgnoreCase("null")
                        || sqLiving.equalsIgnoreCase("0")) {
                    sqLiving1_tv.setVisibility(View.GONE);
                    sqLiving_tv.setVisibility(View.GONE);
                } else {
                    sqLiving_tv.setText(Html.fromHtml(sqLiving) + " кв.м");
                }

                TextView sqKitchen1_tv = (TextView) findViewById(R.id.sqKitchen1);
                TextView sqKitchen_tv = (TextView) findViewById(R.id.sqKitchen);
                if (sqKitchen == null || sqKitchen.trim().length() <= 0
                        || sqKitchen.equalsIgnoreCase("null")
                        || sqKitchen.equalsIgnoreCase("0")) {
                    sqKitchen1_tv.setVisibility(View.GONE);
                    sqKitchen_tv.setVisibility(View.GONE);
                } else {
                    sqKitchen_tv.setText(Html.fromHtml(sqKitchen) + " кв.м");
                }

                TextView sqLand1_tv = (TextView) findViewById(R.id.sqLand1);
                TextView sqLand_tv = (TextView) findViewById(R.id.sqLand);
                if (sqLand == null || sqLand.trim().length() <= 0
                        || sqLand.equalsIgnoreCase("null")
                        || sqLand.equalsIgnoreCase("0")) {
                    sqLand1_tv.setVisibility(View.GONE);
                    sqLand_tv.setVisibility(View.GONE);
                } else {
                    sqLand_tv.setText(Html.fromHtml(sqLand) + " кв.м");
                }
                Bundle ex = getIntent().getExtras();
                byte[] imm = ex.getByteArray("imMap");
                imSmall = (ImageView) findViewById(R.id.loaderImageView);
                Bitmap bitmap = BitmapFactory.decodeByteArray(imm, 0,
                        imm.length);
                imSmall.setImageBitmap(bitmap);

                imSmall.setOnClickListener(new OnClickListener() {

                    public void onClick(View v) {
                        UILApplication.photo_iterator = 0;
                        bigImageCreator();
                        String[] buf_image_url = new String[UILApplication.photo_buffer_big
                                .size()];
                        buf_image_url = UILApplication.photo_buffer_big
                                .toArray(buf_image_url);
                        Intent intent = new Intent(
                                "ua.mirkvartir.android.frontend.ImageShowActivity");
                        intent.putExtra(Extra.IMAGES, buf_image_url);
                        startActivity(intent);
                    }
                });
                TextView price_tittle_tv = (TextView) findViewById(R.id.price_tittle);
                price_tittle_tv.setText(Html.fromHtml(price_title));
                TextView item_title_tv = (TextView) findViewById(R.id.item_title);
                if (item_title == null || item_title.trim().length() <= 0
                        || item_title.equalsIgnoreCase("null")) {
                    item_title_tv.setText("Нет названия");
                } else {
                    item_title_tv.setText(Html.fromHtml(item_title));
                }

                TextView ids_tv = (TextView) findViewById(R.id.ids);
                ids_tv.setText(Html.fromHtml(ids));
                TextView chg_data_tv = (TextView) findViewById(R.id.chg_data);
                chg_data_tv.setText(Html.fromHtml(chg_data));
                Button share_btn = (Button) findViewById(R.id.share_btn);
                // social sharing
                share_btn.setOnClickListener(new OnClickListener() {
                    public void onClick(View v) {
                        final Intent intent = new Intent(Intent.ACTION_SEND);
                        intent.setType("text/plain");
                        intent.putExtra(Intent.EXTRA_SUBJECT,
                                "Отличный вариант недвижимости:");
                        intent.putExtra(Intent.EXTRA_TEXT, "Хороший вариант "
                                + href);
                        startActivity(Intent.createChooser(intent,
                                getString(R.string.app_name)));
                    }
                });
                ImageView map_button = (ImageView) findViewById(R.id.imageView5);
                if (street.length()>0 || (UILApplication.coords != null
                        && UILApplication.coords.trim().length() > 0
                        && !UILApplication.coords.equalsIgnoreCase("null")
                        && !UILApplication.coords.equalsIgnoreCase("0"))) {
                    map_button.setVisibility(View.VISIBLE);
                }
                map_button.setOnClickListener(new OnClickListener() {

                    public void onClick(View arg0) {
                        String geoUriString = "geo:0,0?q="+street;
                        if (UILApplication.coords != null
                                && UILApplication.coords.trim().length() > 0
                                && !UILApplication.coords.equalsIgnoreCase("null")
                                && !UILApplication.coords.equalsIgnoreCase("0")){
                            geoUriString = "geo:"+UILApplication.coords+"?z=15";
                        }else{
                            geoUriString = "geo:0,0?q="+street;
                        }

                        Uri geoUri = Uri.parse(geoUriString);
                        Intent map = new Intent(Intent.ACTION_VIEW, geoUri);
                        startActivity(map);
//                      startActivity(new Intent(
//                              "ua.mirkvartir.android.frontend.MyMapActivity"));
                    }
                });
                Button btn_look_on_site = (Button) findViewById(R.id.btn_look_on_site);
                btn_look_on_site.setOnClickListener(new OnClickListener() {

                    public void onClick(View arg0) {
                        openWebURL(href);
                    }
                });
                Button save_btn = (Button) findViewById(R.id.save_btn);
                if (UILApplication.addType == 0) {
                    save_btn.setText("В избранное");
                } else {
                    save_btn.setText("Отписатся");
                }
                save_btn.setOnClickListener(new OnClickListener() {

                    @Override
                    public void onClick(View v) {

                        if (UILApplication.addType == 0) {
                            writeJSONtoFile(saveJSON.toString());
                        } else {
                            deleteRecord(saveJSON.toString());
                        }
                    }
                });
            }
        }
    }

}
4

1 に答える 1

0

既知のバッグであり、回答がありますhttp://support.flurry.com/index.php?title=Guides/s/Publishers/Tips/Android

onStart() を少し拡張する必要があります

public void onStart()
   {
       super.onStart();
      // Add the following code to your main Activity before calling FlurryAgent.onStartSession():
      // workaround for AsyncTask issue
       try {

      Class.forName("android.os.AsyncTask");
      }  catch (ClassNotFoundException e) {

         e.printStackTrace();
      }

      FlurryAgent.onStartSession(this, YOUR_API_KEY);
      //your code
  }
于 2013-07-31T09:07:30.877 に答える