ListView
私はアンドロイドで簡単なリスト結果を持っています。各アイテムをクリックすると、下にスライドして展開し、コンテンツを表示したいと思います。Androidでこれを行う簡単な方法はありますか?
どんな助けでも大歓迎です。
ListView
私はアンドロイドで簡単なリスト結果を持っています。各アイテムをクリックすると、下にスライドして展開し、コンテンツを表示したいと思います。Androidでこれを行う簡単な方法はありますか?
どんな助けでも大歓迎です。
これはウディニッチの例です。リストビュー項目がアニメーションで展開され、API レベルのみが必要です 4+ 基本的にアニメーション クラスが必要です
/**
* This animation class is animating the expanding and reducing the size of a view.
* The animation toggles between the Expand and Reduce, depending on the current state of the view
* @author Udinic
*
*/
public class ExpandAnimation extends Animation {
private View mAnimatedView;
private LayoutParams mViewLayoutParams;
private int mMarginStart, mMarginEnd;
private boolean mIsVisibleAfter = false;
private boolean mWasEndedAlready = false;
/**
* Initialize the animation
* @param view The layout we want to animate
* @param duration The duration of the animation, in ms
*/
public ExpandAnimation(View view, int duration) {
setDuration(duration);
mAnimatedView = view;
mViewLayoutParams = (LayoutParams) view.getLayoutParams();
// decide to show or hide the view
mIsVisibleAfter = (view.getVisibility() == View.VISIBLE);
mMarginStart = mViewLayoutParams.bottomMargin;
mMarginEnd = (mMarginStart == 0 ? (0- view.getHeight()) : 0);
view.setVisibility(View.VISIBLE);
}
@Override
protected void applyTransformation(float interpolatedTime, Transformation t) {
super.applyTransformation(interpolatedTime, t);
if (interpolatedTime < 1.0f) {
// Calculating the new bottom margin, and setting it
mViewLayoutParams.bottomMargin = mMarginStart
+ (int) ((mMarginEnd - mMarginStart) * interpolatedTime);
// Invalidating the layout, making us seeing the changes we made
mAnimatedView.requestLayout();
// Making sure we didn't run the ending before (it happens!)
} else if (!mWasEndedAlready) {
mViewLayoutParams.bottomMargin = mMarginEnd;
mAnimatedView.requestLayout();
if (mIsVisibleAfter) {
mAnimatedView.setVisibility(View.GONE);
}
mWasEndedAlready = true;
}
}
}
そしてこれを使用します:
View toolbar = view.findViewById(R.id.toolbar);
// Creating the expand animation for the item
ExpandAnimation expandAni = new ExpandAnimation(toolbar, 500);
// Start the animation on the toolbar
toolbar.startAnimation(expandAni);
この回答をチェックしてください。それ以上に、ツイード アニメーションを使用する必要があります。ApiDemos/Animation2の例を確認してください。ApiDemos の anim フォルダーも参照してください。それは私にとってとても役に立ちます。あなたの質問によると、slide_top_to_bottom が役立ちます。