From a1d1fb7c44e33c4baeb52964a027932018bc1325 Mon Sep 17 00:00:00 2001 From: Linjiajia <319408893@qq.com> Date: 星期二, 04 四月 2023 16:35:39 +0800 Subject: [PATCH] 家大事记添加接口、家庭资产、家庭设备 --- app/src/main/java/com/application/zhangshi_app_android/ui/function/CreateFamilyProjectActivity.java | 132 ++++++++++++++++++++++++++++++++++++------- 1 files changed, 109 insertions(+), 23 deletions(-) diff --git a/app/src/main/java/com/application/zhangshi_app_android/ui/function/CreateFamilyProjectActivity.java b/app/src/main/java/com/application/zhangshi_app_android/ui/function/CreateFamilyProjectActivity.java index 4c9fced..40ecd10 100644 --- a/app/src/main/java/com/application/zhangshi_app_android/ui/function/CreateFamilyProjectActivity.java +++ b/app/src/main/java/com/application/zhangshi_app_android/ui/function/CreateFamilyProjectActivity.java @@ -1,39 +1,47 @@ package com.application.zhangshi_app_android.ui.function; import android.graphics.drawable.ColorDrawable; -import android.os.Bundle; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; +import android.widget.EditText; import android.widget.PopupWindow; -import androidx.annotation.Nullable; -import androidx.databinding.DataBindingUtil; +import androidx.recyclerview.widget.GridLayoutManager; import com.android.app_base.base.BaseConfig; import com.android.app_base.base.dialog.BaseDialog; import com.android.app_base.base.dialog.UIDialog; import com.android.app_base.base.view.BaseActivity; +import com.android.app_base.manager.UserManager; import com.android.app_base.utils.ScreenSizeUtils; -import com.android.app_base.utils.ToastUtils; -import com.android.app_base.widget.LinearItemDecoration; import com.application.zhangshi_app_android.BR; import com.application.zhangshi_app_android.R; +import com.application.zhangshi_app_android.adapter.ImageRvAdapter; import com.application.zhangshi_app_android.bean.FamilyMemorabiliaBean; -import com.application.zhangshi_app_android.databinding.ItemFamilyCreateBinding; +import com.application.zhangshi_app_android.databinding.ActivityFamilyMemorabiliaCreateBinding; +import com.luck.picture.lib.entity.LocalMedia; +import com.luck.picture.lib.interfaces.OnResultCallbackListener; + +import java.io.File; +import java.util.ArrayList; +import java.util.function.Consumer; + /** * @author Gss * @date 2023.03.25. 16:00 * @desc 瀹跺ぇ浜嬭 CreateFamilyProjectActivity */ -public class CreateFamilyProjectActivity extends BaseActivity<ItemFamilyCreateBinding,CreateFamilyProjectActivityViewModel> { +public class CreateFamilyProjectActivity extends BaseActivity<ActivityFamilyMemorabiliaCreateBinding,CreateFamilyProjectActivityViewModel> { private int type; - private int operateType; private PopupWindow popupWindow; + private FamilyMemorabiliaBean bean; + private ImageRvAdapter adapter; + @Override public int getLayoutId() { - return R.layout.item_family_create; + return R.layout.activity_family_memorabilia_create; } @Override @@ -45,7 +53,7 @@ public void initParam() { type = getIntent().getIntExtra(BaseConfig.EXTRA_TYPE,0); if (type == 0){ - FamilyMemorabiliaBean bean = (FamilyMemorabiliaBean) getIntent().getSerializableExtra("bean"); + bean = (FamilyMemorabiliaBean) getIntent().getSerializableExtra("bean"); if (bean!=null){ viewModel.getBeanMutableLiveData().postValue(bean); } @@ -54,13 +62,43 @@ @Override public void initView() { + adapter = new ImageRvAdapter(this); + GridLayoutManager gridLayoutManager = new GridLayoutManager(this, 3); + binding.rvImage.setLayoutManager(gridLayoutManager); + binding.rvImage.setNestedScrollingEnabled(false); + View footerView = View.inflate(this,R.layout.item_image_footer,null); + binding.rvImage.addFooterView(footerView); + footerView.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + UserManager.getInstance().selectImage(getSelfActivity(), 9, new OnResultCallbackListener<LocalMedia>() { + @Override + public void onResult(ArrayList<LocalMedia> result) { + if (result.size() == 0) return; + for (LocalMedia media : result) { + String path = media.getRealPath(); + File file = new File(path); + if (file.exists()) { + viewModel.uploadFile(file); + } + } + } + + @Override + public void onCancel() { + + } + }); + } + }); + binding.rvImage.setAdapter(adapter); + if (type == 1){ - binding.ivOperate.setBackgroundResource(R.drawable.ic_operate_finish); + viewModel.getTypeLiveData().postValue(true); binding.ivOperate.setOnClickListener(v -> { viewModel.add(); }); }else { - binding.ivOperate.setBackgroundResource(R.drawable.ic_operate); popupWindow = new PopupWindow(this); // 璁剧疆甯冨眬鏂囦欢 popupWindow.setContentView(LayoutInflater.from(this).inflate(R.layout.pop_operate_delete, null)); @@ -78,18 +116,10 @@ // 璁剧疆鐐瑰嚮pop澶栦晶娑堝け锛岄粯璁や负false锛涘湪focusable涓簍rue鏃剁偣鍑诲渚у缁堟秷澶� popupWindow.setOutsideTouchable(true); - binding.ivOperate.setOnClickListener(v -> { - if (operateType == 0){ - popupWindow.showAsDropDown(binding.ivOperate,-ScreenSizeUtils.dip2px(this,85) +binding.ivOperate.getWidth(),0); - }else{ - viewModel.update(); - } - }); popupWindow.getContentView().findViewById(R.id.tv_modify).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { - binding.ivOperate.setBackgroundResource(R.drawable.ic_operate_finish); - operateType = 1; + viewModel.getTypeLiveData().postValue(true); popupWindow.dismiss(); } }); @@ -111,7 +141,9 @@ .show(); } }); + viewModel.getTypeLiveData().postValue(false); } + } @Override @@ -122,8 +154,62 @@ @Override public void initLiveDataObserve() { - + viewModel.getBeanMutableLiveData().observe(this,bean -> { + if (bean!=null){ + bean.setUrl(bean.getUrl()); + adapter.setData(bean.getUrlList()); + } + }); + viewModel.getTypeLiveData().observe(this,operateType -> { + if (operateType){ + if (type == 1) { + binding.ivOperate.setOnClickListener(v -> { + viewModel.add(); + }); + }else { + binding.ivOperate.setOnClickListener(v -> { + viewModel.update(); + }); + } + binding.rvImage.getFooterViews().forEach(new Consumer<View>() { + @Override + public void accept(View view) { + view.setVisibility(View.VISIBLE); + } + }); + setIsEdited(true); + }else { + binding.ivOperate.setOnClickListener(v -> { + popupWindow.showAsDropDown(binding.ivOperate,-ScreenSizeUtils.dip2px(this,85) +binding.ivOperate.getWidth(),0); + }); + binding.rvImage.getFooterViews().forEach(new Consumer<View>() { + @Override + public void accept(View view) { + view.setVisibility(View.GONE); + } + }); + setIsEdited(false); + } + }); } - + public void setIsEdited(boolean isEdited){ + disableAllEditText(getContentView(),isEdited); + adapter.setIsEdited(isEdited); + } + public void disableAllEditText(ViewGroup viewGroup,boolean isEdited) { + for (int i = 0; i < viewGroup.getChildCount(); i++) { + View child = viewGroup.getChildAt(i); + if (child instanceof ViewGroup) { + disableAllEditText((ViewGroup) child,isEdited); + } else if (child instanceof EditText) { + child.setEnabled(isEdited); + child.setFocusable(isEdited); + child.setFocusableInTouchMode(isEdited); + if (!isEdited){ + child.clearFocus(); + } + } + } + } } -- Gitblit v1.9.1