Android HorizontalScrollView 水平滑动 在listview上面动态添加图片

Android HorizontalScrollView   水平滑动    listview 上动态添加图片

最近遇到了个 在listview展示广告的需要动态添加图片

如图:

使用了 horizontalScrollView   在listview上进行添加

java代码:

package com.baozi.bzhorizontalscrollview;

import java.util.ArrayList;

import android.app.Activity;
import android.content.Intent;
import android.net.Uri;
import android.os.Bundle;
import android.text.TextUtils;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.ListView;

public class MainActivity extends Activity {

	private ListView lv;
	private View headerView;
	private LinearLayout header_ll;
	ArrayList<String> arrayList = new ArrayList<String>();

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		lv = (ListView) findViewById(R.id.lv);

		headerView = LayoutInflater.from(this).inflate(
				R.layout.item_home_header, null);
		header_ll = (LinearLayout) headerView.findViewById(R.id.header_ll);

		for (int i = 0; i < 10; i++) {
			View coupon_home_ad_item = LayoutInflater.from(this).inflate(
					R.layout.home_item, null);
			ImageView icon = (ImageView) coupon_home_ad_item
					.findViewById(R.id.coupon_ad_iv);// 拿个这行的icon 就可以设置图片

			final String href = "http://www.blog.csdn.net/aaawqqq";
			if (!TextUtils.isEmpty(href)) {

				coupon_home_ad_item.setOnClickListener(new OnClickListener() {// 每个item的点击事件加在这里

							@Override
							public void onClick(View v) {
								Uri uri = Uri.parse(href);
								Intent intent = new Intent(Intent.ACTION_VIEW,
										uri);
								startActivity(intent);

							}
						});
			}
			header_ll.addView(coupon_home_ad_item);

		}
		lv.addHeaderView(headerView);// 通过listview的addHeaderView方法 将header添加到
										// listview里面

		// listview的测试数据
		for (int i = 0; i < 20; i++) {
			arrayList.add(i + "  -------------     "
					+ System.currentTimeMillis());
		}
		ArrayAdapter adapter = new ArrayAdapter(this, R.layout.item,
				R.id.textView1, arrayList);

		lv.setAdapter(adapter);
	}
}

xml代码:

activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#f4f4f4"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.baozi.bzhorizontalscrollview.MainActivity" >

    <ListView
        android:id="@+id/lv"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent" >
    </ListView>

</RelativeLayout>

item_home_header.xml

<?xml version="1.0" encoding="UTF-8"?>
<HorizontalScrollView xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:ptr="http://schemas.android.com/apk/res-auto"
    android:id="@+id/coupon_home_ad_hv"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical"
    android:scrollbars="none" >

    <LinearLayout
        android:id="@+id/header_ll"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="15dp"
        android:background="#dddddd"
        android:orientation="horizontal" >
    </LinearLayout>

</HorizontalScrollView>

home_item.xml

<?xml version="1.0" encoding="UTF-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:ptr="http://schemas.android.com/apk/res-auto"
    android:id="@+id/coupon_home_ad_ll"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginBottom="10dp"
    android:layout_marginLeft="5dp"
    android:layout_marginRight="5dp"
    android:layout_marginTop="10dp"
    android:gravity="center"
    android:orientation="horizontal" >

    <ImageView
        android:id="@+id/coupon_ad_iv"
        android:layout_width="120dp"
        android:layout_height="90dp"
        android:layout_margin="4dp"
        android:background="@drawable/ic_launcher"
        android:scaleType="centerCrop" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:text="点我"
        android:textColor="#000000"
        android:textSize="20sp" />

    <View
        android:layout_width="1dp"
        android:layout_height="90dp"
        android:background="#000000" />

</FrameLayout>

步骤:

首先加载 header

headerView = LayoutInflater.from(this).inflate(R.layout.item_home_header,
null);

header_ll = (LinearLayout)
headerView.findViewById(R.id.header_ll);

获取header里面的  LinearLayout

将服务器获取的imageview 通过for循环    add   到header上的linearlayout

添加点击事件等

不足之处请大家指正 谢谢

时间: 2024-08-27 05:18:40

Android HorizontalScrollView 水平滑动 在listview上面动态添加图片的相关文章

横向滑动的listview效果的实现方法,scrollview嵌套水平滑动的listview卡顿的解决方法

很多时候,界面需要实现横向滑动的listview效果.网络上有一种方法,自定义了HorizontalListView,用法同正常的listview,可实现水平滑动效果. 但是如果一个界面 为垂直滑动的scrollview嵌套水平滑动的listview的时候,滑动水平listview的时候,会很卡.我最近就遇到了这样的问题,一直把思路放在监听水平和垂直滑动手势,想实现滑动角度小于45的时候 垂直的scrollview 滑动效果被禁止.但是一直没有研究出来. 于是一个偶然的机会,灵光一闪,想到用Ho

Android 动态添加图片 换行

<strong>近在项目中用到动态添加图片,然后换行的实现.刚开始想用GridView,但是没用,什么原因到是忘了.下面我记录一下我的实现方式.</strong> <strong> </strong> 看代码xml: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.andro

android开发干货:实现listview异步加载图片

针对listview异步加载图片这个问题,麦子学院android开发老师讲了一种非常实用的方法,麦子学院android开发老师说凡是是要通过网络获取图片资源一般使用这种方法比较好,用户体验好,下面就说实现方法,先贴上主方法的代码: package cn.wangmeng.test; import java.io.IOException; import java.io.InputStream; import java.lang.ref.SoftReference; import java.net.

安卓——ListView的动态添加与删除

一,添加 case R.id.imgBtnAdd:/*添加列表*/ if(SetTempListView.getChildCount()>5){ Toast.makeText(getApplicationContext(), "列表只能添加6条!", Toast.LENGTH_SHORT).show(); break; } listItem.clear(); for(int i=0;i<SetTempListView.getChildCount();i++){ View v

ios开发 在cell中动态添加图片解决重复出现图层问题

1.在cell初始化的时候创建scrollView,然后往scrollView中添加imageView,最后在重用cell的时候动态计算scrollView的高度 总而言之,就是初始化创建控件要放在cell的init里面,赋值放init外面,不然每次循环都会重复创建imageView视图 -(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{ UI

UEditor动态添加图片访问路径前缀

在使用UEditor上传图片时发现上传图片后在编辑器中不能显示上传的图片,在这里是需要在jsp/config.json中设置图片访问路径前缀,即项目的根路径,在config.json只能填写字符串的配置,不能动态设置,如果需要动态设置需要修改ueditor.all.js(这是找到的方法),具体修改如下 这里的link就是图片的访问路径 下面的方法是在js中获取当前项目的根路径

Winform DataGridView列的单元格中动态添加图片和文字

先上图在说,第二列中图片和文字的样式 1.需要重写DataGridViewTextBoxColumn,新建类TextAndImageColumn.cs 1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Windows.Forms; 6 using System.Drawing; 7 8 namespace DataGridView

可以动态添加图片的轮播插件

http://www.jq22.com/jquery-info70 官网:http://tympanus.net/codrops/2011/09/12/elastislide-responsive-carousel/ 官网下载的demo包里默认的CSS和页面中引用了Google的api导致加载很慢,可以去掉或者加载国内的jQueryCDN <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></scri

android 动态添加控件并实现每个子控件的点击事件

需求:我们要点击进入一家店铺,根据不同的店铺,显示不同条数的子条目 如:消毒间,洗菜间等...这些都是或多或少的,所以需要动态添加: 首先自定义View(linearLayout): package cn.qust.fang.widget; import io.vov.vitamio.MediaPlayer; import io.vov.vitamio.widget.MediaController; import io.vov.vitamio.widget.VideoView; import a