我做了个思考,用View来代替Activity会不会更好呢?

PageActivity

仓库地址

我做了个思考,用View来代替Activity会不会更好呢?

兼容性检查
模块兼容性
API~90%
生命周期模拟
转场动画支持
页面自动回收与恢复支持
启动模式未知
数据传输支持

代码示例

MainActivity


class MainActivity : PageDocker() {

    override fun onGetHomePage(): Class<out PageActivity> {
        return MainPageActivity::class.java
    }

    override fun onPreInjectRootLayout() {

    }

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
    }

    //自定义容器布局
    override fun onCustomDockerLayout(): FrameLayout? {
        return super.onCustomDockerLayout()
    }
}

MainPageActivity


class MainPageActivity(context: Context) : PageActivity(context) {

    private val mViewBinding by lazy { MainPageActivityLayoutBinding.bind(this.getPageWindows().pageActivity) }
    private var num = 0

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.main_page_activity_layout)

        mViewBinding.btNext.setOnClickListener {
            val intent = Intent(context,SubPageActivity::class.java)
            intent.putExtra("title","标题${++num}")
            startActivityForResult(intent,1)
        }

        mViewBinding.btShowDialog.setOnClickListener {
            val dialog = HomeDialog(this)
            dialog.onClick {
                dialog.dismiss()
            }
            dialog.show()
        }
    }

    override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
        super.onActivityResult(requestCode, resultCode, data)

    }

}

SubPageActivity


class SubPageActivity(context: Context) : PageActivity(context) {

    private val mViewBinding by lazy { SubPageActivityLayoutBinding.bind(this.getPageWindows().pageActivity) }
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)

        setContentView(R.layout.sub_page_activity_layout)

        mViewBinding.btBack.setOnClickListener {
            this.setResult(RESULT_OK, Intent().apply {
                this.data = Uri.parse("https://www.hao123.com")
            })
            this.finish()
        }
        mViewBinding.btNewPage.setOnClickListener {
            startActivity(SubPageActivity::class.java)
        }
    }

    override fun onPreEnterStartAnim(animId: Int, function: () -> Unit) {
        scaleX = 0.8f
        scaleY = 0.8f
        translationX = getScreenWidth().toFloat()
        animate().scaleX(1f).scaleY(1f).translationX(0f).onEnd{
            function()
        }
    }

    override fun onPreExitFinishAnim(function: () -> Unit) {
        animate().scaleX(0.8f).scaleY(0.8f).translationX(getScreenWidth().toFloat()).onEnd{
            function()
        }
    }

    private fun ViewPropertyAnimator.onEnd(function:()->Unit): ViewPropertyAnimator {
        this.setListener(object : Animator.AnimatorListener{
            override fun onAnimationStart(animation: Animator?) {
            }

            override fun onAnimationEnd(animation: Animator?) {
                function()
            }

            override fun onAnimationCancel(animation: Animator?) {
            }

            override fun onAnimationRepeat(animation: Animator?) {
            }

        })
        return this
    }
}

HomeDialog


@SuppressLint("ViewConstructor")
class HomeDialog(mPageActivity: BasePageActivity) : PageDialog(mPageActivity) {

    override fun onCreate() {
        setContentView(R.layout.home_dialog_layout)
        setCancelable(false)
        setCanceledOnTouchOutside(false)
        listenerClick(R.id.btOk)
        listenerClick(R.id.btCancel)
    }
}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将一个Activity转换成一个View并显示,可以按以下步骤操作: 1. 在Activity中,创建一个布局文件,用来显示界面上的各个控件和视图。 2. 在Activity中重写onCreateView()方法,在该方法中加载布局文件,生成View对象并返回。 3. 在Activity中获取FragmentManager对象,并通过调用FragmentManager.beginTransaction()方法创建一个FragmentTransaction对象。 4. 在FragmentTransaction对象中,使用add()方法将生成的View对象添加到要显示它的布局容器中。 5. 调用commit()方法提交事务,完成将Activity转换成View并显示的操作。 以下是一个简单的示例代码: ``` public class MyActivity extends Activity { @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { // 加载布局文件 View view = inflater.inflate(R.layout.my_layout, container, false); // 返回生成的View对象 return view; } public void showAsView(ViewGroup container) { // 获取FragmentManager对象 FragmentManager fragmentManager = getFragmentManager(); // 创建FragmentTransaction对象 FragmentTransaction transaction = fragmentManager.beginTransaction(); // 将生成的View对象添加到要显示它的布局容器中 transaction.add(container.getId(), this); // 提交事务,完成将Activity转换成View并显示的操作 transaction.commit(); } } ``` 在代码中,MyActivity继承自Activity类,并重写了onCreateView()方法,用来加载布局文件并生成View对象。同时,还提供了一个showAsView()方法,用来将该Activity转换成View并显示在指定的布局容器中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值