片段不能转换为 android.app.activity

Posted

技术标签:

【中文标题】片段不能转换为 android.app.activity【英文标题】:Fragment cannot be cast to android.app.activity 【发布时间】:2014-01-01 19:50:18 【问题描述】:

我知道以前有人问过这个问题,但他们的情况与我不同。

我的问题是我的 PostPhotosActivity 类需要保留实例。我这样做的方式是将它变成一个片段。不幸的是,我总是遇到这个错误。

   12-13 14:38:55.669: E/androidRuntime(30234): FATAL EXCEPTION: main

12-13 14:38:55.669: E/AndroidRuntime(30234): java.lang.RuntimeException: Unable to instantiate activity ComponentInfotrade.ly.tradely/trade.ly.tradely.PostPhotosActivity: java.lang.ClassCastException: trade.ly.tradely.PostPhotosActivity cannot be cast to android.app.Activity

12-13 14:38:55.669: E/AndroidRuntime(30234):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2106)

12-13 14:38:55.669: E/AndroidRuntime(30234):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)

12-13 14:38:55.669: E/AndroidRuntime(30234):    at android.app.ActivityThread.access$600(ActivityThread.java:141)

12-13 14:38:55.669: E/AndroidRuntime(30234):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)

12-13 14:38:55.669: E/AndroidRuntime(30234):    at android.os.Handler.dispatchMessage(Handler.java:99)

12-13 14:38:55.669: E/AndroidRuntime(30234):    at android.os.Looper.loop(Looper.java:137)

12-13 14:38:55.669: E/AndroidRuntime(30234):    at android.app.ActivityThread.main(ActivityThread.java:5039)

12-13 14:38:55.669: E/AndroidRuntime(30234):    at java.lang.reflect.Method.invokeNative(Native Method)

12-13 14:38:55.669: E/AndroidRuntime(30234):    at java.lang.reflect.Method.invoke(Method.java:511)

12-13 14:38:55.669: E/AndroidRuntime(30234):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)

12-13 14:38:55.669: E/AndroidRuntime(30234):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)

12-13 14:38:55.669: E/AndroidRuntime(30234):    at dalvik.system.NativeStart.main(Native Method)

12-13 14:38:55.669: E/AndroidRuntime(30234): Caused by: java.lang.ClassCastException: trade.ly.tradely.PostPhotosActivity cannot be cast to android.app.Activity

12-13 14:38:55.669: E/AndroidRuntime(30234):    at android.app.Instrumentation.newActivity(Instrumentation.java:1054)

12-13 14:38:55.669: E/AndroidRuntime(30234):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097)

12-13 14:38:55.669: E/AndroidRuntime(30234): ... 11 more

这是导致所有错误的 PostPhotosActivity。

public class PostPhotosActivity extends android.app.Fragment 

public static final String TAG = "PostPhotosActivity";

String title, price, description, maincat, subcat, pname, pemail, pphone, pmeet, imageUri;

public static final String TEMP_PHOTO_FILE_NAME = "temp_photo.jpg";

public static final int REQUEST_CODE_GALLERY      = 0x1;
public static final int REQUEST_CODE_TAKE_PICTURE = 0x2;
public static final int REQUEST_CODE_CROP_IMAGE   = 0x3;
private ImageView mImageView;
private File      mFileTemp;
ParseFile file;
double latitude;
final String[] items = new String[]  "Take from camera", "Select from gallery" ;

double longitude;
Button button;



@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
        Bundle savedInstanceState) 


     View view = inflater.inflate(R.layout.activity_post_photos, container,false);


     Bundle extras= getActivity().getIntent().getExtras();
     if(extras!=null)
     
        title = extras.getString("TITLE"); // get the value based on the key
        price = extras.getString("PRICE"); // get the value based on the key 
        description = extras.getString("DESCRIPTION"); // get the value based on the key
        maincat = extras.getString("MAINCAT"); // get the value based on the key 
        subcat = extras.getString("SUBCAT"); // get the value based on the key
        pname = extras.getString("PNAME"); // get the value based on the key 
        pemail = extras.getString("PEMAIL"); // get the value based on the key
        pphone = extras.getString("PPHONE"); // get the value based on the key 
        pmeet = extras.getString("PMEET"); // get the value based on the key
        latitude = extras.getDouble("lat");
        longitude = extras.getDouble("long");
      



Button newPost = (Button)view.findViewById(R.id.post_data);
newPost.setVisibility(View.INVISIBLE);

newPost.setOnClickListener(new View.OnClickListener() 
    public void onClick(View v) 
        // Perform action on click

        ParseGeoPoint point = new ParseGeoPoint(latitude, longitude);
        ParseObject setPost = new ParseObject("Posts");

        // Create an author relationship with the current user
        setPost.put("author", ParseUser.getCurrentUser());

        // Get location

        setPost.put("location", point);
        setPost.put("Title", title);
        setPost.put("Price", price);
        setPost.put("Description", description);
        setPost.put("MainCat", maincat);
        setPost.put("SubCat", subcat);
        setPost.put("PName", pname);
        setPost.put("PEmail", pemail);
        setPost.put("PPhone", pphone);
        setPost.put("PMeet", pmeet);
        setPost.put("Photo", file);

        setPost.saveInBackground();

        Intent intent = new Intent(getActivity(), Flow.class);
       startActivity(intent);
    
);



    ArrayAdapter<String> adapter = new ArrayAdapter<String>(getActivity(), android.R.layout.select_dialog_item, items);
    AlertDialog.Builder builder = new AlertDialog.Builder(getActivity());

    builder.setTitle("Select Image");
    builder.setAdapter(adapter, new DialogInterface.OnClickListener() 
        public void onClick(DialogInterface dialog, int item)  // pick from
                                                                // camera
            if (item == 0) 

                takePicture();

             else  // pick from file

                openGallery();

            
        
    );

    final AlertDialog dialog = builder.create();

    mImageView = (ImageView) view.findViewById(R.id.iv_photo);
    mImageView.setOnClickListener(new OnClickListener() 
        public void onClick(View v) 

            dialog.show();
        
    );



        String state = Environment.getExternalStorageState();
        if (Environment.MEDIA_MOUNTED.equals(state)) 
                mFileTemp = new File(Environment.getExternalStorageDirectory(), TEMP_PHOTO_FILE_NAME);
        
        else 
                mFileTemp = new File(getActivity().getFilesDir(), TEMP_PHOTO_FILE_NAME);
        
        setRetainInstance(true);
        return view;



private void takePicture() 

    Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);

    try 
            Uri mImageCaptureUri = null;
            String state = Environment.getExternalStorageState();
            if (Environment.MEDIA_MOUNTED.equals(state)) 
                    mImageCaptureUri = Uri.fromFile(mFileTemp);
            
            else 
                    /*
                     * The solution is taken from here: http://***.com/questions/10042695/how-to-get-camera-result-as-a-uri-in-data-folder
                     */
                    mImageCaptureUri = InternalStorageContentProvider.CONTENT_URI;
                    
        intent.putExtra(android.provider.MediaStore.EXTRA_OUTPUT, mImageCaptureUri);
        intent.putExtra("return-data", true);
        startActivityForResult(intent, REQUEST_CODE_TAKE_PICTURE);
     catch (ActivityNotFoundException e) 

        Log.d(TAG, "cannot take picture", e);
    


private void openGallery() 

    Intent photoPickerIntent = new Intent(Intent.ACTION_PICK);
    photoPickerIntent.setType("image/*");
    startActivityForResult(photoPickerIntent, REQUEST_CODE_GALLERY);


private void startCropImage() 

    Intent intent = new Intent(getActivity(), CropImage.class);
    intent.putExtra(CropImage.IMAGE_PATH, mFileTemp.getPath());
    intent.putExtra(CropImage.SCALE, true);

    intent.putExtra(CropImage.ASPECT_X, 1);
    intent.putExtra(CropImage.ASPECT_Y, 1);

    startActivityForResult(intent, REQUEST_CODE_CROP_IMAGE);


@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) 

    if (resultCode != Activity.RESULT_OK) 

        return;
    

    Bitmap bitmap;

    switch (requestCode) 

        case REQUEST_CODE_GALLERY:

            try 

                InputStream inputStream = getActivity().getContentResolver().openInputStream(data.getData());
                FileOutputStream fileOutputStream = new FileOutputStream(mFileTemp);
                copyStream(inputStream, fileOutputStream);
                fileOutputStream.close();
                inputStream.close();

                startCropImage();

             catch (Exception e) 

                Log.e(TAG, "Error while creating temp file", e);
            

            break;
        case REQUEST_CODE_TAKE_PICTURE:

            startCropImage();
            break;
        case REQUEST_CODE_CROP_IMAGE:

            String path = data.getStringExtra(CropImage.IMAGE_PATH);
            if (path == null) 

                return;
            

            //byte[] idata = path.getBytes();
            Bitmap picture = BitmapFactory.decodeFile(path);
            ByteArrayOutputStream stream = new ByteArrayOutputStream();
            picture.compress(Bitmap.CompressFormat.JPEG, 100, stream);
            // get byte array here
            byte[] idata= stream.toByteArray();

            file = new ParseFile("photo.jpg", idata);
            file.saveInBackground();

            bitmap = BitmapFactory.decodeFile(mFileTemp.getPath());

            mImageView.setImageBitmap(bitmap);
            button.setVisibility(View.VISIBLE);
            break;
    
    super.onActivityResult(requestCode, resultCode, data);






public static void copyStream(InputStream input, OutputStream output)
        throws IOException 

    byte[] buffer = new byte[1024];
    int bytesRead;
    while ((bytesRead = input.read(buffer)) != -1) 
        output.write(buffer, 0, bytesRead);
    



清单

 <activity
        android:name="trade.ly.tradely.PostPhotosActivity"
        android:label="@string/title_activity_post_photos">
    </activity>

在点击时创建片段的类 Activity

    public class PostActivity extends FragmentActivity implements
PageFragmentCallbacks, ReviewFragment.Callbacks, ModelCallbacks 
    private ViewPager mPager;
    private MyPagerAdapter mPagerAdapter;

    private boolean mEditingAfterReview;

    private AbstractWizardModel mWizardModel = new SandwichWizardModel(this);

    private boolean mConsumePageSelectedEvent;

    private Button mNextButton;
    private Button mPrevButton;
    String user_name;
    String uemail;

    private List<Page> mCurrentPageSequence;
    private StepPagerStrip mStepPagerStrip;

    public static final String TAG = "PostActivity";
    double latitude, longitude;

    public void onCreate(Bundle savedInstanceState) 


        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_post);

        Bundle extras = getIntent().getExtras();
        if(extras !=null) 
        // Get the results
        user_name = extras.getString("name");
        uemail = extras.getString("email");
           

        Bundle data = new Bundle();
        if (!TextUtils.isEmpty(CustomerInfoPage.EMAIL_DATA_KEY)) 
           data.putString(CustomerInfoPage.EMAIL_DATA_KEY, uemail);
           mWizardModel.findByKey("Your Info").resetData(data);
     

        GpsLocationTracker mGpsLocationTracker = new GpsLocationTracker(PostActivity.this);


        // Set GPS Location fetched address

       if (mGpsLocationTracker.canGetLocation()) 
       
           latitude = mGpsLocationTracker.getLatitude();
           longitude = mGpsLocationTracker.getLongitude();
           Log.i(TAG, String.format("latitude: %s", latitude));
           Log.i(TAG, String.format("longitude: %s", longitude));

        
       else 
       
           mGpsLocationTracker.showSettingsAlert();
       

        if (savedInstanceState != null) 
            mWizardModel.load(savedInstanceState.getBundle("model"));
        

        mWizardModel.registerListener(this);

        mPagerAdapter = new MyPagerAdapter(getSupportFragmentManager());
        mPager = (ViewPager) findViewById(R.id.pager);
        mPager.setAdapter(mPagerAdapter);
        mStepPagerStrip = (StepPagerStrip) findViewById(R.id.strip);
        mStepPagerStrip.setOnPageSelectedListener(new StepPagerStrip.OnPageSelectedListener() 
            @Override
            public void onPageStripSelected(int position) 
                position = Math.min(mPagerAdapter.getCount() - 1, position);
                if (mPager.getCurrentItem() != position) 
                    mPager.setCurrentItem(position);
                
            
        );

        mNextButton = (Button) findViewById(R.id.next_button);
        mPrevButton = (Button) findViewById(R.id.prev_button);

        mPager.setOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() 
            @Override
            public void onPageSelected(int position) 
                mStepPagerStrip.setCurrentPage(position);

                if (mConsumePageSelectedEvent) 
                    mConsumePageSelectedEvent = false;
                    return;
                

                mEditingAfterReview = false;
                updateBottomBar();
            
        );

        mNextButton.setOnClickListener(new View.OnClickListener() 
            @SuppressLint("ValidFragment")
            @Override
            public void onClick(View view) 

                if (mPager.getCurrentItem() == mCurrentPageSequence.size()) 


                    DialogFragment dg = new DialogFragment() 
                        @Override
                        public Dialog onCreateDialog(Bundle savedInstanceState) 
                            return new AlertDialog.Builder(getActivity())
                                    .setMessage(R.string.submit_confirm_message)
                                    .setPositiveButton(
                                            R.string.submit_confirm_button,
                                            new DialogInterface.OnClickListener() 
                                                public void onClick(
                                                        DialogInterface dialog,
                                                        int id) 

                                                    String title = mWizardModel
                                                            .findByKey(
                                                                    "Post Info")
                                                            .getData()
                                                            .getString(
                                                                    TpdModel.TITLE_DATA_KEY);

                                                    String price = mWizardModel
                                                            .findByKey(
                                                                    "Post Info")
                                                            .getData()
                                                            .getString(
                                                                    TpdModel.PRICE_DATA_KEY);

                                                    String description = mWizardModel
                                                            .findByKey(
                                                                    "Post Info")
                                                            .getData()
                                                            .getString(
                                                                    TpdModel.DESCRIPTION_DATA_KEY);

                                                    String maincat = mWizardModel
                                                            .findByKey(
                                                                    "Main Category")
                                                            .getData()
                                                            .getString(
                                                                    Page.SIMPLE_DATA_KEY);

                                                    String subcat = mWizardModel
                                                            .findByKey(
                                                                    "Sub Category")
                                                            .getData()
                                                            .getString(
                                                                    Page.SIMPLE_DATA_KEY);

                                                    String pname = mWizardModel
                                                            .findByKey(
                                                                    "Your Info")
                                                            .getData()
                                                            .getString(
                                                                    CustomerInfoPage.NAME_DATA_KEY);

                                                    String pemail = mWizardModel
                                                            .findByKey(
                                                                    "Your Info")
                                                            .getData()
                                                            .getString(
                                                                    CustomerInfoPage.EMAIL_DATA_KEY);

                                                    String pphone = mWizardModel
                                                            .findByKey(
                                                                    "Your Info")
                                                            .getData()
                                                            .getString(
                                                                    CustomerInfoPage.PHONE_DATA_KEY);

                                                    String pmeet = mWizardModel
                                                            .findByKey(
                                                                    "Your Info")
                                                            .getData()
                                                            .getString(
                                                                    CustomerInfoPage.MEET_DATA_KEY);

                                                    Intent i = new Intent(
                                                            PostActivity.this,
                                                            PostPhotosActivity.class);
                                                    i.putExtra("TITLE", title);
                                                    i.putExtra("PRICE", price);
                                                    i.putExtra("DESCRIPTION",
                                                            description);
                                                    i.putExtra("MAINCAT",
                                                            maincat);
                                                    i.putExtra("SUBCAT", subcat);
                                                    i.putExtra("PNAME", pname);
                                                    i.putExtra("PEMAIL", pemail);
                                                    i.putExtra("PPHONE", pphone);
                                                    i.putExtra("PMEET", pmeet);
                                                    i.putExtra("lat", latitude);
                                                    i.putExtra("long", longitude);
                                                    startActivityForResult(i, 0);

                                                
                                            )
                                    .setNegativeButton(android.R.string.cancel,
                                            null).create();
                        

                    ;
                dg.show(getSupportFragmentManager(), "place_order_dialog");
             else 
                    if (mEditingAfterReview) 
                        mPager.setCurrentItem(mPagerAdapter.getCount() - 1);
                     else 
                        mPager.setCurrentItem(mPager.getCurrentItem() + 1);
                    
                

            
        );

        mPrevButton.setOnClickListener(new View.OnClickListener() 
            @Override
            public void onClick(View view) 
                    mPager.setCurrentItem(mPager.getCurrentItem() - 1);
            
    );

    onPageTreeChanged();
    updateBottomBar();


@Override
public void onPageTreeChanged() 
    mCurrentPageSequence = mWizardModel.getCurrentPageSequence();
    recalculateCutOffPage();
    mStepPagerStrip.setPageCount(mCurrentPageSequence.size() + 1); // + 1 =
                                                                                                                                    // review
                                                                                                                                    // step
    mPagerAdapter.notifyDataSetChanged();
    updateBottomBar();


private void updateBottomBar() 
    int position = mPager.getCurrentItem();
    if (position == mCurrentPageSequence.size()) 
            mNextButton.setText(R.string.finish);
            mNextButton.setBackgroundResource(R.drawable.finish_background);
            mNextButton.setTextAppearance(this, R.style.TextAppearanceFinish);
     else 
            mNextButton.setText(mEditingAfterReview ? R.string.review
                            : R.string.next);
            mNextButton
                            .setBackgroundResource(R.drawable.selectable_item_background);
            TypedValue v = new TypedValue();
            getTheme().resolveAttribute(android.R.attr.textAppearanceMedium, v,
                            true);
            mNextButton.setTextAppearance(this, v.resourceId);
            mNextButton.setEnabled(position != mPagerAdapter.getCutOffPage());
    

    mPrevButton
                    .setVisibility(position <= 0 ? View.INVISIBLE : View.VISIBLE);


@Override
protected void onDestroy() 
    super.onDestroy();
    mWizardModel.unregisterListener(this);


@Override
protected void onSaveInstanceState(Bundle outState) 
    super.onSaveInstanceState(outState);
    outState.putBundle("model", mWizardModel.save());


@Override
public AbstractWizardModel onGetModel() 
    return mWizardModel;


@Override
public void onEditScreenAfterReview(String key) 
    for (int i = mCurrentPageSequence.size() - 1; i >= 0; i--) 
            if (mCurrentPageSequence.get(i).getKey().equals(key)) 
                    mConsumePageSelectedEvent = true;
                    mEditingAfterReview = true;
                    mPager.setCurrentItem(i);
                    updateBottomBar();
                    break;
            
    


@Override
public void onPageDataChanged(Page page) 
    if (page.isRequired()) 
            if (recalculateCutOffPage()) 
                    mPagerAdapter.notifyDataSetChanged();
                    updateBottomBar();
            
    


@Override
public Page onGetPage(String key) 
    return mWizardModel.findByKey(key);


private boolean recalculateCutOffPage() 
    // Cut off the pager adapter at first required page that isn't completed
    int cutOffPage = mCurrentPageSequence.size() + 1;
    for (int i = 0; i < mCurrentPageSequence.size(); i++) 
            Page page = mCurrentPageSequence.get(i);
            if (page.isRequired() && !page.isCompleted()) 
                    cutOffPage = i;
                    break;
            
    

    if (mPagerAdapter.getCutOffPage() != cutOffPage) 
            mPagerAdapter.setCutOffPage(cutOffPage);
            return true;
    

    return false;


public class MyPagerAdapter extends FragmentStatePagerAdapter 
    private int mCutOffPage;
    private Fragment mPrimaryItem;

    public MyPagerAdapter(FragmentManager fm) 
            super(fm);
    

    @Override
    public Fragment getItem(int i) 
            if (i >= mCurrentPageSequence.size()) 
                    return new ReviewFragment();
            

            return mCurrentPageSequence.get(i).createFragment();
    

    @Override
    public int getItemPosition(Object object) 
            // TODO: be smarter about this
            if (object == mPrimaryItem) 
                    // Re-use the current fragment (its position never changes)
                    return POSITION_UNCHANGED;
            

            return POSITION_NONE;
    

    @Override
    public void setPrimaryItem(ViewGroup container, int position,
                    Object object) 
            super.setPrimaryItem(container, position, object);
            mPrimaryItem = (Fragment) object;
    

    @Override
    public int getCount() 
            return Math.min(mCutOffPage + 1, mCurrentPageSequence == null ? 1
                            : mCurrentPageSequence.size() + 1);
    

    public void setCutOffPage(int cutOffPage) 
            if (cutOffPage < 0) 
                    cutOffPage = Integer.MAX_VALUE;
            
            mCutOffPage = cutOffPage;
    

    public int getCutOffPage() 
            return mCutOffPage;
    

    

【问题讨论】:

请发布整个堆栈跟踪。 请在创建或使用 PostPhotosActivity 类(清单或代码中的某处)时发布代码片段。片段不是一个活动,我认为你正试图在需要活动的地方使用这个片段。 请检查编辑! 【参考方案1】:

您不能将PostPhotosActivity 用作活动,因为它不是活动。它是片段,因为它扩展了Fragment 而不是Activity。在你的清单中有这个是一个错误,并在意图上调用 startActivityForResult

Intent i = new Intent(
PostActivity.this,
PostPhotosActivity.class);

导致转换异常,因为 Fragment 无法转换为 Activity

您可以在其他活动中使用带有此片段的 xml 布局或将片段更改为活动。 xml布局示例:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="horizontal"
    android:layout_ android:layout_>

    <fragment class="com.example.PostPhotosFragment"
            android:id="@+id/post_photos_fragment"
            android:layout_ android:layout_ />


</LinearLayout>

然后在扩展Activity 类的一些活动中调用setContentView(R.layout.yourlayout),您的片段将在您的活动中创建。

【讨论】:

非常感谢!我试图解决的实际问题并没有解决,但这个问题已经解决了。

以上是关于片段不能转换为 android.app.activity的主要内容,如果未能解决你的问题,请参考以下文章

对象不能从 DBNull 转换为其他类型。

HTTP转换为null什么意思?

如何将活动转换为片段以在抽屉中使用

片段无法转换为上下文

为啥在片段中从 char* 转换为 std::string 比转换为 const char* 更可取?

无法将整数强制转换为android.support.design.widget.FloatingActionButton