0

FragmentActivity で ViewPager を使用しています。これで、Activity が起動するたびに、position値をnewinstanceフラグメントのメソッドに渡します。そこから、私のフラグメントはドローアブルのリソース ID を選択し、背景として設定します。

マイフラグメントアクティビティ

import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentStatePagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.LayoutParams;
import android.view.ViewGroup;
import android.view.Window;

public class HowToActivity extends FragmentActivity {

    @Override
    public void onBackPressed() {
        super.onBackPressed();
        overridePendingTransition(R.anim.slide_out_bottom, R.anim.slide_in_top);

    }


    private ViewPager mViewPager;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_NO_TITLE);  // remove title

        mViewPager = new ViewPager(this);
        mViewPager.setId(R.id.viewPager_howto);

        setContentView(mViewPager);

        getWindow().setLayout(LayoutParams.MATCH_PARENT /* width */ , LayoutParams.MATCH_PARENT /* height */);

        FragmentManager fm = this.getSupportFragmentManager();
        mViewPager.setAdapter(new FragmentStatePagerAdapter(fm){

            @Override
            public void setPrimaryItem(ViewGroup container, int position,
                    Object object) {
                super.setPrimaryItem(container, position, object);
            }

            @Override
            public int getCount() {
                return 3;

            }
            @Override
            public Fragment getItem(int position) {
                 return HowToFragment.newInstance(position);
            }

        });
    }

}

私のフラグメント

import android.os.AsyncTask;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentStatePagerAdapter;
import android.support.v4.app.FragmentTransaction;
import android.support.v4.view.ViewPager;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

public class HowToFragment extends Fragment {

    private static int image_pos;
    private int[] image_id = {R.drawable.image_1, R.drawable.image_2, R.drawable.image_3};

    public static Fragment newInstance(int pos){
        image_pos = pos;
        return new HowToFragment();
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        View v = inflater.inflate(R.layout.fragment_how_to_image, container, false);
        v.setBackgroundResource(image_id[image_pos]);
        return v;
    }

}

起動時のimage_2.png代わりに常に表示されます。次に、位置を固定するには、その位置image_1までスワイプする必要があります。と から前後にスワイプすると、各フラグメントに表示されます。image_32image_1001image_2

私が間違っていたアイデアはありますか?

4

2 に答える 2

2

その変数を静的にすることはできません

private static int image_pos;

すべてのフラグメントは同じものを使用しているため、作成すると常に 2 番目のフラグメントが表示されます。

FG[0] newInstance -> image_pos=0;
FG[1] newInstance -> image_pos=1;

そして、フラグメントがビューを作成するとき:

FG[0] onCreateView -> value of image_pos=1;
FG[1] onCreateView -> value of image_pos=1;

代わりにこれを作ってください:

private int image_pos;
private int[] image_id = {R.drawable.image_1, R.drawable.image_2, R.drawable.image_3};

public static Fragment newInstance(int pos){
    HowToFragment fg = new HowToFragment();
    fg.image_pos = pos;
    return fg;
}

また、アダプター内の画像を使用して配列を定義し、フラグメント作成メソッドに Id を渡すだけです。

于 2013-10-08T07:25:45.597 に答える