質問

私はAndroid開発の初心者です。今、以下の画像のように円形でギャラリービューをしたいと考えています。問題は、ユーザーが左から右、右から左にスクロールしたときに中央の画像を拡大したいということです。そのためのチュートリアルはありますか?

enter image description here私が望むのは、スワイプされた画像が中央にあるときに拡大する必要があることです。ギャラリーならそれができると思いました。しかし、Android 開発者からの例は私が望むものではありません。:(

役に立ちましたか?

解決


あなたはセンター選択した画像を拡大したい場合は1つの可能な方法があります。 あなたのonItemSelected方法では、単にオブジェクトをズームするアニメーションを呼び出します。ギャラリーのプロパティは、それが常にセンターロックであるということです。だから、中央の要素は常に選択されます。 働くことを願っています..

<?xml version="1.0" encoding="utf-8"?>
<set
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:shareInterpolator="false"
    android:fillAfter="true"
>
<scale 
       android:fromXScale="1.0"
       android:toXScale="1.50"
       android:fromYScale="1.0"
       android:toYScale="1.50"
       android:duration="600"
       android:pivotX="50%"
       android:pivotY="50%"
       android:fillAfter="true"/>

</set>

要素は、それが通常のサイズに置くべきである中心部から離れて移動するときのように、あなたが前のビューを保存する必要がありますことを覚えています。

あなたは二つのビュー持つことができるので - 。prevViewとcurrViewを
currView上のアニメーションを行います。

おかげで、
セン

他のヒント

youcan試します:

public class TestGallery extends Activity {
/** Called when the activity is first created. */
private Integer[] mImageIds = { R.drawable.sample_1, R.drawable.sample_2, R.drawable.sample_3, R.drawable.sample_4 }; 

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    Gallery g = (Gallery) findViewById(R.id.gallery); 
    g.setAdapter(new ImageAdapter(this)); 

    g.setOnItemClickListener(new OnItemClickListener() { 
        public void onItemClick(AdapterView parent, View v, int position, long id) { 
            if (position >= mImageIds.length) { 
                position = position % mImageIds.length; 
            } 
            Toast.makeText(TestGallery.this, "" + position, Toast.LENGTH_SHORT).show(); 
        } 
    }); 

}

public class ImageAdapter extends BaseAdapter { 
    int mGalleryItemBackground; 
    private Context mContext; 

    public ImageAdapter(Context c) { 
        mContext = c; 
        TypedArray a = obtainStyledAttributes(R.styleable.Gallery1); 
        mGalleryItemBackground = a.getResourceId(R.styleable.Gallery1_android_galleryItemBackground, 0); 

        a.recycle(); 
    } 

    public int getCount() { 
        return Integer.MAX_VALUE; 
    } 

    public Object getItem(int position) { 
        if (position >= mImageIds.length) { 
            position = position % mImageIds.length; 
        } 
        return position; 
    } 

    public long getItemId(int position) { 
        if (position >= mImageIds.length) { 
            position = position % mImageIds.length; 
        } 
        return position; 
    } 

    public View getView(int position, View convertView, ViewGroup parent) { 
        ImageView i = new ImageView(mContext); 
        if (position >= mImageIds.length) { 
            position = position % mImageIds.length; 
        } 
        i.setImageResource(mImageIds[position]); 
        i.setLayoutParams(new Gallery.LayoutParams(80, 80)); 
        i.setScaleType(ImageView.ScaleType.FIT_XY); 
        i.setBackgroundResource(mGalleryItemBackground); 
        return i; 
    } 

    public int checkPosition(int position) { 
        if (position >= mImageIds.length) { 
            position = position % mImageIds.length; 
        } 
        return position; 
    } 
}}

このために独自のチュートリアルを作成しました。http://evgeni-shafran.blogspot.com/2011/08/tutorial-custom-gallery-circular-and.html

円形にするには、実際に持っているよりもはるかに多くのアイテムがあると思わせる必要があります。

そして、position= Position % items.length を作成することで、次のようなものを作成します(3 つのアイテムについて示します)。1,2,3,1,2,3,1,2,3,1,2,3,1,2,3,1,1,2,3,1,2,3、そしてその後、真ん中に移動してください。巻物は、彼が最後まで近くに来ることはありません。1,2,3,1,2,3,1,2,3,->1<-,2,3,1,2,3,1,2,3,1,2,3

選択するには:setOnItemSelectedListener をオーバーライドしてサイズを操作する必要があります。最後のビューへの参照を保存することを忘れないでください。そうすれば、次のビューに到達したときに、拡大ではなく通常の外観にできるようになります。

上記のチュートリアルでこれの両方を実装しました

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top