From 31b7700b976a46901f67c5d7a00281ca4745fc9f Mon Sep 17 00:00:00 2001 From: Linjiajia <319408893@qq.com> Date: 星期六, 07 十月 2023 21:44:35 +0800 Subject: [PATCH] 调整旅游模块功能 --- app/src/main/java/com/application/zhangshi_app_android/ui/function/FunctionFragment.java | 205 +++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 189 insertions(+), 16 deletions(-) diff --git a/app/src/main/java/com/application/zhangshi_app_android/ui/function/FunctionFragment.java b/app/src/main/java/com/application/zhangshi_app_android/ui/function/FunctionFragment.java index 40fa8e2..dbb4ce6 100644 --- a/app/src/main/java/com/application/zhangshi_app_android/ui/function/FunctionFragment.java +++ b/app/src/main/java/com/application/zhangshi_app_android/ui/function/FunctionFragment.java @@ -1,21 +1,44 @@ package com.application.zhangshi_app_android.ui.function; +import android.content.Intent; import android.os.Bundle; +import android.view.GestureDetector; +import android.view.MotionEvent; import android.view.View; +import android.widget.PopupWindow; -import com.android.app_base.base.view.BaseFragment; +import androidx.fragment.app.Fragment; +import androidx.fragment.app.FragmentTransaction; +import androidx.lifecycle.Observer; + import com.android.app_base.manager.AppManager; +import com.android.app_base.utils.ScreenSizeUtils; import com.application.zhangshi_app_android.BR; import com.application.zhangshi_app_android.R; +import com.application.zhangshi_app_android.bean.BannerBean; import com.application.zhangshi_app_android.databinding.FragmentFunctionBinding; +import com.application.zhangshi_app_android.ui.DLBaseFragment; +import com.application.zhangshi_app_android.ui.dialog.TotalAddDialog; +import com.application.zhangshi_app_android.ui.home.HomeFragment; +import com.application.zhangshi_app_android.ui.main.MainActivity; + +import java.io.Serializable; +import java.util.ArrayList; +import java.util.List; /** * @author Ljj * @date 2023.03.15. 20:14 * @desc 鍔熻兘 Fragment */ -public class FunctionFragment extends BaseFragment<FragmentFunctionBinding,FunctionFragmentViewModel> { - public FunctionFragment() { +public class FunctionFragment extends DLBaseFragment<FragmentFunctionBinding,FunctionFragmentViewModel> { + + private PopupWindow mOperatePopupWindow; + private PopupWindow mAddPopupWindow; + private ImageCarouselFragment imageCarouselFragment; + private VideoCarouselFragment videoCarouselFragment; + + private FunctionFragment() { } public static FunctionFragment newInstance() { @@ -41,6 +64,12 @@ @Override protected void initView() { + binding.layoutHomeRootNet.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + MainActivity.start(getSelfActivity(), HomeFragment.class); + } + }); binding.layoutFamilyMemorabilia.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { @@ -59,17 +88,11 @@ AppManager.getAppManager().startActivity(FamilyAssetsActivity.class); } }); - binding.layoutHomeDevices.setOnClickListener(new View.OnClickListener() { - @Override - public void onClick(View view) { - AppManager.getAppManager().startActivity(HomeDevicesActivity.class); - } + binding.layoutHomeDevices.setOnClickListener(view -> { + AppManager.getAppManager().startActivity(HomeDevicesActivity.class); }); - binding.layoutGrowingUp.setOnClickListener(new View.OnClickListener() { - @Override - public void onClick(View view) { - AppManager.getAppManager().startActivity(GrowthExperienceActivity.class); - } + binding.layoutGrowingUp.setOnClickListener(view -> { + AppManager.getAppManager().startActivity(GrowthExperienceActivity.class); }); binding.layoutHonorCollection.setOnClickListener(v->{ AppManager.getAppManager().startActivity(HonorCollectionActivity.class); @@ -98,15 +121,165 @@ binding.layoutMarriage.setOnClickListener(v->{ AppManager.getAppManager().startActivity(MarriageActivity.class); }); + binding.layoutHealthCare.setOnClickListener(v->{ + AppManager.getAppManager().startActivity(HealthCareActivity.class); + }); + binding.layoutPrivacy.setOnClickListener(v->{ + AppManager.getAppManager().startActivity(PrivacyActivity.class); + }); + binding.layoutTourism.setOnClickListener(v->{ + AppManager.getAppManager().startActivity(TourismActivity.class); + }); + binding.layoutContacts.setOnClickListener(v->{ + AppManager.getAppManager().startActivity(ContactsActivity.class); + }); + + binding.fabAdd.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + + } + }); + binding.fabAdd.setOnTouchListener(new View.OnTouchListener() { + + private boolean isDragging = false; + private int startX, startY; + private float dX, dY; + + @Override + public boolean onTouch(View v, MotionEvent event) { + boolean flag = false; + + switch (event.getAction()) { + case MotionEvent.ACTION_DOWN: + // 璁$畻鎵嬫寚鎸変笅鏃剁浉瀵逛簬 FloatingActionButton 鐨勫亸绉婚噺 + dX = v.getX() - event.getRawX(); + dY = v.getY() - event.getRawY(); + startY = (int) event.getRawY(); + startX = (int) event.getRawX(); + isDragging = false; + break; + case MotionEvent.ACTION_MOVE: + // 鏇存柊 FloatingActionButton 鐨勪綅缃� + float newX = event.getRawX() + dX; + float newY = event.getRawY() + dY; + + // 闄愬埗绉诲姩鑼冨洿 + float minX = 0; + float maxX = binding.container.getWidth() - v.getWidth(); + float minY = 0; + float maxY = binding.container.getHeight() - v.getHeight(); + + // 纭繚涓嶈秴鍑鸿寖鍥� + if (newX < minX) { + newX = minX; + } else if (newX > maxX) { + newX = maxX; + } + + if (newY < minY) { + newY = minY; + } else if (newY > maxY) { + newY = maxY; + } + v.setX(newX); + v.setY(newY); + if (Math.abs(event.getRawX() - startX) > 10 || Math.abs(event.getRawY() - startY) > 10) { + isDragging = true; // 濡傛灉绉诲姩璺濈澶т簬闃堝�硷紝璁や负鏄嫋鍔� + }else { + isDragging = false; + } + flag = true; + break; + case MotionEvent.ACTION_UP: + if (!isDragging) { + // 濡傛灉娌℃湁鎷栧姩锛岃涓烘槸鐐瑰嚮浜嬩欢 + new TotalAddDialog.Builder(getContext()).show(); + } + break; + default: + break; + } + return flag; + } + }); + + binding.ivOperateSelect.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + AppManager.getAppManager().startActivity(new Intent(getSelfActivity(),ImageSelectActivity.class).putExtra("flag",0).putExtra("list", (Serializable) imageCarouselFragment.getImageList())); + } + }); + + //鍙充笂瑙掓搷浣滃脊绐� + mOperatePopupWindow = initPopUpWindow(View.inflate(getSelfActivity(),R.layout.pop_switch_video_or_image,null)); + mOperatePopupWindow.getContentView().findViewById(R.id.tv_image).setOnClickListener(v -> { + mOperatePopupWindow.dismiss(); + imageCarouselFragment = ImageCarouselFragment.newInstance(); + replaceFragment(imageCarouselFragment); + imageCarouselFragment.setImageList(viewModel.getImageListLiveData().getValue()); + binding.ivOperateSelect.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + AppManager.getAppManager().startActivity(new Intent(getSelfActivity(),ImageSelectActivity.class).putExtra("flag",0).putExtra("list", (Serializable) imageCarouselFragment.getImageList())); + } + }); + }); + mOperatePopupWindow.getContentView().findViewById(R.id.tv_video).setOnClickListener(v -> { + mOperatePopupWindow.dismiss(); + videoCarouselFragment = VideoCarouselFragment.newInstance(); + replaceFragment(videoCarouselFragment); + videoCarouselFragment.setVideoList(viewModel.getVideoListLiveData().getValue()); + binding.ivOperateSelect.setOnClickListener(new View.OnClickListener() { + @Override + public void onClick(View v) { + AppManager.getAppManager().startActivity(new Intent(getSelfActivity(),ImageSelectActivity.class).putExtra("flag",1).putExtra("list", (Serializable) videoCarouselFragment.getVideoList())); + } + + }); + }); + //鐐瑰嚮寮瑰嚭鎿嶄綔寮圭獥 + binding.ivOperate.setOnClickListener(v -> { + mOperatePopupWindow.showAsDropDown(binding.ivOperate,-ScreenSizeUtils.dip2px(getSelfActivity(),85) +binding.ivOperate.getWidth(),0); + }); + + imageCarouselFragment = ImageCarouselFragment.newInstance(); + replaceFragment(imageCarouselFragment); + } + public void replaceFragment(Fragment fragment){ + FragmentTransaction transaction = getSelfActivity().getSupportFragmentManager().beginTransaction(); + transaction.replace(R.id.layout_frame,fragment); + transaction.commit(); + } + @Override + protected void initData() { + viewModel.getBannerData(); } @Override - protected void initData() { - + public void onResume() { + super.onResume(); + initData(); } @Override protected void initLiveDataObserve() { + viewModel.getImageListLiveData().observe(this, new Observer<List<BannerBean>>() { + @Override + public void onChanged(List<BannerBean> bannerBeans) { + if (imageCarouselFragment != null){ + imageCarouselFragment.setImageList(bannerBeans); + } + } + }); + viewModel.getVideoListLiveData().observe(this, new Observer<List<BannerBean>>() { + @Override + public void onChanged(List<BannerBean> bannerBeans) { + if (videoCarouselFragment != null){ + videoCarouselFragment.setVideoList(bannerBeans); + } + } + }); } @@ -115,5 +288,5 @@ return true; } - } + -- Gitblit v1.9.1