Google Plus の投票アニメーションを作成する方法についてのアイデア/リファレンスはありますか? ボタン(ビュー)用とビューグループ用の2つのアニメーションがあると思います。任意の提案をいただければ幸いです。ありがとう。
Google Plus の投票アニメーションを作成する方法についてのアイデア/リファレンスはありますか? ボタン(ビュー)用とビューグループ用の2つのアニメーションがあると思います。任意の提案をいただければ幸いです。ありがとう。
良いニュースは、数時間を費やした後、最終的に解決策が見つかったことです。これは私のコードであり、将来他の人に役立つことを願っています。
1- res/anim の下に最初の xml ファイルを作成します (私の場合は btn_anim.xml):
<?xml version="1.0" encoding="utf-8"?>
<set
xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/decelerate_interpolator">
<translate
android:fromXDelta="0.0"
android:fromYDelta="0.0"
android:toXDelta="0.0"
android:toYDelta="-75.0"
android:duration="350"
android:fillBefore="true"
android:fillAfter="true" />
<scale
android:fromXScale="1.0"
android:fromYScale="1.0"
android:toXScale="1.05"
android:toYScale="1.0"
android:pivotX="50%"
android:pivotY="50%"
android:duration="350"
android:fillBefore="true"
android:fillAfter="true"/>
</set>
2- res/anim の下に 2 番目の xml ファイルを作成します (私の場合は layout_anim.xml):
<?xml version="1.0" encoding="utf-8"?>
<set
xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/decelerate_interpolator">
<scale
android:fromXScale="1.0"
android:fromYScale="1.0"
android:toXScale="0.95"
android:toYScale="0.95"
android:pivotX="50%"
android:pivotY="50%"
android:duration="100"
android:fillBefore="true"
android:fillAfter="true"/>
</set>
3-アクティビティ(またはフラグメント)に次のコードを追加します。
...
private ScrollView scrollView; // This is my container. Yours may be different
private Animation btnAnim;
private Animation layoutAnim;
...
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
// Getting context
context = getActivity().getApplicationContext();
btnAnim = AnimationUtils.loadAnimation(context, R.anim.btn_anim);
btnAnim.setAnimationListener(new Animation.AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {
}
@Override
public void onAnimationEnd(Animation animation) {
layoutAnim = AnimationUtils.loadAnimation(context, R.anim.layout_anim);
scrollView.startAnimation(layoutAnim);
}
@Override
public void onAnimationRepeat(Animation animation) {
}
});
// create view
View view = inflater.inflate(R.layout.fragment_browse_single, container, false);
scrollView = (ScrollView) view.findViewById(R.id.scrollView);
myButton = (Button) view.findViewById(R.id.myButton);
myButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
btnFancy.startAnimation(btnAnim);
}
});
Log.i(TAG, "View created");
return view;
}