From 4c99ee7028c3fe58a2cd4b8273b22c75c45574fc Mon Sep 17 00:00:00 2001 From: Pu Zhibing <393733352@qq.com> Date: 星期五, 16 五月 2025 10:27:41 +0800 Subject: [PATCH] 修改文档bug --- DriverIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/CompanyCityServiceImpl.java | 106 +++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 98 insertions(+), 8 deletions(-) diff --git a/DriverIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/CompanyCityServiceImpl.java b/DriverIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/CompanyCityServiceImpl.java index ca19a16..8902a0d 100644 --- a/DriverIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/CompanyCityServiceImpl.java +++ b/DriverIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/CompanyCityServiceImpl.java @@ -13,10 +13,12 @@ import com.stylefeng.guns.modular.system.util.GoogleMap.AddressComponentsVo; import com.stylefeng.guns.modular.system.util.GoogleMap.GoogleMapUtil; import com.stylefeng.guns.modular.system.util.GoogleMap.ReverseGeocodeVo; +import com.stylefeng.guns.modular.system.util.RedisUtil; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import javax.annotation.Resource; +import java.util.ArrayList; import java.util.Arrays; import java.util.List; import java.util.Map; @@ -34,6 +36,9 @@ @Autowired private ICityService cityService; + + @Resource + private RedisUtil redisUtil; /** @@ -52,8 +57,9 @@ } @Override - public Company query1(String lon, String lat) throws Exception { - ReverseGeocodeVo reverseGeocode = GoogleMapUtil.getReverseGeocode(Double.valueOf(lat), Double.valueOf(lon)); + public Company query1(Integer uid, String lon, String lat) throws Exception { + String tripId = redisUtil.getValue("trip" + uid); + ReverseGeocodeVo reverseGeocode = GoogleMapUtil.getReverseGeocode(Double.valueOf(lat), Double.valueOf(lon), tripId); if(null == reverseGeocode){ return null; } @@ -95,12 +101,57 @@ @Override public Company query(String[] city) throws Exception { - List<Company> query = companyMapper.queryList(city, 3); + List<City> cities1 = cityService.selectList(null); + List<Integer> collect = new ArrayList<>(); + for (City city1 : cities1) { + String chineseName = city1.getChineseName(); + String englishName = city1.getEnglishName(); + String frenchName = city1.getFrenchName(); + for (String s : city) { + if(s.equals(chineseName)){ + collect.add(city1.getId()); + break; + } + if(s.equals(englishName)){ + collect.add(city1.getId()); + break; + } + if(s.equals(frenchName)){ + collect.add(city1.getId()); + break; + } + } + } + if(collect.size() == 0){ + for (City city1 : cities1) { + String chineseName = city1.getChineseName(); + String englishName = city1.getEnglishName(); + String frenchName = city1.getFrenchName(); + for (String s : city) { + if(s.contains(chineseName)){ + collect.add(city1.getId()); + break; + } + if(s.contains(englishName)){ + collect.add(city1.getId()); + break; + } + if(s.contains(frenchName)){ + collect.add(city1.getId()); + break; + } + } + } + } + if(collect.size() == 0){ + return null; + } + List<Company> query = companyMapper.queryList(collect, 3); if(query.size() == 0){ - query = companyMapper.queryList(city, 2); + query = companyMapper.queryList(collect, 2); } if(query.size() == 0){ - query = companyMapper.queryList(city, 1); + query = companyMapper.queryList(collect, 1); } if(query.size() > 0){ return query.get(0); @@ -111,9 +162,48 @@ public Company query1(String[] city) throws Exception { - List<City> cities = cityService.selectList(new EntityWrapper<City>().in("chineseName", Arrays.asList(city)).or() - .in("englishName", Arrays.asList(city)).or().in("frenchName", Arrays.asList(city))); - List<Integer> collect = cities.stream().map(City::getId).collect(Collectors.toList()); + List<City> cities1 = cityService.selectList(null); + List<Integer> collect = new ArrayList<>(); + for (City city1 : cities1) { + String chineseName = city1.getChineseName(); + String englishName = city1.getEnglishName(); + String frenchName = city1.getFrenchName(); + for (String s : city) { + if(s.equals(chineseName)){ + collect.add(city1.getId()); + break; + } + if(s.equals(englishName)){ + collect.add(city1.getId()); + break; + } + if(s.equals(frenchName)){ + collect.add(city1.getId()); + break; + } + } + } + if(collect.size() == 0){ + for (City city1 : cities1) { + String chineseName = city1.getChineseName(); + String englishName = city1.getEnglishName(); + String frenchName = city1.getFrenchName(); + for (String s : city) { + if(s.contains(chineseName)){ + collect.add(city1.getId()); + break; + } + if(s.contains(englishName)){ + collect.add(city1.getId()); + break; + } + if(s.contains(frenchName)){ + collect.add(city1.getId()); + break; + } + } + } + } if(collect.size() == 0){ return null; } -- Gitblit v1.7.1