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 |  168 ++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 122 insertions(+), 46 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 41e34d6..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,10 +1,10 @@
 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.view.ViewGroup;
-import android.widget.FrameLayout;
-import android.widget.ImageView;
 import android.widget.PopupWindow;
 
 import androidx.fragment.app.Fragment;
@@ -12,19 +12,18 @@
 import androidx.lifecycle.Observer;
 
 import com.android.app_base.manager.AppManager;
-import com.android.app_base.utils.GlideUtil;
 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.TestActivity;
+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.Arrays;
 import java.util.List;
 
 /**
@@ -35,8 +34,9 @@
 public class FunctionFragment extends DLBaseFragment<FragmentFunctionBinding,FunctionFragmentViewModel> {
 
     private PopupWindow mOperatePopupWindow;
+    private PopupWindow mAddPopupWindow;
     private ImageCarouselFragment imageCarouselFragment;
-    private VideoFragment videoFragment;
+    private VideoCarouselFragment videoCarouselFragment;
 
     private FunctionFragment() {
     }
@@ -133,35 +133,118 @@
         binding.layoutContacts.setOnClickListener(v->{
             AppManager.getAppManager().startActivity(ContactsActivity.class);
         });
-        binding.ivOperate.setOnClickListener(v->{
-            AppManager.getAppManager().startActivity(TestActivity.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;
+            }
         });
 
-        imageCarouselFragment = ImageCarouselFragment.newInstance();
-        videoFragment = VideoFragment.newInstance();
-        replaceFragment(imageCarouselFragment);
+        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();
-            if (imageCarouselFragment == null){
-                imageCarouselFragment = ImageCarouselFragment.newInstance();
-            }
+            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();
-            if (videoFragment == null){
-                videoFragment = VideoFragment.newInstance();
-            }
-            replaceFragment(videoFragment);
+            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();
@@ -174,25 +257,30 @@
     }
 
     @Override
+    public void onResume() {
+        super.onResume();
+        initData();
+    }
+
+    @Override
     protected void initLiveDataObserve() {
-        viewModel.getBannerListLiveData().observe(this, new Observer<List<BannerBean>>() {
+        viewModel.getImageListLiveData().observe(this, new Observer<List<BannerBean>>() {
             @Override
             public void onChanged(List<BannerBean> bannerBeans) {
-                List<String> imageList = new ArrayList<>();
-                List<String> videoList = new ArrayList<>();
-                for (BannerBean bannerBean : bannerBeans) {
-                    if (bannerBean.getFlag() == 0){
-                        //鍥剧墖
-                        imageList.add(bannerBean.getUrl());
-                    }else if (bannerBean.getFlag() == 1){
-                        //瑙嗛
-                        videoList.add(bannerBean.getUrl());
-                    }
+                if (imageCarouselFragment != null){
+                    imageCarouselFragment.setImageList(bannerBeans);
                 }
-                imageCarouselFragment.setImageList(imageList);
-                videoFragment.setVideoList(videoList);
             }
         });
+        viewModel.getVideoListLiveData().observe(this, new Observer<List<BannerBean>>() {
+            @Override
+            public void onChanged(List<BannerBean> bannerBeans) {
+                if (videoCarouselFragment != null){
+                    videoCarouselFragment.setVideoList(bannerBeans);
+                }
+            }
+        });
+
     }
 
     @Override
@@ -200,17 +288,5 @@
         return true;
     }
 
-    @Override
-    protected void dataNull() {
-        super.dataNull();
-        binding.layoutFrame.setVisibility(View.GONE);
-        binding.layoutDataNull.setVisibility(View.VISIBLE);
-    }
-
-    @Override
-    protected void hide() {
-        super.hide();
-        binding.layoutFrame.setVisibility(View.VISIBLE);
-        binding.layoutDataNull.setVisibility(View.GONE);
-    }
 }
+

--
Gitblit v1.9.1