我在Activity中成功完成了动画(相同活动布局中的satrting和destination)。但我希望它从子片段转移到其父Activity的工具栏中的布局。以前给我制作动画的COde。
工具栏xml布局
<android.support.v7.widget.Toolbar android:id="@+id/products_toolbar"
android:layout_width="wrap_content"
android:layout_height="?attr/actionBarSize"
android:background="@android:color/transparent"
app:layout_collapseMode="pin"
app:titleTextColor="@android:color/white"
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<RelativeLayout
android:id="@+id/cartRelativeLayout"
android:layout_width="0dp"
android:layout_weight=".15"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:clickable="true"
android:paddingRight="3dip">
<ImageButton
android:id="@+id/cartButtonIV"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@android:color/transparent"
android:clickable="false"
android:src="@drawable/cart" />
<TextView
android:id="@+id/textNotify"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignRight="@id/cartButtonIV"
android:layout_alignTop="@id/cartButtonIV"
android:layout_marginRight="5dip"
android:layout_marginTop="5dip"
android:background="@drawable/notification_circle"
android:gravity="center"
android:minHeight="20dip"
android:minWidth="20dip"
android:padding="3dip"
android:text="0"
android:textColor="#424242"
android:textSize="12sp" />
</RelativeLayout>
Fragment中用于启动动画的方法
private void makeFlyAnimation(ImageView targetView) {
toolbar = getActivity().findViewById(R.id.toolbar);
RelativeLayout destView = (RelativeLayout)toolbar.findViewById(R.id.cartRelativeLayout);
ImageButton dest = (ImageButton)toolbar.findViewById(R.id.cartButtonIV);
new CircleAnimationUtil().attachActivity(getActivity()).setTargetView(targetView).setMoveDuration(1000).setDestView(dest).setAnimationListener(new Animator.AnimatorListener() {
@Override
public void onAnimationStart(Animator animation) {
}
@Override
public void onAnimationEnd(Animator animation) {
addItemToCart();
}
@Override
public void onAnimationCancel(Animator animation) {
}
@Override
public void onAnimationRepeat(Animator animation) {
}
}).startAnimation();
}
private void addItemToCart() {
((NavHomeActivity)getActivity()).addItemToCart2("2");
}
在下面的CircleAnimationUtil.class方法中,即使我从makeFlyAnimation函数向其传递活动,我也将视图视为null。
public CircleAnimationUtil setTargetView(View view) {
Log.e("view here",""+view);
mTarget = view;
setOriginRect(mTarget.getWidth(), mTarget.getHeight());
return this;
}
有人请给我一个解决方案。
使用目标Fragment
实现此目的
public class First extends Fragment{
public void startSecondFragmentForResult(){
Fragment second = Second.newInstance()
second.setTargetFragment(this);
fm.beginTranstaction().replace(second).commit();
}
@Override
public void onActivityResult(int reqCode, int resCode, Intent data){
// do something on result
}
}
第二片段
public class Second extends Fragment{
public void postResultToCaller(){
Intent intent = new Intent();
getTargetFragment().onActivityResult(getTargetRequestCode(), resultCode, intent);
}
}