创建扩展Activity的BaseActivityClass

来源:爱站网时间:2022-10-24编辑:网友分享
想要在java中创建扩展Activity的BaseActivityClass,想必不少朋友都忘记了如何操作,为了帮助大家恢复记忆,爱站技术频道小编进行了问题描述方式来告诉大家,接下来就一起看一看 。

问题描述


我创建了一个看起来像这样的可重用的xml布局

我想在不同的活动上使用相同的组件,我想做的是创建扩展活动的BaseActivityClass

public class BaseActivityClass extends Activity {
    int layout_id = R.layout.SomeLayout;
    final int menu_button_id = R.id.menuButton;
    final int save_button_id = R.id.saveButton;

    protected void onCreate(Bundle savedInstanceState) {
       super.onCreate(savedInstanceState);
       setContentView(layout_id);

       Button btn = findViewById(menu_button_id);
       btn.setOnClickListener(new OnClickListener() {
        @Override
        public void onClick(View v) {
            //this functionality will be same on every child class
        }
       });
   }
}

我想将该类扩展为

public class SomeActivityClass extends BaseActivityClass {
    int layout_id = R.layout.SomeOtherLayout;

    protected void onCreate(Bundle savedInstanceState) {
       super.onCreate(savedInstanceState);
    }
}

没有Activity的构造函数类。在意图调用中,仅引用了类名。并且子类无法更改(隐藏)超类变量。

我不想将粘贴在BaseActivityClass中的相同代码复制到其他类中。包装器类可以解决问题,但imo似乎太草率。

我该如何解决这个设计问题?我可以对任何想法发表评论

思路:


听起来像您想要base类控制主容器布局,并允许derived类提供“内容”布局。那是对的吗?如果是这样,您可以使用此模式:

步骤1-将ViewStub添加到基本布局。一些伪代码给你的想法:

<ConstraintLayout>
   <!-- Common Stuff -->
   <Button id="menu">
   <Button id="save">

   <!-- "Content" area to be filled by derived classes -->
   <ViewStub id="viewStub" />

</ConstraintLayout>

[步骤2-更新您的基本布局,以提供一种将内容膨胀到“内容区域”的方法。一些伪代码:

public abstract class BaseActivityClass extends Activity {
    int layout_id = R.layout.SomeLayout;
    final int menu_button_id = R.id.menuButton;
    final int save_button_id = R.id.saveButton;

    protected void onCreate(Bundle savedInstanceState) {
       super.onCreate(savedInstanceState);
       setContentView(layout_id);

       Button btn = findViewById(menu_button_id);
       btn.setOnClickListener(new OnClickListener() {
        @Override
        public void onClick(View v) {
            //this functionality will be same on every child class
        }
       });

       // Get the ViewStub, set the derived class's content layout on it and inflate it,
       // thereby displaying the derived class's view layout within the base class's 
       // "content area"
       ViewStub vs = findViewById(viewStub);
       vs.setLayout(getContentLayoutId());
       vs.inflate();
   }

   // Define abstract method that all derived classes must implement to provide
   // the id of the layout to show in the "content area"
   @LayoutRes
   public abstract int getContentLayoutId();
}

第3步-更新派生类以提供要显示的布局。一些伪代码:

public class SomeActivityClass extends BaseActivityClass {
    int layout_id = R.layout.SomeOtherLayout;

    protected void onCreate(Bundle savedInstanceState) {
       super.onCreate(savedInstanceState);
    }

    @Override
    @LayoutRes
    public int getContentLayoutId() { return layout_id; }
}

现在创建SomeActivityClass时,它将调用超类onCreate,该类会夸大您的基本布局,然后向派生类询问要推送到“内容区域”的主要内容布局。

我已经在我的项目中使用了这种模式,并且效果很好。


[另一种选择是仅通过超类构造函数传递布局ID。如果基本Activity为abstract,它将永远不会被实例化,也不必遵守零参数构造函数规则。只有您的派生类可以。因此,您可以执行以下操作:

public abstract class BaseActivityClass extends Activity {
    private final int mContentLayoutId;
    protected BaseActivityClass(int contentLayoutId) {
        mContentLayoutId = contentLayoutId;
    }

    protected void onCreate(Bundle state) {
        // Same code to load ViewStub, but use mContentLayoutId instead
    }
}

public SomeOtherActivity extends BaseActivity {
    public SomeOtherActivity() {
        super(R.layout.SomeOtherLayout); // Call super with derived layout
    }
}

希望创建扩展Activity的BaseActivityClass文章对大家有帮助!想要了解更多技术文章内容的朋友,可以来爱站技术频道网站查找翻阅,会让你有意想不到的收获。

上一篇:Java获取类对象的解决方法

下一篇:Java编程中GPIO解构函数的详细介绍

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载