From 82e57df230ecb744af6c8865f80870ba03c86d89 Mon Sep 17 00:00:00 2001 From: Linjiajia <319408893@qq.com> Date: 星期二, 25 七月 2023 22:18:27 +0800 Subject: [PATCH] 基本功能完成 --- app/src/main/java/com/application/zhangshi_app_android/ui/function/FamilyMemorabiliaActivity.java | 262 +++++++++++++++++++++++++++++++++++----------------- 1 files changed, 177 insertions(+), 85 deletions(-) diff --git a/app/src/main/java/com/application/zhangshi_app_android/ui/function/FamilyMemorabiliaActivity.java b/app/src/main/java/com/application/zhangshi_app_android/ui/function/FamilyMemorabiliaActivity.java index 2ef8c27..fce4d09 100644 --- a/app/src/main/java/com/application/zhangshi_app_android/ui/function/FamilyMemorabiliaActivity.java +++ b/app/src/main/java/com/application/zhangshi_app_android/ui/function/FamilyMemorabiliaActivity.java @@ -1,16 +1,13 @@ package com.application.zhangshi_app_android.ui.function; import android.content.Intent; -import android.graphics.drawable.ColorDrawable; -import android.view.KeyEvent; -import android.view.LayoutInflater; +import android.text.Editable; +import android.text.TextUtils; +import android.text.TextWatcher; +import android.view.MotionEvent; import android.view.View; -import android.view.ViewGroup; -import android.view.inputmethod.EditorInfo; import android.widget.PopupWindow; -import android.widget.TextView; -import androidx.databinding.DataBindingUtil; import androidx.lifecycle.Observer; import com.android.app_base.base.BaseConfig; @@ -18,28 +15,34 @@ import com.android.app_base.base.dialog.UIDialog; import com.android.app_base.manager.AppManager; import com.android.app_base.utils.ScreenSizeUtils; +import com.android.app_base.utils.Utils; +import com.android.app_base.utils.rxbus.RxBus; 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.FamilyMemorabiliaRvAdapter; import com.application.zhangshi_app_android.bean.FamilyMemorabiliaBean; import com.application.zhangshi_app_android.databinding.ActivityFamilyMemorabiliaBinding; -import com.application.zhangshi_app_android.databinding.PopSearchBinding; import com.application.zhangshi_app_android.ui.DLBaseActivity; +import com.github.gzuliyujiang.wheelpicker.DatePicker; +import com.github.gzuliyujiang.wheelpicker.contract.OnDatePickedListener; +import java.util.Calendar; import java.util.List; + +import io.reactivex.functions.Consumer; /** * @author Ljj * @date 2023.03.18. 10:00 * @desc 瀹跺ぇ浜嬭 Activity */ -public class FamilyMemorabiliaActivity extends DLBaseActivity<ActivityFamilyMemorabiliaBinding,FamilyMemorabiliaActivityViewModel> { +public class FamilyMemorabiliaActivity extends DLBaseActivity<ActivityFamilyMemorabiliaBinding,FamilyMemorabiliaActivityViewModel>{ FamilyMemorabiliaRvAdapter adapter; private PopupWindow mOperatePopupWindow; - private PopupWindow mSearchPopupWindow; - private PopSearchBinding mSearchPopBinding; + private boolean isSearchLayoutVisible; + private int dateType; //0:寮�濮嬫椂闂� 1:缁撴潫鏃堕棿 @Override public int getLayoutId() { @@ -58,79 +61,166 @@ @Override public void initView() { + //涓嬫媺鍒锋柊甯冨眬 binding.refreshLayout.setEnableRefresh(false); binding.refreshLayout.setEnableLoadMore(true); binding.refreshLayout.setEnableOverScrollDrag(true); - binding.refreshLayout.setOnLoadMoreListener(refreshLayout -> { + binding.refreshLayout.setOnLoadMoreListener(refreshLayout -> { viewModel.getMoreFamilyMemorabilia(); }); - + //recyclerView閫傞厤鍣� adapter = new FamilyMemorabiliaRvAdapter(this,viewModel); LinearItemDecoration itemDecoration = new LinearItemDecoration(); itemDecoration.setBottomSpace((int) getResources().getDimension(com.android.app_base.R.dimen.dp_12)); itemDecoration.setHorizontalSpace((int) getResources().getDimension(com.android.app_base.R.dimen.dp_20)); - itemDecoration.setFirstTop((int) getResources().getDimension(com.android.app_base.R.dimen.dp_20)); binding.recyclerView.addItemDecoration(itemDecoration); binding.recyclerView.setAdapter(adapter); - - mSearchPopBinding = DataBindingUtil.inflate(LayoutInflater.from(this), R.layout.pop_search, null, false); - mSearchPopBinding.setViewModel(viewModel); - mSearchPopupWindow = initPopUpWindow(mSearchPopBinding.getRoot()); - + //鍙充笂瑙掓搷浣滃脊绐� mOperatePopupWindow = initPopUpWindow(View.inflate(this,R.layout.pop_operate,null)); - + setOnClickListener( + mOperatePopupWindow.getContentView().findViewById(R.id.tv_add), + mOperatePopupWindow.getContentView().findViewById(R.id.tv_select), + mOperatePopupWindow.getContentView().findViewById(R.id.tv_from_new_to_old), + mOperatePopupWindow.getContentView().findViewById(R.id.tv_from_old_to_new) + ); + //鐐瑰嚮鏀惧ぇ闀滄寜閽樉绀哄嚭鎼滅储妗� binding.ivSearchDefault.setOnClickListener(v -> { binding.layoutSearch.setVisibility(View.VISIBLE); binding.layoutDefault.setVisibility(View.GONE); }); - + //鐐瑰嚮鎼滅储妗嗚彍鍗曚笅鎷夊嚭 鎼滅储鍙傛暟 binding.ivSearchType.setOnClickListener(v -> { - hideSoftKeyboard(); - mSearchPopupWindow.setWidth(binding.layoutSearch.getMeasuredWidth()); - mSearchPopupWindow.showAsDropDown(binding.layoutSearch,0,0); - }); - - binding.etSearch.setOnEditorActionListener(new TextView.OnEditorActionListener() { - @Override - public boolean onEditorAction(TextView v, int actionId, KeyEvent event) { - if ((actionId == EditorInfo.IME_ACTION_UNSPECIFIED || actionId == EditorInfo.IME_ACTION_SEARCH) - && event != null) { - viewModel.getFamilyMemorabilia(); - binding.layoutSearch.setVisibility(View.GONE); - binding.layoutDefault.setVisibility(View.VISIBLE); - binding.tvTitle.setText("鎼滅储缁撴灉"); - hideSoftKeyboard(); - return true; - } - return false; + if (!isSearchLayoutVisible){ + binding.layoutSearchParameter.measure(View.MeasureSpec.UNSPECIFIED, View.MeasureSpec.UNSPECIFIED); + int targetHeight = binding.layoutSearchParameter.getMeasuredHeight(); + Utils.pullCollapse(binding.containerSearchParameter,0,targetHeight); + isSearchLayoutVisible = true; } }); + //鎼滅储鍙傛暟layout娣诲姞绌虹偣鍑讳簨浠讹紝闃叉鐐瑰嚮瀹冨唴閮╲iew鏃跺畠鍚庨潰鐨剅ecycler杩樿兘鍝嶅簲鐐瑰嚮浜嬩欢 + binding.layoutSearchParameter.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + } + }); + //鐐瑰嚮鎼滅储鎸夐挳杩涜鎼滅储 binding.ivSearch.setOnClickListener(v -> { viewModel.getFamilyMemorabilia(); binding.layoutSearch.setVisibility(View.GONE); binding.layoutDefault.setVisibility(View.VISIBLE); binding.tvTitle.setText("鎼滅储缁撴灉"); - mSearchPopupWindow.dismiss(); hideSoftKeyboard(); }); + //鐐瑰嚮娣诲姞鎸夐挳璺宠浆鍒板垱寤哄澶т簨璁伴〉闈� binding.fabAdd.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { - AppManager.getAppManager().startActivity(new Intent(getSelfActivity(),CreateFamilyProjectActivity.class).putExtra(BaseConfig.EXTRA_TYPE,1)); + AppManager.getAppManager().startActivity(new Intent(getSelfActivity(), FamilyMemorabiliaDetailActivity.class).putExtra(BaseConfig.EXTRA_TYPE,1)); } }); + binding.etStartTime.addTextChangedListener(new TextWatcher() { + @Override + public void beforeTextChanged(CharSequence s, int start, int count, int after) { + } - setOnClickListener( - mSearchPopupWindow.getContentView().findViewById(R.id.iv_clear_person), - mSearchPopupWindow.getContentView().findViewById(R.id.iv_clear_place), - mSearchPopupWindow.getContentView().findViewById(R.id.iv_clear_time), - mSearchPopupWindow.getContentView().findViewById(R.id.iv_clear_title), - mOperatePopupWindow.getContentView().findViewById(R.id.tv_add), - mOperatePopupWindow.getContentView().findViewById(R.id.tv_select), - mOperatePopupWindow.getContentView().findViewById(R.id.tv_from_new_to_old), - mOperatePopupWindow.getContentView().findViewById(R.id.tv_from_old_to_new) - ); + @Override + public void onTextChanged(CharSequence s, int start, int before, int count) { + if (!TextUtils.isEmpty(s)) { + binding.ivTimeClear.setVisibility(View.VISIBLE); + } else { + if (TextUtils.isEmpty(binding.etEndTime.getText().toString())) { + binding.ivTimeClear.setVisibility(View.INVISIBLE); + } + } + } + @Override + public void afterTextChanged(Editable s) { + + } + }); + binding.etEndTime.addTextChangedListener(new TextWatcher() { + @Override + public void beforeTextChanged(CharSequence s, int start, int count, int after) { + } + + @Override + public void onTextChanged(CharSequence s, int start, int before, int count) { + if (!TextUtils.isEmpty(s)) { + binding.ivTimeClear.setVisibility(View.VISIBLE); + } else { + if (TextUtils.isEmpty(binding.etStartTime.getText().toString())) { + binding.ivTimeClear.setVisibility(View.INVISIBLE); + } + } } + + @Override + public void afterTextChanged(Editable s) { + + } + }); + binding.etStartTime.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + hideSoftKeyboard(); + DatePicker datePicker = getDatePicker(); + datePicker.setTitle("璇烽�夋嫨寮�濮嬫椂闂�"); + datePicker.setOnDatePickedListener(new OnDatePickedListener() { + @Override + public void onDatePicked(int year, int month, int day) { + //浠yyy-MM-dd鐨勬牸寮忔樉绀猴紝鏈堟棩灏忎簬10鏃跺墠闈㈣ˉ0 + binding.etStartTime.setText(String.format("%d-%02d-%02d", year, month, day)); + if (binding.etEndTime.getText().toString().isEmpty()){ + binding.etEndTime.setText(String.format("%d-%02d-%02d", year, month, day)); + }else { + //姣旇緝寮�濮嬫椂闂村拰缁撴潫鏃堕棿鐨勫ぇ灏� + String startTime = binding.etStartTime.getText().toString(); + String endTime = binding.etEndTime.getText().toString(); + if (Utils.compareDate(startTime,endTime) > 0){ + //浜ゆ崲 + binding.etStartTime.setText(endTime); + binding.etEndTime.setText(startTime); + } + } + } + }); + datePicker.show(); + } + }); + binding.etEndTime.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + hideSoftKeyboard(); + DatePicker datePicker = getDatePicker(); + datePicker.setTitle("璇烽�夋嫨缁撴潫鏃堕棿"); + datePicker.setOnDatePickedListener(new OnDatePickedListener() { + @Override + public void onDatePicked(int year, int month, int day) { + binding.etEndTime.setText(String.format("%d-%02d-%02d", year, month, day)); + if (binding.etStartTime.getText().toString().isEmpty()){ + binding.etStartTime.setText(String.format("%d-%02d-%02d", year, month, day)); + }else { + //姣旇緝寮�濮嬫椂闂村拰缁撴潫鏃堕棿鐨勫ぇ灏� + String startTime = binding.etStartTime.getText().toString(); + String endTime = binding.etEndTime.getText().toString(); + if (Utils.compareDate(startTime,endTime) > 0){ + //浜ゆ崲 + binding.etStartTime.setText(endTime); + binding.etEndTime.setText(startTime); + } + } + } + }); + datePicker.show(); + } + }); + binding.ivTimeClear.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + binding.etStartTime.setText(""); + binding.etEndTime.setText(""); + } + }); } @Override @@ -139,7 +229,27 @@ } @Override + public boolean dispatchTouchEvent(MotionEvent event) { + float x = event.getX(); + float y = event.getY(); + if (isSearchLayoutVisible){ + if (!Utils.isPointInsideView(x, y, binding.layoutSearchParameter)) { + Utils.pullCollapse(binding.containerSearchParameter, binding.layoutSearchParameter.getMeasuredHeight(),0); + isSearchLayoutVisible = false; + return true; + } + } + return super.dispatchTouchEvent(event); + } + + @Override public void initLiveDataObserve() { + viewModel.getDataListLiveData().observe(this, new Observer<List<FamilyMemorabiliaBean>>() { + @Override + public void onChanged(List<FamilyMemorabiliaBean> familyMemorabiliaBeans) { + adapter.setData(familyMemorabiliaBeans); + } + }); viewModel.getCheckListLiveData().observe(this, new Observer<List<FamilyMemorabiliaBean>>() { @Override public void onChanged(List<FamilyMemorabiliaBean> familyMemorabiliaBeans) { @@ -151,12 +261,6 @@ }else{ viewModel.getOperateTypeLiveData().setValue(2); } - } - }); - viewModel.getDataListLiveData().observe(this, new Observer<List<FamilyMemorabiliaBean>>() { - @Override - public void onChanged(List<FamilyMemorabiliaBean> familyMemorabiliaBeans) { - adapter.setData(familyMemorabiliaBeans); } }); viewModel.getMoreListLiveData().observe(this, new Observer<List<FamilyMemorabiliaBean>>() { @@ -182,48 +286,38 @@ binding.ivOperate.setBackgroundResource(R.drawable.ic_delete_white); binding.ivOperate.setOnClickListener(v -> { new UIDialog.Builder(this) - .setTitle("鎮ㄧ‘瀹氳鍒犻櫎椤圭洰鍚�") + .setTitle("鎮ㄧ‘瀹氳鍒犻櫎閫変腑鐨勯」鐩悧") .setContent("椤圭洰鍒犻櫎鍚庡皢鏃犳硶鎭㈠") .setConfirm("纭畾") .setCancel("鍙栨秷") .setListener(new UIDialog.OnListener() { @Override public void onConfirm(BaseDialog dialog) { - viewModel.delete(); + viewModel.deleteCheckList(); } }) .show(); }); } }); + viewModel.getFinishDeleteListLiveData().observe(this, beans -> { + for (FamilyMemorabiliaBean bean : beans) { + adapter.removeItem(bean); + } + }); + //瑙傚療瀹跺ぇ浜嬭鏁版嵁鐨勫彉鍖栵紝鏈夊彉鍖栧寘鎷坊鍔犮�佷慨鏀广�佸垹闄ら兘浼氬彂閫佹秷鎭紝鎺ユ敹鍒版秷鎭悗閲嶆柊鑾峰彇鏁版嵁 + RxBus.getInstance().toObservable(this, FamilyMemorabiliaBean.class) + .subscribe(bean -> { + viewModel.getFamilyMemorabilia(); + }); } - - public PopupWindow initPopUpWindow(View view){ - PopupWindow popupWindow = new PopupWindow(this); - // 璁剧疆甯冨眬鏂囦欢 - popupWindow.setContentView(view); - // 涓轰簡閬垮厤閮ㄥ垎鏈哄瀷涓嶆樉绀猴紝闇�瑕侀噸鏂拌缃竴涓嬪楂� - popupWindow.setWidth(ViewGroup.LayoutParams.WRAP_CONTENT); - popupWindow.setHeight(ViewGroup.LayoutParams.WRAP_CONTENT); - // 璁剧疆pop閫忔槑鏁堟灉 - popupWindow.setBackgroundDrawable(new ColorDrawable(0x0000)); - // 璁剧疆pop鍑哄叆鍔ㄧ敾 - popupWindow.setAnimationStyle(com.android.app_base.R.style.pop_operate); -// // 璁剧疆pop鑾峰彇鐒︾偣锛屽鏋滀负false鐐瑰嚮杩斿洖鎸夐挳浼氶��鍑哄綋鍓岮ctivity锛屽鏋減op涓湁Editor鐨勮瘽锛宖ocusable蹇呴』瑕佷负true - popupWindow.setFocusable(true); -// // 璁剧疆pop鍙偣鍑伙紝涓篺alse鐐瑰嚮浜嬩欢鏃犳晥锛岄粯璁や负true - popupWindow.setTouchable(true); - // 璁剧疆鐐瑰嚮pop澶栦晶娑堝け锛岄粯璁や负false锛涘湪focusable涓簍rue鏃剁偣鍑诲渚у缁堟秷澶� - popupWindow.setOutsideTouchable(false); - return popupWindow; - } @Override protected void dataNull() { super.dataNull(); binding.layoutDataNull.setVisibility(View.VISIBLE); - binding.recyclerView.setVisibility(View.GONE); + binding.refreshLayout.setVisibility(View.GONE); } @Override @@ -236,7 +330,7 @@ protected void hide() { super.hide(); binding.layoutDataNull.setVisibility(View.GONE); - binding.recyclerView.setVisibility(View.VISIBLE); + binding.refreshLayout.setVisibility(View.VISIBLE); binding.refreshLayout.finishLoadMore(); } @@ -244,7 +338,7 @@ public void onClick(View v) { int id = v.getId(); if (id == R.id.tv_add){ - AppManager.getAppManager().startActivity(new Intent(this,CreateFamilyProjectActivity.class).putExtra(BaseConfig.EXTRA_TYPE,1)); + AppManager.getAppManager().startActivity(new Intent(this, FamilyMemorabiliaDetailActivity.class).putExtra(BaseConfig.EXTRA_TYPE,1)); }else if (id == R.id.tv_select){ viewModel.getOperateTypeLiveData().postValue(1); mOperatePopupWindow.dismiss(); @@ -260,11 +354,9 @@ @Override protected void onDestroy() { super.onDestroy(); - if (mSearchPopupWindow != null){ - mSearchPopupWindow.dismiss(); - } if (mOperatePopupWindow != null){ mOperatePopupWindow.dismiss(); } } + } \ No newline at end of file -- Gitblit v1.9.1