0

sharingIntent用来分享应用程序的链接。当我单击该按钮时,它会显示共享窗口,并且我会正确共享链接。之后,共享过程,我的应用程序无法打开并崩溃。我intent.getExtras()用来识别图像和图像网址。Logcat 说问题是数组索引是 11,大小等于 0。但是,我不知道如何解决它。

共享过程完成后,此行给出错误:imageLoader.displayImage(imageUrls.get(imagePosition), imageView);

这是我的活动:

public class ProductDetail extends Activity {

    static List<String> imageUrls = Data.BIGIMAGE;
    static List<String> productUrl = Data.PRODUCT_URL;
    DisplayImageOptions options;

    LinearLayout shareButton;
    int imagePosition;

      public void onCreate(Bundle savedInstanceState)
      {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.single_itemview);

        Intent intent = getIntent();
        Bundle bundle = intent.getExtras();
        if(bundle!=null){ 
            imagePosition = bundle.getInt("imagePosition");
        } 

        ImageView imageView = (ImageView) findViewById(R.id.pager);

        shareButton = (LinearLayout)findViewById(R.id.btn_share);
        ImageLoader imageLoader = ImageLoader.getInstance();
        imageLoader.displayImage(imageUrls.get(imagePosition), imageView);

        imageView.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                Intent i = new Intent(ProductDetail.this, WebViewActivity.class);
                i.putExtra("productUrl", productUrl.get(imagePosition));
                startActivity(i);

            }
        });

        shareButton.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                Intent sharingIntent = new Intent(Intent.ACTION_SEND);
                sharingIntent.setType("text/plain");
                sharingIntent.putExtra(android.content.Intent.EXTRA_TEXT, productUrl.get(imagePosition));
                startActivity(Intent.createChooser(sharingIntent,"Share With?"));

            }
        });
        }
      }

和 logcat 输出:

02-12 10:53:45.405: E/AndroidRuntime(31742): FATAL EXCEPTION: main
02-12 10:53:45.405: E/AndroidRuntime(31742): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example/com.example.ProductDetail}: java.lang.IndexOutOfBoundsException: Invalid index 11, size is 0
02-12 10:53:45.405: E/AndroidRuntime(31742):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2295)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2349)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at android.app.ActivityThread.access$700(ActivityThread.java:159)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1316)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at android.os.Handler.dispatchMessage(Handler.java:99)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at android.os.Looper.loop(Looper.java:176)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at android.app.ActivityThread.main(ActivityThread.java:5419)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at java.lang.reflect.Method.invokeNative(Native Method)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at java.lang.reflect.Method.invoke(Method.java:525)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1046)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:862)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at dalvik.system.NativeStart.main(Native Method)
02-12 10:53:45.405: E/AndroidRuntime(31742): Caused by: java.lang.IndexOutOfBoundsException: Invalid index 11, size is 0
02-12 10:53:45.405: E/AndroidRuntime(31742):    at java.util.ArrayList.throwIndexOutOfBoundsException(ArrayList.java:255)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at java.util.ArrayList.get(ArrayList.java:308)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at com.example.ProductDetail.onCreate(ProductDetail.java:39)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at android.app.Activity.performCreate(Activity.java:5372)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1104)
02-12 10:53:45.405: E/AndroidRuntime(31742):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2257)
4

1 回答 1

1

Data.BIGIMAGE显然是空的。为了证明这一点,请替换此行

imageLoader.displayImage(imageUrls.get(imagePosition), imageView);

有了这个

if (Data.BIGIMAGE != null && Data.BIGIMAGE.size() > 0) {
  imageLoader.displayImage(Data.BIGIMAGE.get(imagePosition), imageView);
} else {
  Log.e(getClass().getSimpleName(), "Data.BIGIMAGE is null or empty");
}
于 2015-02-12T09:36:56.973 回答