How to share common layout between activities without fragment

后端 未结 3 1314
挽巷
挽巷 2021-02-02 18:11

Is there any possible way to share layout(part) between activities? For example, in my app, all activities have similar layout, the top part is long operation indicator (a progr

相关标签:
3条回答
  • 2021-02-02 18:52

    You could use include in XML to, well.. include the re-useable part of your layout code.

    As an example, here's my layout file for the Toolbar I used in my app:

    // /res/layout/component_toolbar.xml
    
    <android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:taggr="http://schemas.android.com/apk/res-auto"
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@color/primary"
        android:minHeight="?attr/actionBarSize"
        taggr:popupTheme="@style/ThemeOverlay.AppCompat.Light"
        taggr:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar" />
    

    Now, say if I want to use that Toolbar again in a different Activity, this is all I'd have to write:

    // /res/layout/whatever_layout_this_might_be.xml
    
    <include layout="@layout/component_toolbar" />
    

    Bear in mind that this would only copy the layout - not the actual behavior of said widget/component.

    If you want to actually copy all of the aspects (layout, behaviour) I'm afraid Fragment is the only way to go.

    0 讨论(0)
  • 2021-02-02 18:58

    You can create an abstract 'base' activity that all your activities extend from, overriding setContentView to merge the base, and sub activity layouts.

    This way you can handle all the loading/error code in the base activity, and simply toggle between hiding and showing the views in the sub activities.

    The abstract activity:

    public abstract class BaseActivity extends Activity {
    
        protected RelativeLayout fullLayout;
        protected FrameLayout subActivityContent;
    
        @Override
        public void setContentView(int layoutResID) {
            fullLayout = (RelativeLayout) getLayoutInflater().inflate(R.layout.activity_base, null);  // The base layout
            subActivityContent = (FrameLayout) fullLayout.findViewById(R.id.content_frame);            // The frame layout where the activity content is placed.
            getLayoutInflater().inflate(layoutResID, subActivityContent, true);            // Places the activity layout inside the activity content frame.
            super.setContentView(fullLayout);                                                       // Sets the content view as the merged layouts.
        }
    
    }
    

    the layout file:

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
    
    
        <!-- The main content view -->
        <FrameLayout
            android:id="@+id/loading_frame"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" />
    
        <!-- The main content view -->
        <FrameLayout
            android:id="@+id/content_frame"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
    
        <FrameLayout
            android:id="@+id/error_frame"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" />
    
    </RelativeLayout>
    
    0 讨论(0)
  • 2021-02-02 18:59

    Although ActivityGroup is deprecated fro API 13 but if you don't wish to go with fragments then this can be your best choice.

    According to documentation, an ActivityGroup is:

    A screen that contains and runs multiple embedded activities.

    You can find a tutorial here and here Although the mentioned tutorial uses a Tablayout you can replace that with your common layout in XML.

    A second Approach could be Reuse the layout with include tag, in this approach you could just reuse your once created common layout everywhere in the app.

    0 讨论(0)
提交回复
热议问题