From bc0643f42cc19cfa1153f355851968e5486281ef Mon Sep 17 00:00:00 2001 From: zuoxiao <470321431@qq.com> Date: 星期三, 16 十月 2024 11:29:18 +0800 Subject: [PATCH] 地图添加比例尺 --- app/src/main/java/com/dayu/pipirrapp/activity/MainActivity.java | 120 +++++++++++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 99 insertions(+), 21 deletions(-) diff --git a/app/src/main/java/com/dayu/pipirrapp/activity/MainActivity.java b/app/src/main/java/com/dayu/pipirrapp/activity/MainActivity.java index 15b6c0e..c768fc6 100644 --- a/app/src/main/java/com/dayu/pipirrapp/activity/MainActivity.java +++ b/app/src/main/java/com/dayu/pipirrapp/activity/MainActivity.java @@ -1,53 +1,131 @@ package com.dayu.pipirrapp.activity; import android.os.Bundle; +import android.view.KeyEvent; import android.view.LayoutInflater; -import android.view.MotionEvent; -import android.view.View; +import android.widget.Toast; import androidx.appcompat.app.AppCompatActivity; +import androidx.core.content.ContextCompat; import androidx.fragment.app.Fragment; +import com.dayu.pipirrapp.R; import com.dayu.pipirrapp.adapter.TabAdapter; import com.dayu.pipirrapp.databinding.ActivityMainBinding; -import com.dayu.pipirrapp.fragment.MainFragment; +import com.dayu.pipirrapp.fragment.OrderFragment; import com.dayu.pipirrapp.fragment.MapFragment; import com.dayu.pipirrapp.fragment.MyFragment; import java.util.ArrayList; import java.util.List; - /** - * + * 棣栭〉 */ public class MainActivity extends AppCompatActivity { - ActivityMainBinding binding; - List<Fragment> mFragment = new ArrayList<>(); + private ActivityMainBinding binding; + private List<Fragment> fragments = new ArrayList<>(); + private long mExitTime; + private enum Tab { + ORDER, MAP, MY + } @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); binding = ActivityMainBinding.inflate(LayoutInflater.from(this)); - MapFragment mapFragment = new MapFragment(); - setContentView(binding.getRoot()); - mFragment.add(mapFragment); - mFragment.add(new MainFragment()); - mFragment.add(new MyFragment()); + + setupFragments(); + initView(); initTab(); } - private void initTab() { - TabAdapter adapter = new TabAdapter(getSupportFragmentManager(), mFragment); - binding.viewPager.setAdapter(adapter); - binding.viewPager.setPagingEnabled(false); - //璁剧疆缂撳瓨view 鐨勪釜鏁� - binding.viewPager.setOffscreenPageLimit(3); - // 灏� ViewPager 涓� TabLayout 鍏宠仈 - binding.tabLayout.setupWithViewPager(binding.viewPager); + private void setupFragments() { + fragments.add(new OrderFragment()); + fragments.add(new MapFragment()); + fragments.add(new MyFragment()); } + private void initView() { + binding.orderLL.setOnClickListener(v -> changeBottomState(Tab.ORDER)); + binding.mapLL.setOnClickListener(v -> changeBottomState(Tab.MAP)); + binding.myLL.setOnClickListener(v -> changeBottomState(Tab.MY)); + } -} \ No newline at end of file + private void initTab() { + TabAdapter adapter = new TabAdapter(getSupportFragmentManager(), fragments); + binding.viewPager.setAdapter(adapter); + binding.viewPager.setPagingEnabled(false); + binding.viewPager.setOffscreenPageLimit(fragments.size()); + binding.viewPager.setCurrentItem(1); // 榛樿鏄剧ず鍦板浘椤� + } + + @Override + public boolean onKeyDown(int keyCode, KeyEvent event) { + if (keyCode == KeyEvent.KEYCODE_BACK) { + if ((System.currentTimeMillis() - mExitTime) > 2000) { + Toast.makeText(MainActivity.this, "鍐嶆寜涓�娆¢��鍑虹▼搴�", Toast.LENGTH_SHORT).show(); + mExitTime = System.currentTimeMillis(); + } else { + finish(); + } + return true; + } + return super.onKeyDown(keyCode, event); + } + + /** + * 淇敼搴曢儴鐘舵�� + */ + private void changeBottomState(Tab tab) { + resetTabState(); + switch (tab) { + case ORDER: + updateTabUI(0, R.drawable.bottom_order_white, R.color.white); + break; + case MAP: + updateTabUI(1, R.drawable.bottom_map_white, R.color.white); + break; + case MY: + updateTabUI(2, R.drawable.bottom_my_white, R.color.white); + break; + } + } + + /** + * 鏇存柊鏌愪釜 Tab 鐨� UI 鐘舵�� + */ + private void updateTabUI(int position, int iconResId, int textColorResId) { + binding.viewPager.setCurrentItem(position); + switch (position) { + case 0: + binding.orderImg.setImageDrawable(ContextCompat.getDrawable(this, iconResId)); + binding.orderText.setTextColor(ContextCompat.getColor(this, textColorResId)); + break; + case 1: + binding.mapImg.setImageDrawable(ContextCompat.getDrawable(this, iconResId)); + binding.mapText.setTextColor(ContextCompat.getColor(this, textColorResId)); + break; + case 2: + binding.myImg.setImageDrawable(ContextCompat.getDrawable(this, iconResId)); + binding.myText.setTextColor(ContextCompat.getColor(this, textColorResId)); + break; + } + } + + /** + * 閲嶇疆鎵�鏈� Tab 鐨勯粯璁ょ姸鎬� + */ + private void resetTabState() { + binding.orderImg.setImageDrawable(ContextCompat.getDrawable(this, R.drawable.bottom_order_black)); + binding.orderText.setTextColor(ContextCompat.getColor(this, R.color.black)); + + binding.mapImg.setImageDrawable(ContextCompat.getDrawable(this, R.drawable.bottom_map_black)); + binding.mapText.setTextColor(ContextCompat.getColor(this, R.color.black)); + + binding.myImg.setImageDrawable(ContextCompat.getDrawable(this, R.drawable.bottom_my_black)); + binding.myText.setTextColor(ContextCompat.getColor(this, R.color.black)); + } +} -- Gitblit v1.8.0