两listview联动

package com.mttz;

import java.util.ArrayList;
import java.util.List;

import com.mttz.adapter.CaiDanADP;
import com.mttz.bean.ShopDTO;

import android.graphics.Color;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.util.Log;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.ScrollView;
import android.widget.TextView;

public class CaiPinFragment extends Fragment{

//开始
ListView listView, listView2;
/**
* 本来想做标题停留在最上方的,不想想了
*/
// TextView textView;
/**
* 左边listview的要使用的数组
*/
String[] arr = new String[] {"快餐","超市","水果","生鲜","药店","更多" };

String[] arr2 = new String[] { "快餐", "水饺", "面", "米粉", "辣椒", "" };
String[] arr3 = new String[] { "超市", "急", "用", "钱", "找", "我", "们" };
String[] arr4 = new String[] { "水果", "放", "款", "快", "额" };
String[] arr5 = new String[] { "生鲜", "度", "高", "无", "需", "低", "压",
"food" };
String[] arr6 = new String[] { "药店", "联", "系", "电" };
String[] arr7 = new String[] { "更多", "话", "x", "x", "x", "x", "x",
"x", "x", "x", "美", "通", "投", "资" };

String[][] arr8 = new String[][] { arr2, arr3, arr4, arr5, arr6, arr7 };

/**
* 用来存放 food数组
*/
List<String> list;

/**
* 用来记录每一个 1 2 3 4 5 6 在右边listview的位置;
*/
List<Integer> nums = new ArrayList<Integer>();
//结束

// private ListView cp_caidan_lv,cp_caipin_lv;

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View rootView = inflater.inflate(R.layout.fragment_caipin,container, false);
// initWithView(rootView);
initView(rootView);

return rootView;
}

// private void initWithView(View view){
// cp_caidan_lv = (ListView) view.findViewById(R.id.cp_caidan_lv);//左侧菜单栏
// cp_caipin_lv = (ListView) view.findViewById(R.id.cp_caidan_lv);//右侧菜品栏
//
//
// }
//

private void initView(View view)
{
// textView = (TextView) findViewById(R.id.textView1);
listView = (ListView) view.findViewById(R.id.cp_caidan_lv);

List<String> CaiPinLV= new ArrayList<String>();
// list = new ArrayList<String>();

for (int j = 0; j < arr.length; j++)
{

CaiPinLV.add(arr[j]);

}

CaiDanADP adp = new CaiDanADP(CaiPinLV, getActivity());
listView.setAdapter(adp);

list = new ArrayList<String>();

for (int j = 0; j < arr8.length; j++)
{
for (int j2 = 0; j2 < arr8[j].length; j2++)
{
list.add(arr8[j][j2]);
}
}

for (int i = 0; i < arr8.length; i++)
{
if (i == 0)
{
nums.add(0);
} else if (i > 0 && i < arr8.length)
{
int num = 0;
for (int j = 0; j < i; j++)
{
num = num + arr8[j].length;

}
nums.add(num);
}
}

listView2 =(ListView) view.findViewById(R.id.cp_caipin_lv);
listView2.setAdapter(new MyAdapter());

/**
*
* 判断listview滑动
* */
listView2.setOnScrollListener(new AbsListView.OnScrollListener()
{

@Override
public void onScrollStateChanged(AbsListView view, int scrollState)
{

}

@Override
public void onScroll(AbsListView view, int firstVisibleItem,
int visibleItemCount, int totalItemCount)
{
if (nums.contains(firstVisibleItem) && listView.getChildCount() > 0)
{

for (int i = 0; i < listView.getChildCount(); i++)
{
if (i == nums.indexOf(firstVisibleItem))
{
listView.getChildAt(i).setBackgroundColor(
Color.rgb(200, 200, 200));
} else
{
listView.getChildAt(i).setBackgroundColor(Color.TRANSPARENT);

}

}

}
}
});

listView.setOnItemClickListener(new AdapterView.OnItemClickListener()
{
@Override
public void onItemClick(AdapterView<?> parent, View view, int position,
long id)
{
for (int i = 0; i < listView.getChildCount(); i++)
{
if (i == position)
{
view.setBackgroundColor(Color.rgb(255, 250, 250));
} else
{
view.setBackgroundColor(Color.rgb(200, 200, 200));
}
}

listView2.setSelection(nums.get(position));

}
});

}

class MyAdapter extends BaseAdapter
{
private LayoutInflater inflater;

@Override
public int getCount()
{
return list.size();
}

@Override
public Object getItem(int position)
{
return list.get(position);
}

@Override
public long getItemId(int position)
{
return position;
}

@Override
public View getView(int position, View convertView, ViewGroup parent)
{
// TextView textView = new TextView(getActivity());
// textView.setText(list.get(position));
// textView.setGravity(Gravity.CENTER_VERTICAL);
// textView.setMinHeight(200);
//
//
// if (nums.contains(position))
// {
// textView.setBackgroundColor(Color.argb(80,80, 80, 80));
// }

// if (convertView == null) {
inflater = LayoutInflater.from(getActivity());
convertView = inflater.inflate(R.layout.shop_item, null);

TextView shop_name = (TextView) convertView.findViewById(R.id.shop_name);
ImageView shoplogo = (ImageView) convertView.findViewById(R.id.shop_logo);
// convertView.setTag(holder);
shop_name.setText(list.get(position));
shoplogo.setBackgroundResource(R.drawable.eleme_sjm);
if (nums.contains(position))
{
convertView = inflater.inflate(R.layout.goods_details, null);
// convertView.setg
TextView cp = (TextView) convertView.findViewById(R.id.cp_root);
cp.setText(list.get(position));
cp.setTextColor(Color.rgb(255,250,250));
convertView.setBackgroundColor(Color.rgb(200, 200, 200));
return convertView;
}else {
return convertView;
}
// }
//
//
// if (mInfo!=null) {
// String shopname= mInfo.getShopname();
// String imageUrl = mInfo.getShoplogo();

}

}
}

时间: 2024-10-08 20:08:26

两listview联动的相关文章

Combobox下拉框两级联动

下拉框的两级联动是我们开发中经常遇到一种情况.比如一个学生管理系统中,根据年级.科目及姓名查询学生考试成绩,年级和科目都是硬盘中的有限数据(数据库)而学生则可以有用户手动指定,这时在数据库中有年级和科目两张表,每门科目都对应一个年级,所以我们可以用两个下拉框(Combobox)来存储年级和科目信息来供用户选择.界面如下: 这时如果我们将科目对应的下拉框直接绑定科目表时,用户选择一个年级后还要从所有科目中进行选择就会降低系统的友好性,甚至可能出现没有任何意义的查询语句.我们可以先绑定年级下拉框的数

DropDownList绑定数据表实现两级联动示例

这篇文章主要介绍了DropDownList绑定数据表实现两级联动具体实现,需要的朋友可以参考下 场景一:平时我们在DropDownList控件下添加下拉选项时,都会使用它的Item.Add方法,直接在代码下添加.如果我们想添加或修改下拉选项,则必须去修改源代码.如果几个DropDownList控件的下拉选项相同,我们则需要重复添加好多次,后期的维护工作很不方便. 场景二:我们在12306网站买票时,肯定遇到过这么一种情景:我们需要先选定目的地的省份,选完省份后在城市选框中会自动加载该省份的城市,

故障管理系统--select两级联动查询

写故障管理系统时,根据主类-平台进行故障搜索,需要用到select两级联动查询 我前端技术纯菜鸟,请教了个水平高的同事才搞定,所以记录下来,以免以后再忘了 前端html <form id="tab" class="form-inline" role="form" action='/search/' method='GET' style="float:right;margin-top:-48px;margin-right:0px;&

NET:异步刷新,dropdownlist两级联动, Triggers

PS::我在论坛发了个求助帖子,居然没啥人回..好纠结啊... http://bbs.csdn.net/topics/390809330 目的:三个dropdownlist A  B   C,     要求实现  A  联动 C,   B 联动 C 涉及:ScriptManager .  UpdatePanel ,  Triggers,   AsyncPostBackTrigger ScriptManager 对象集:启用局部呈现 <asp:ScriptManager ID="Script

仿饿了点餐界面2个ListView联动

如图是效果图 是仿饿了的点餐界面 1.点击左侧的ListView,通过在在适配器中设置Item来改变颜色,再通过notifyDataSetInvalidated来刷新并用lv_home.setSelection(showTitle.get(arg2));来关联右侧的 2.右侧的主要是重写下onScroll的方法:来改变左侧ListView的颜色及背景 不过程序中还有个问题,望大神解答就是我右侧的ListView下拉时,上面的TextView能改变:但是上拉时,TextView的不能及时改变应为滑

DropDownList控件:两级联动--【Asp.Net】

最近学习Asp.Net,发现很多控件都很有意思,例如:Canlender,AdRotator等.以前只知道有这样的页面效果,但是对这些控件了解并不多.不怕不知道,就怕不知道. DropDownList,两级联动,做这个demo的时候,让我又爱又恨. 一开始的时候,自己就草草的建立了一个Fresh的数据库,建立了一个Student表如下图所示: 在页面上面放了两个DropDownList,两个SqlDataSource.如下图所示: 下面就需要通过SqlDataSource设置数据源,让DropD

JS练习:两级联动

代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>两级联动</title> <script> //准备数据 var provinces = [ ["深圳市", "东莞市", "惠州市", "广州市"], ["长沙市", &quo

仿美团外卖,饿了吗 两个ListView联动,左边点击切换右边,右边滑动切换左边

先上效果图: 实现思路: 1.先说右边标题: 首先,右边的数据源集合中的Javabean中含有三个属性name,type,title,而每个条目中会默认含有一个标题. 如果这是第一个条目,就让标题显示出来,再如果这个条目的类型和上一个条目的类型不一样,就让这个条目的标题显示出来,否则,就隐藏标题,  这样我们就做到了每种类型只有第一个数据标题显示出来 接着,在Listview的外层(也就是MainActivity的布局文件中),默认放一个标题(下面都称作是主标题) 最后,设置右边Listview

Jquery实现两级联动

最后结果如下: 关键代码如下: <select name="customerCondition['credibilityBegin']" id="credibilityBegin" class="ui_select01" style="width:90px" onchange="changeCredibility();"> <option value="" select