简体   繁体   English

以编程方式将transitionName添加到工具栏标题(Android)

[英]Programmatically add transitionName to Toolbar Title (Android)

Is it possible to programmatically set the xml property transitionName to a Toolbar title and then use it for an animation using ActivityOptionsCompat ? 是否可以以编程方式将xml属性transitionName设置为Toolbar标题,然后使用ActivityOptionsCompat将其用于动画?

This is how I declare my Toolbar : 这就是我声明Toolbar

        Toolbar myToolbar = (Toolbar) findViewById(R.id.my_toolbar);
        myToolbar.setTitle("title");

And this is my xml declaration: 这是我的xml声明:

<android.support.v7.widget.Toolbar
        android:id="@+id/my_toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:background="@color/primary_color"
        android:elevation="4dp"
        android:theme="@style/ThemeOverlay.AppCompat.ActionBar"
        android:popupTheme="@style/ThemeOverlay.AppCompat.Light"/>

In order to add the animation I have to use the following code: 为了添加动画,我必须使用以下代码:

ActivityOptionsCompat options =
ActivityOptionsCompat.makeSceneTransitionAnimation(activity,
    albumCoverImageView,   // The view which starts the transition (Should be myToolbar title)
    transitionName    // The transitionName of the view
    );
ActivityCompat.startActivity(activity, intent, options.toBundle());

How can I pass the Toolbar ( TextView ?) title to the makeSceneTransitionAnimation function? 如何将ToolbarTextView ?)标题传递给makeSceneTransitionAnimation函数?

You can get the TextView instance of the Toolbar 's title and set transition by following this code: 您可以通过以下代码获取Toolbar标题的TextView实例并设置转换:

private Toolbar mToolbar;
private TextView mTextViewToolbarTitle;

@Override
protected void onCreated(Bundle savedInstanceState){
    super.onCreate(savedInstanceState);
    setContentView(R.layout.your_layout);
    mToolbar = (Toolbar) findViewById(R.id.your_toolbar_id);
    setSupportActionBar(mToolbar);

    mTextViewToolbarTitle = getTextViewTitle(mToolbar);
    if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
        mTextViewTitle.setTransitionName(getString(R.string.your_transition_name));
    }
}

Copy this method in your activity: 在您的活动中复制此方法:

public static TextView getTextViewTitle(Toolbar toolbar){
    TextView textViewTitle = null;
    for(int i = 0; i<toolbar.getChildCount(); i++) {
        View view = toolbar.getChildAt(i);
        if(view instanceof TextView) {
            textViewTitle = (TextView) view;
            break;
        }
    }
    return textViewTitle;
}

then start your new activity with transition by: 然后通过以下方式开始您的新活动:

if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
    startActivity(intent, 
        ActivityOptionsCompat.makeSceneTransitionAnimation(this, 
                                            mTextViewToolbarTitle, 
                                            getString(R.string.your_transition_name))
                                               .toBundle());
} else {
    startActivity(intent,
        ActivityOptionsCompat.makeSceneTransitionAnimation(this).toBundle());
}

Yes this is possible: 是的,这是可能的:

classes that extend ViewCompat are able to call setTransitionName(String name) 扩展ViewCompat类能够调用setTransitionName(String name)

for example: 例如:

myToolbar.setTransitionName("ToolbarTransition");

UPDATE it seems your specifically trying to share the Title so i would do something like the following: 更新似乎你特意尝试分享标题,所以我会做类似以下的事情:

Example xml for MainActivity: MainActivity的示例xml:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.divshark.toolbaranimation.MainActivity"
    xmlns:app="http://schemas.android.com/apk/res-auto">
    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="?actionBarSize"
        android:background="?attr/colorPrimary"
        app:popupTheme="@style/ThemeOverlay.AppCompat.Light">

        <android.support.v7.widget.AppCompatTextView
            android:id="@+id/tv_title"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:textSize="18sp"
            android:textColor="@android:color/white"
            android:text="Activity Title" />
    </android.support.v7.widget.Toolbar>

    <android.support.v7.widget.AppCompatButton
        android:id="@+id/btnNext"
        android:text="Next"
        android:layout_centerInParent="true"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />
</RelativeLayout>

Then in your Activity reference that view: 然后在您的Activity引用中查看该视图:

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Toolbar mToolbar = (Toolbar) findViewById(R.id.toolbar);
        final AppCompatTextView mTextView = (AppCompatTextView) mToolbar.findViewById(R.id.tv_title);

        if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
            mTextView.setTransitionName("SimpleTransition");
        }

        AppCompatButton mBtnNext = (AppCompatButton) findViewById(R.id.btnNext);
        mBtnNext.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

                Intent secondActivity = new Intent(MainActivity.this, SecondActivity.class);
                if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
                    ActivityOptionsCompat options = ActivityOptionsCompat.makeSceneTransitionAnimation(MainActivity.this, mTextView, mTextView.getTransitionName());
                    startActivity(secondActivity, options.toBundle());
                } else {
                    startActivity(secondActivity);
                }
            }
        });
    }
}

then in your SecondActivity: 然后在你的SecondActivity中:

public class SecondActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.second_activity);

        AppCompatTextView mTextView = (AppCompatTextView) findViewById(R.id.tv_title);
        if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
            mTextView.setTransitionName("SimpleTransition");
        }
    }
}

using this xml: 使用这个xml:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">


    <android.support.v7.widget.AppCompatTextView
        android:id="@+id/tv_title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textSize="18sp"
        android:layout_centerInParent="true"
        android:textColor="@android:color/black"
        android:text="Activity Title" />
</RelativeLayout>

as you can see you are allowed to call setTransitionName(String name) programmatically using ViewCompat views 如您所见,您可以使用ViewCompat视图以编程方式调用setTransitionName(String name)

Good luck and Happy Coding! 祝你好运,快乐编码!

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM