<TextView xmlns:android=“http://schemas.android.com/apk/res/android”
android:id=“@+id/tv_city”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:background=“@drawable/selected_bg_color”
android:paddingStart=“@dimen/dp_16”
android:paddingTop=“@dimen/dp_4”
android:paddingEnd=“@dimen/dp_16”
android:paddingBottom=“@dimen/dp_4”
android:text=“常用城市”
android:textColor=“@drawable/selected_text_color”
android:textSize=“@dimen/sp_18” />
这里我改变了触摸item时的背景样式和文字颜色样式,样式都放在drawable下。
selected_bg_color.xml
<?xml version="1.0" encoding="utf-8"?>selected_bg_radius.xml
<?xml version="1.0" encoding="utf-8"?>selected_text_color.xml
<?xml version="1.0" encoding="utf-8"?>item写完了,下面到适配器了。
在adapter包下新建一个MainChangeCommonlyCityAdapter类,代码如下:
package com.llw.goodweather.adapter;
import androidx.annotation.Nullable;
import com.chad.library.adapter.base.BaseQuickAdapter;
import com.chad.library.adapter.base.BaseViewHolder;
import com.llw.goodweather.R;
import com.llw.mvplibrary.bean.ResidentCity;
import java.util.List;
/**
-
主页面左右滑动切换常用城市列表适配器
-
@author llw
*/
public class MainChangeCommonlyCityAdapter extends BaseQuickAdapter<ResidentCity, BaseViewHolder> {
public MainChangeCommonlyCityAdapter(int layoutResId, @Nullable List data) {
super(layoutResId, data);
}
@Override
protected void convert(BaseViewHolder helper, ResidentCity item) {
helper.setText(R.id.tv_city, item.getLocation())
.addOnClickListener(R.id.tv_city);
}
}
刚才适配器写好了,然后进入到MainActivity中,再创建两个变量
//主页面切换城市列表适配器
private MainChangeCommonlyCityAdapter changeCityAdapter;
//常用城市切换列表
private List residentCityList = new ArrayList<>();
一个适配器一个数据列表,然后下面新增一个方法用于加载适配器数据并且渲染,还有点击事件。这里先查询数据,然后判断数据,之后渲染数据,最后是点击item之后搜索城市,然后查找天气数据。
/**
- 加载常用城市数据
*/
private void loadingCommonlyUsedCity() {
residentCityList = LitePal.findAll(ResidentCity.class);
//先判断是否有常用城市
if (residentCityList != null && residentCityList.size() > 0) {
isChangeCity = true;
} else {
isChangeCity = false;
}
//配置适配器
changeCityAdapter = new MainChangeCommonlyCityAdapter(R.layout.item_main_city_change, residentCityList);
LinearLayoutManager manager = new LinearLayoutManager(context);
manager.setOrientation(RecyclerView.HORIZONTAL);
rvChangeCity.setLayoutManager(manager);
rvChangeCity.setAdapter(changeCityAdapter);
//常用城市点击
changeCityAdapter.setOnItemChildClickListener((adapter, view, position) -> {
showLoadingDialog();
district = residentCityList.get(position).getLocation();
mPresent.newSearchCity(district);
flag = false;
//隐藏列表
rvChangeCity.setVisibility(View.GONE);
changeCityState = false;
});
}
这里我判断了一下是否为定位城市的返回,是的话我就添加到数据库中,当然也不能重复添加数据,因此还需要判断一下。
/**
-
添加到常用城市列表
-
@param locationBean
*/
private void addCommonlyUsedCity(NewSearchCityResponse.LocationBean locationBean) {
if (flag) {//定位到的城市
List residentCityList = LitePal.findAll(ResidentCity.class);
if (residentCityList != null && residentCityList.size() > 0) {
//查询要添加的城市是否已经存在
List residentCities = LitePal
.where(“location = ? and parent_city = ?”, locationBean.getName(), locationBean.getAdm2())
.find(ResidentCity.class);
if (residentCities.size() == 0) {
ResidentCity residentCity = new ResidentCity();
residentCity.setLocation(locationBean.getName());//地区/城市名称
residentCity.setParent_city(locationBean.getAdm2());//该地区/城市的上级城市
residentCity.setAdmin_area(locationBean.getAdm1());//该地区/城市所属行政区域
residentCity.setCnty(locationBean.getCountry());//该地区/城市所属国家名称
residentCity.save();//保存数据到数据库中
}
} else {
ResidentCity residentCity = new ResidentCity();
residentCity.setLocation(locationBean.getName());//地区/城市名称
residentCity.setParent_city(locationBean.getAdm2());//该地区/城市的上级城市
residentCity.setAdmin_area(locationBean.getAdm1());//该地区/城市所属行政区域
residentCity.setCnty(locationBean.getCountry());//该地区/城市所属国家名称
residentCity.save();//保存数据到数据库中
}
}
//加载常用城市数据
loadingCommonlyUsedCity();
}
然后你还需要在initData中调用loadingCommonlyUsedCity方法。
其次就是在接收事件的时候再加载一次数据,因为我在常用城市中添加数据之后会发起事件,然后关闭常用城市页面,回到主页面,此时需要把数据加载一下,后面会演示一下。
因为我是点击城市触发常用城市列表的判断处理,因此之前的代码需要修改一下,有两处,在initData中
在onReceiveLocation方法中
最后在tv_city的点击事件中先判断当前城市是否定位到,定位到则判断有无数据,有数据则可以判断点击后不同的控件样式。
那么下面就可以运行一下了。