ch011 Android Galley与ImageSwitch

本文介绍了一个使用Gallery和ImageSwitcher实现的图片展示案例,包括XML布局文件、自定义适配器ImageAdapter及MainActivity的实现。通过触摸事件实现图片预览与切换,适用于Android应用开发。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

--------------------------------------------Layout activity_main.xml--------------------------

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

    xmlns:tools="http://schemas.android.com/tools"

    android:id="@+id/LinearLayout1"

    android:layout_width="match_parent"

    android:layout_height="match_parent"

    android:orientation="vertical" >

    <ImageSwitcher

        android:id="@+id/imageSwitcher"

        android:layout_width="fill_parent"

        android:layout_height="fill_parent"

        android:layout_weight="0.2" >

    </ImageSwitcher>

    <Gallery

        android:id="@+id/gallery"

        android:layout_width="fill_parent"

        android:layout_height="fill_parent"

        android:layout_weight="0.8" android:spacing="10sp"/>

</LinearLayout>

--------------------------------------------Layout gallery_item.xml---------------------------

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"

    xmlns:tools="http://schemas.android.com/tools"

    android:id="@+id/RelativeLayout1"

    android:layout_width="match_parent"

    android:layout_height="match_parent"

    android:orientation="vertical" >

    <ImageView

        android:id="@+id/image"

        android:layout_width="wrap_content"

        android:layout_height="wrap_content" android:src="@drawable/ic_launcher"/>

</RelativeLayout>

--------------------------------------------Adapter ImageAdapter.xml------------------------

package com.ch11;

import android.content.Context;

import android.view.LayoutInflater;

import android.view.View;

import android.view.ViewGroup;

import android.view.ViewGroup.LayoutParams;

import android.widget.BaseAdapter;

import android.widget.Gallery;

import android.widget.ImageView;

/**

 * 

 * 项目名称:com.ch11    

 * 类名称:ImageAdapter    

 * 类描述:  自定义适配器,为Gallery提供数据

 * 创建人:方勇   

 * 创建时间:2012-11-16 下午4:08:11   

 * Copyright (c) 方勇-版权所有

 */

public class ImageAdapter extends BaseAdapter {

/* 上下文对象 */

private Context mContext;

/* 布局管理对象 */

private LayoutInflater layoutInfalter;

/* 图片资源集合 */

public static Integer[] images = { R.drawable.a, R.drawable.b, R.drawable.c, R.drawable.d, R.drawable.e };

public ImageAdapter(Context context) {

super();

this.mContext = context;

layoutInfalter = LayoutInflater.from(mContext);

}

/* Gallery对应的图片个数 */

@Override

public int getCount() {

// TODO Auto-generated method stub

return images.length;

}

@Override

public Object getItem(int position) {

// TODO Auto-generated method stub

return position;

}

@Override

public long getItemId(int position) {

// TODO Auto-generated method stub

return position;

}

@Override

public View getView(int position, View convertView, ViewGroup parent) {

ImageView imageView;

/* 实例化ImageView对象 */

if (null == convertView) {

/* 获取根视图对象 */

View view = layoutInfalter.inflate(R.layout.gallery_itemnull);

/* 图片对象 */

imageView = (ImageView) view.findViewById(R.id.image);

else {

imageView = (ImageView) convertView;

}

/* 图片源 */

imageView.setImageResource(images[position]);

/* Gallery图片布局类型 */

imageView.setLayoutParams(new Gallery.LayoutParams(100, LayoutParams.FILL_PARENT));

return imageView;

}

}

--------------------------------------------MainActivity.java-----------------------------------

package com.ch11;

import android.app.Activity;

import android.os.Bundle;

import android.util.Log;

import android.view.MotionEvent;

import android.view.View;

import android.view.View.OnTouchListener;

import android.view.ViewGroup.LayoutParams;

import android.widget.AdapterView;

import android.widget.AdapterView.OnItemSelectedListener;

import android.widget.Gallery;

import android.widget.ImageSwitcher;

import android.widget.ImageView;

import android.widget.ViewSwitcher.ViewFactory;

/**

 * 

 * 项目名称:com.ch11    

 * 类名称:MainActivity    

 * 类描述:  Galley,ImageSwitch,自定义适配器

 * 创建人:方勇   

 * 创建时间:2012-11-16 上午9:04:16   

 * Copyright (c) 方勇-版权所有

 */

public class MainActivity extends Activity implements OnItemSelectedListener, ViewFactory {

/* 相册控件 */

private Gallery gallery;

/* 图片切换控件 */

private ImageSwitcher imageSwitcher;

// 选中的图片索引

private int selectedTag = 0;

// 松开时的坐标x

private int upX;

// 按下时 的坐标x

private int downX;

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

findViews();

setListeners();

init();

}

/* 初始化UI */

private void findViews() {

gallery = (Gallery) findViewById(R.id.gallery);

imageSwitcher = (ImageSwitcher) findViewById(R.id.imageSwitcher);

}

/* 监听事件 */

private void setListeners() {

gallery.setOnItemSelectedListener(this);

imageSwitcher.setOnTouchListener(onTouchListener);

}

/* 设置参数 */

private void init() {

/* 绑定图片适配器 */

ImageAdapter imageAdapter = new ImageAdapter(this);

gallery.setAdapter(imageAdapter);

/* Sets the factory used to create the two views between which the ViewSwitcher will flip */

/* 创建两个视图,手指滑动时,相互切换 */

imageSwitcher.setFactory(this);

}

/* 选中事件 */

@Override

public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {

imageSwitcher.setImageResource(ImageAdapter.images[position]);

selectedTag = position;

}

/* ImageSwitcher的触摸事件 */

private OnTouchListener onTouchListener = new OnTouchListener() {

@Override

public boolean onTouch(View v, MotionEvent event) {

if (event.getAction() == MotionEvent.ACTION_DOWN) {

downX = (int) event.getX(); // 取得按下时 的坐标x

return true;

else if (event.getAction() == MotionEvent.ACTION_UP) {

upX = (int) event.getX(); // 取得松开时的坐标x

}

if (upX - downX > 100) { // 从左拖到右,即看前一张

// 如果是第一,则去到尾部

if (gallery.getSelectedItemPosition() == 0)

selectedTag = gallery.getCount() - 1;

else

selectedTag = gallery.getSelectedItemPosition() - 1;

}

if (downX - upX > 100)// 从右拖到左,即看后一张

{

// 如果是最后,则去到第一

if (gallery.getSelectedItemPosition() == (gallery.getCount() - 1))

selectedTag = 0;

else

selectedTag = gallery.getSelectedItemPosition() + 1;

}

// Jump directly to a specific item in the adapter data.

// 直接跳到数据适配器中指定项。

// 改变gallery图片所选,自动触发ImageSwitcher的setOnItemSelectedListener

gallery.setSelection(selectedTagtrue);

return true;

}

};

@Override

public void onNothingSelected(AdapterView<?> parent) {

// TODO Auto-generated method stub

}

@Override

public View makeView() {

Log.v("fy""makeView start ...");

ImageView imageView = new ImageView(this);

// 伸缩比例与图片位置

imageView.setScaleType(ImageView.ScaleType.FIT_CENTER);

// 布局

imageView.setLayoutParams(new ImageSwitcher.LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));

Log.v("fy""makeView end ...");

return imageView;

}

}

--------------------------------------------效果图-----------------------------------------------

<!--EndFragment-->
标题基于SpringBoot+Vue的学生交流互助平台研究AI更换标题第1章引言介绍学生交流互助平台的研究背景、意义、现状、方法创新点。1.1研究背景意义分析学生交流互助平台在当前教育环境下的需求及其重要性。1.2国内外研究现状综述国内外在学生交流互助平台方面的研究进展实践应用。1.3研究方法创新点概述本研究采用的方法论、技术路线及预期的创新成果。第2章相关理论阐述SpringBootVue框架的理论基础及在学生交流互助平台中的应用。2.1SpringBoot框架概述介绍SpringBoot框架的核心思想、特点及优势。2.2Vue框架概述阐述Vue框架的基本原理、组件化开发思想及前端的交互机制。2.3SpringBootVue的整合应用探讨SpringBootVue在学生交流互助平台中的整合方式及优势。第3章平台需求分析深入分析学生交流互助平台的功能需求、非功能需求及用户体验要求。3.1功能需求分析详细阐述平台的各项功能需求,如用户管理、信息交流、互助学习等。3.2非功能需求分析对平台的性能、安全性、可扩展性等非功能需求进行分析。3.3用户体验要求从用户角度出发,提出平台在易用性、美观性等方面的要求。第4章平台设计实现具体描述学生交流互助平台的架构设计、功能实现及前后端交互细节。4.1平台架构设计给出平台的整体架构设计,包括前后端分离、微服务架构等思想的应用。4.2功能模块实现详细阐述各个功能模块的实现过程,如用户登录注册、信息发布查看、在线交流等。4.3前后端交互细节介绍前后端数据交互的方式、接口设计及数据传输过程中的安全问题。第5章平台测试优化对平台进行全面的测试,发现并解决潜在问题,同时进行优化以提高性能。5.1测试环境方案介绍测试环境的搭建及所采用的测试方案,包括单元测试、集成测试等。5.2测试结果分析对测试结果进行详细分析,找出问题的根源并
内容概要:本文详细介绍了一个基于灰狼优化算法(GWO)优化的卷积双向长短期记忆神经网络(CNN-BiLSTM)融合注意力机制的多变量多步时间序列预测项目。该项目旨在解决传统时序预测方法难以捕捉非线性、复杂时序依赖关系的问题,通过融合CNN的空间特征提取、BiLSTM的时序建模能力及注意力机制的动态权重调节能力,实现对多变量多步时间序列的精准预测。项目不仅涵盖了数据预处理、模型构建训练、性能评估,还包括了GUI界面的设计实现。此外,文章还讨论了模型的部署、应用领域及其未来改进方向。 适合人群:具备一定编程基础,特别是对深度学习、时间序列预测及优化算法有一定了解的研发人员和数据科学家。 使用场景及目标:①用于智能电网负荷预测、金融市场多资产价格预测、环境气象多参数预报、智能制造设备状态监测预测维护、交通流量预测智慧交通管理、医疗健康多指标预测等领域;②提升多变量多步时间序列预测精度,优化资源调度和风险管控;③实现自动化超参数优化,降低人工调参成本,提高模型训练效率;④增强模型对复杂时序数据特征的学习能力,促进智能决策支持应用。 阅读建议:此资源不仅提供了详细的代码实现和模型架构解析,还深入探讨了模型优化和实际应用中的挑战解决方案。因此,在学习过程中,建议结合理论实践,逐步理解各个模块的功能和实现细节,并尝试在自己的项目中应用这些技术和方法。同时,注意数据预处理的重要性,合理设置模型参数网络结构,控制多步预测误差传播,防范过拟合,规划计算资源训练时间,关注模型的可解释性和透明度,以及持续更新迭代模型,以适应数据分布的变化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值