私はAndroid開発の初心者です.今、私は下のように画像のように円形のギャラリービューをしたいと思っています.ユーザーが左から右、右から左にスクロールするときに中央の画像を拡大したい. そのためのチュートリアルはありますか?
私が欲しいのは、スワイプされた画像が中央にある間に拡大する必要があることです。ギャラリーでできると思いました。しかし、アンドロイド開発者の例は私が望むものではありません。:(
私はAndroid開発の初心者です.今、私は下のように画像のように円形のギャラリービューをしたいと思っています.ユーザーが左から右、右から左にスクロールするときに中央の画像を拡大したい. そのためのチュートリアルはありますか?
私が欲しいのは、スワイプされた画像が中央にある間に拡大する必要があることです。ギャラリーでできると思いました。しかし、アンドロイド開発者の例は私が望むものではありません。:(
あなたが試すことができます:
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;
}
}}
中央の選択した画像を拡大したい場合、考えられる方法が 1 つあります。onItemSelected メソッドで、アニメーションを呼び出してオブジェクトをズームします。gallery の特性は、常にセンターロックされることです。したがって、中央の要素が常に選択されます。それがうまくいくことを願っています..
<?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 の 2 つのビューを使用できます。
currView でアニメーションを実行します。
ありがとう、
セン
このための独自のチュートリアルを作成しました: 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,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 をオーバーライドしてサイズを操作する必要があります。最後のビューへの参照を保存することを忘れないでください。そうすれば、次のビューに到達したときに、拡大ではなく通常の外観にすることができます。
上記のチュートリアルでこの両方を実装しました