Android Gallery setSelection()とonFling()の方法の違い
2843 ワード
galleryには要素を最下位にする必要があるため、私たちの実現方法はGalleryをレイアウトにandroid:layout_を設定することです.alignParentBottom="true";しかし、Galleryのデフォルトの方法は要素を中心にしており、この方法はソースコードのprivateにあるので、書き換えることはできません.だから、ここでは曲がって、Galleryの高さをパッケージ画像の高さに設定するしかありません.このようにgalleryAdapterでは、リアルタイムで画像の高さを取りに行かなければなりません.そうすれば、galleryに要素を底に置く必要があります.
しかし、galleryには自動ラウンドとスライドをサポートする必要があります.ここに問題があったとは思わなかった.オートキャストではsetSelection()という方法を使っていますが、この方法は異なる高さの画像表示に問題はありませんが、スライドしてはいけません.ソースコードを見てみるとsetSelection()という方法にはrequestLayoutとinvalidateを実現する方法があり,スライドにはこの2つの方法が実現されていないことが分かった.どうやらこの原因らしい.そしてこの2つの方法を調べました.
requestLayout:viewが既存の領域に適していないと判断した場合、view自体がこのメソッドを呼び出し、parent viewにonMeasure onLayoutを再呼び出して自分の位置を再設定するように要求します.特にviewのlayoutparameterが変更され、その値がviewに適用されていない場合は、このメソッドを呼び出すのに適しています.invalidate:View自体が呼び出してviewを再描画させます.
だからGalleryソースコードにonTouchEvent()メソッドで設定したときにこのメソッドを入れればいいのです.
しかし、galleryには自動ラウンドとスライドをサポートする必要があります.ここに問題があったとは思わなかった.オートキャストではsetSelection()という方法を使っていますが、この方法は異なる高さの画像表示に問題はありませんが、スライドしてはいけません.ソースコードを見てみるとsetSelection()という方法にはrequestLayoutとinvalidateを実現する方法があり,スライドにはこの2つの方法が実現されていないことが分かった.どうやらこの原因らしい.そしてこの2つの方法を調べました.
requestLayout:viewが既存の領域に適していないと判断した場合、view自体がこのメソッドを呼び出し、parent viewにonMeasure onLayoutを再呼び出して自分の位置を再設定するように要求します.特にviewのlayoutparameterが変更され、その値がviewに適用されていない場合は、このメソッドを呼び出すのに適しています.invalidate:View自体が呼び出してviewを再描画させます.
だからGalleryソースコードにonTouchEvent()メソッドで設定したときにこのメソッドを入れればいいのです.
package com.geekpark.utils;
import android.content.Context;
import android.graphics.Camera;
import android.util.AttributeSet;
import android.view.KeyEvent;
import android.view.MotionEvent;
import android.view.View;
import android.view.animation.Transformation;
import android.widget.Gallery;
public class CustomGallery extends Gallery {
public CustomGallery(Context context) {
super(context);
}
public CustomGallery(Context context, AttributeSet attrs) {
super(context, attrs);
}
public CustomGallery(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
int position = getSelectedItemPosition()%getChildCount();
int kEvent;
if (isScrollingLeft(e1, e2)) {
// Check if scrolling left
kEvent = KeyEvent.KEYCODE_DPAD_LEFT;
} else {
// Otherwise scrolling right
kEvent = KeyEvent.KEYCODE_DPAD_RIGHT;
}
return onKeyDown(kEvent, null);
// return true;
}
private boolean isScrollingLeft(MotionEvent e1, MotionEvent e2) {
return e2.getX() > e1.getX();
}
protected boolean getChildStaticTransformation(View child, Transformation t) {
return super.getChildStaticTransformation(child, t);
}
public boolean onTouchEvent(MotionEvent event) {
boolean result;
if(event.getAction() == MotionEvent.ACTION_UP){
requestLayout();
invalidate();
}
try {
result = super.onTouchEvent(event);
} catch (NullPointerException e) {
result = false;
} catch (OutOfMemoryError ex) {
ex.printStackTrace();
result = false;
System.gc();
System.gc();
}
return result;
}
}