package com.uumap.MapInterface;
import android.app.Activity;
import android.os.Bundle;
import android.os.Message;
import android.view.View;
import android.view.Window;
import android.view.WindowManager;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.Spinner;
import android.widget.TextView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.AdapterView.OnItemSelectedListener;
import com.uumap.Entity.Province;
import com.uumap.Entity.city;
import com.uumap.adapter.CityAdapter;
import com.uumap.mapview.Map;
import com.uumap.util.CacheTools;
public class ChangeCityActivity extends Activity
{
ListView cityLv;
Spinner proSpinner;
TextView cityNameTv;
boolean isInit = true;
int proIndex = 0;
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
getWindow().requestFeature(Window.FEATURE_NO_TITLE);
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN);
this.setContentView(R.layout.change_city);
cityNameTv = (TextView) findViewById(R.id.cityName);
cityNameTv.setText(getResources().getString(R.string.curr_city)
+ mapIndex.cityName);
isInit = true;
proIndex = this.getIntent().getExtras().getInt("index");
cityLv = (ListView) findViewById(R.id.cityList);
CityAdapter ca = new CityAdapter(this, CacheTools.proList.get(proIndex)
.getCityList());
cityLv.setAdapter(ca);
cityLv.setOnItemClickListener(changeCity);
proSpinner = (Spinner) findViewById(R.id.switch_pro);
ArrayAdapter<String> proAdapter = new ArrayAdapter<String>(this,
android.R.layout.simple_spinner_item, this.getProNames());
proAdapter.setDropDownViewResource(R.layout.province_item);
proSpinner.setAdapter(proAdapter);
proSpinner.setSelection(proIndex);
proSpinner.setOnItemSelectedListener(changePro);
Map.tmDiv.removeAllViews();
}
public String[] getProNames()
{
String[] proNames = new String[CacheTools.proList.size()];
for (int i = 0; i < CacheTools.proList.size(); i++)
{
proNames[i] = CacheTools.proList.get(i).getName();
}
return proNames;
}
public String[] getProNames2() {
int order = 0;
String[] proNames = new String[CacheTools.proList.size()];
proNames[0] = "直辖市";
proNames[1] = "广东";
for (int i = 1; i < CacheTools.proList.size(); i++) {
if (CacheTools.proList.get(i).getName().equals("广东")) {
i++;
order = -1;
}
proNames[i + 1 + order] = CacheTools.proList.get(i).getName();
}
return proNames;
}
private OnItemClickListener changeCity = new OnItemClickListener()
{
@Override
public void onItemClick(AdapterView<?> adapter, View view,
int position, long id)
{
city ct = (city) adapter.getAdapter().getItem(position);
cityNameTv.setText(getResources().getString(R.string.curr_city)
+ ct.name);
mapIndex.proIndex = proIndex;
Message msg = Message.obtain();
msg.obj = ct;
finish();
Map.ChangeCityHandler.handleMessage(msg);
}
};
private OnItemSelectedListener changePro = new OnItemSelectedListener()
{
public void onItemSelected(AdapterView<?> adapter, View view,
int position, long id)
{
if (!isInit)
{
Province pro = CacheTools.proList.get(position);
CityAdapter ca = new CityAdapter(ChangeCityActivity.this, pro
.getCityList());
proIndex = position;
cityLv.setAdapter(ca);
}
else
{
isInit = false;
}
}
public void onNothingSelected(AdapterView<?> parent)
{
}
};
}
package com.uumap.adapter;
import java.util.List;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.TextView;
import com.uumap.Entity.city;
import com.uumap.MapInterface.R;
public class CityAdapter extends BaseAdapter
{
private List<city> cityList;
private LayoutInflater lif;
public CityAdapter(Context context, List<city> cityList)
{
this.cityList = cityList;
lif = LayoutInflater.from(context);
}
@Override
public int getCount()
{
return cityList.size();
}
@Override
public Object getItem(int position)
{
return cityList.get(position);
}
@Override
public long getItemId(int position)
{
return position;
}
final class ViewHolder
{
public TextView cityTv;
}
@Override
public View getView(int position, View convertView, ViewGroup parent)
{
ViewHolder vh = null;
if (convertView == null)
{
vh = new ViewHolder();
convertView = lif.inflate(R.layout.city_item, null);
vh.cityTv = (TextView) convertView.findViewById(R.id.city_name);
convertView.setTag(vh);
}
else
{
vh = (ViewHolder) convertView.getTag();
}
vh.cityTv.setText(cityList.get(position).name);
return convertView;
}
}
分享到:
相关推荐
"js+css3支持多选下拉城市菜单选择代码"就是一个专注于提升用户体验的解决方案,它结合了JavaScript和CSS3技术,实现了可多选的下拉城市菜单功能。这种设计允许用户在一个简洁的界面中快速、方便地选择多个城市或...
在网页设计中,创建交互式的下拉城市菜单是提高用户体验的重要手段之一。"js css3下拉城市菜单多选代码"是一个使用JavaScript和CSS3技术实现的实例,它允许用户在下拉菜单中选择多个城市,增加了用户界面的互动性和...
"js css3下拉城市菜单多选代码.zip" 提供了一种实现这一目标的解决方案。这个压缩包包含了必要的CSS样式表、HTML结构以及JavaScript脚本来创建一个功能丰富的下拉城市菜单,允许用户进行多选操作。 首先,CSS3...
《jQuery下拉城市单选多选插件详解》 在Web开发中,用户界面的交互性和易用性是至关重要的,而下拉选择框作为常见的交互元素,常常用于收集用户的地理位置信息,如城市选择。jQuery作为一款强大的JavaScript库,...
本篇文章将详细讲解基于jQuery的下拉城市选择插件,这款插件支持单选和多选功能,并且具有关键词搜索功能。 首先,我们要了解这个插件的基本工作原理。在网页设计中,传统的HTML `<select>` 元素常用于创建下拉选项...
"js+css3下拉城市选择多选代码.zip" 是一个用于创建交互式城市选择下拉菜单的资源,它结合了JavaScript和CSS3技术,以实现更丰富的用户体验和功能。这个压缩包包含了一个名为 "jiaoben6823" 的文件,可能是源代码或...
在这个"js css3下拉城市选择多选代码"项目中,开发者利用这两种技术创建了一个实用且美观的城市选择菜单。这个菜单具有圆形的外观,并且支持用户的多选操作,提供了一种优雅的方式来处理地理位置相关的数据输入。 ...
【标题】"js+css3制作下拉城市菜单多选代码.zip"的资源是一个结合JavaScript和CSS3技术实现的交互式下拉城市菜单的代码示例。这种菜单通常用于网站中,让用户能够方便地选择他们所在的城市或者感兴趣的地区,且支持...
在网页开发中,"Select框下拉城市三级联动代码"是一种常见的交互设计,它用于实现一个用户友好的城市选择功能。这种设计通常涉及到JavaScript(JS)编程,HTML和CSS技术,用于创建一个可搜索的、多级联动的城市选择...
这是一个基于JavaScript和CSS3实现的多选下拉城市菜单选择代码。这个代码示例主要利用了jQuery库,它提供了一种高效且用户友好的方式来处理动态交互和UI效果。在网页开发中,jQuery是一个非常流行的选择,因为它简化...
本文将深入探讨Unigui如何实现下拉城市选择功能,以及这一功能在实际应用中的重要性和实现细节。 一、Unigui框架简介 Unigui是基于VCL(Visual Component Library)和FMX(FireMonkey)框架的扩展,提供了丰富的...
在JavaScript和CSS3技术的支持下,我们可以创建一个交互性极强、视觉效果美观的下拉城市选择组件。这个组件主要用于用户在网页上进行多选城市操作,尤其适用于那些需要用户指定多个偏好或服务覆盖区域的场景。下面...
"js+css3下拉城市选择多选特效代码"是一个利用这两种技术实现的交互式城市选择组件,特别适合用于网站上的地址输入或者用户信息填写场景。 JavaScript是一种轻量级的解释型编程语言,常用于网页动态效果的实现,...
在网页开发中,"Select框下拉城市三级联动代码"是一种常见的交互设计,它用于创建一个下拉选择框,展示省、市、区三级结构的城市列表,并且支持通过中文拼音首字母快速搜索城市。这样的功能在许多需要用户输入地理...
描述中提到"jQuery下拉单选多选城市选择代码是一款select下拉框美化和下拉城市选择插件",这意味着该插件不仅解决了城市选择的视觉问题,还可能包含对元素的优化,如动态加载数据,以提高页面性能。同时,"单选"和...
《jQuery下拉选择城市插件hhDrop深度解析与应用》 在网页开发中,用户界面的设计和交互体验至关重要。为了提升用户体验,许多开发者选择使用jQuery这一强大的JavaScript库来实现复杂的功能,例如动态下拉选择城市的...
在网页开发中,"Select框下拉城市三级联动特效代码" 是一种常见的交互设计,用于实现用户在选择城市时的便捷操作。这种效果通常应用于地址输入或者定位服务中,能够帮助用户快速找到并选择他们所在的城市,特别是...
excle多级联动下拉列表模版(省市县) 采用省市县行数据格式,无需处理数据格式,更加方便快捷 内附excle多级联动下拉列表模版供参考
本文将深入探讨如何使用jQuery实现一个功能丰富的下拉多选组件,包括左右选择和移除功能。 首先,`jQuery multiselect` 是一种常见的实现下拉多选的解决方案。它允许用户在下拉框中选择多个选项,同时提供了自定义...