当前位置:  编程技术>移动开发
本页文章导读:
    ▪Spring对IBatis的调整        Spring对IBatis的整合 10.3 Spring对IBatis的支持 Spring对IBatis提供了完善的内建支持。使用Spring提供的IBatis辅助类,可以大大简化原有的IBatis访问代码。这些辅助类位于org.springframework.orm.ibatis包下,.........
    ▪ 自定义BaseAdapter,兑现列表显示功能        自定义BaseAdapter,实现列表显示功能 public class AppInfo{ public String appName = null;//应用程序名 public Drawable icon = null;//应用程序图片 }     import java.util.List; import android.content.Context; import android.v.........
    ▪ listview 几个主要属性       listview 几个重要属性 参考资料http://www.cnblogs.com/over140/archive/2010/09/11/1823806.htmlhttp://www.cnblogs.com/over140/archive/2010/11/19/1881445.html引用用心的朋友应该会发现,listview中在设置了背景之后。会有.........

[1]Spring对IBatis的调整
    来源: 互联网  发布时间: 2014-02-18
Spring对IBatis的整合
10.3 Spring对IBatis的支持

Spring对IBatis提供了完善的内建支持。使用Spring提供的IBatis辅助类,可以大大简化原有的IBatis访问代码。这些辅助类位于org.springframework.orm.ibatis包下,目前Spring可同时支持IBatis1.3.x和2.0。 此外,针对IBatis,Spring也提供了和JdbcTemplate一致的异常处理方式



10.3.1 标准JavaBean实体和映射

Spring宠物店非常典型的展现了Spring和IBatis的整合,下文将围绕宠物店展开介绍。首先来看宠物店中的一个领域对象(它是一个标准的JavaBean)和它的映射文件
Product.java(JavaBean)
public class Product implements Serializable {
  private String productId;
  private String categoryId;
  private String name;
  private String description;
  
  省略getter/setter...
}

Product.xml(映射文件)
<sqlMap namespace="Product">
  ...
  <resultMap id="result" >
    <result property="productId" column="productid" columnIndex="1"/>
    ...
  </resultMap>
  <select id="getProduct" resultMap="result">
    select productid, name, descn, category from product where productid = #value#
  </select>
  <select id="getProductListByCategory" resultMap="result">
    select productid, name, descn, category from product where category = #value#
  </select>
    ...
</sqlMap>

10.3.2  衔接IBatis配置和DAO实现

接着给出IBatis的基本配置文件
sql-map-config.xml(配置文件)
<sqlMapConfig>
  ...
  <sqlMap resource="org/springframework/samples/jpetstore/dao/ibatis/maps/Product.xml"/>
  ...
</sqlMapConfig>

在宠物店中,该文件仅包含了所有领域对象的映射文件,而挪走了关于IBatis的事务和数据源配置(即IBatis配置文件中的transactionManager元素和它的子元素dataSource)。注意:在稍后将要给出的Spring配置文件中接手了这些配置,这是一个整合点。在宠物店中,持久和数据访问都是通过DAO来实现的。对于Product,存在一个与其对应的SqlMapProductDao SqlMapProductDao.java
package org.springframework.samples.jpetstore.dao.ibatis;
import java.util.ArrayList;
import java.util.List;
import java.util.StringTokenizer;
import org.springframework.dao.DataAccessException;
import org.springframework.orm.ibatis.support.SqlMapClientDaoSupport;
import org.springframework.samples.jpetstore.dao.ProductDao;
import org.springframework.samples.jpetstore.domain.Product;

public class SqlMapProductDao extends SqlMapClientDaoSupport implements ProductDao {
  public List getProductListByCategory(String categoryId) throws DataAccessException {
    return getSqlMapClientTemplate().queryForList("getProductListByCategory", categoryId);
 }
  public Product getProduct(String productId) throws DataAccessException {
    return (Product) getSqlMapClientTemplate().queryForObject("getProduct", productId);
  }
  ...
}

上述代码中出现了Spring提供的IBatis DAO支持类和获取SqlMapClientTemplate的父类模板方法,这和JdbcDaoSupport及JdbcTemplate的使用具有一致的概念。并且,这些操作都统一的抛出Spring的通用数据访问异常DataAccessException。
注意:在早期的IBatis1.3.x版本中Dao支持类和模板类分别被命名为SqlMapDaoSupport和SqlMapTemplate,在使用时不要混淆。

10.3.3  关键整合点:Spring配置文件

有了以上的DAO组件后,来看一下Spring的配置,这是一个关键的整合点,如代码10.17所示。
代码10.17  dataAccessContext-local.xml(Spring配置文件)
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN"
"http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
  <!-- 相关数据源和事务管理的定义 -->
  <bean id="dataSource"  destroy-method="close">
    <property name="driverClassName" value="${jdbc.driverClassName}"/>
    <property name="url" value="${jdbc.url}"/>
    <property name="username" value="${jdbc.username}"/>
    <property name="password" value="${jdbc.password}"/>
  </bean>
  <!-- Transaction manager for a single JDBC DataSource -->
  <bean id="transactionManager"
  >
    <property name="dataSource" ref="dataSource"/>
  </bean>
  <!-- Spring提供的iBatis的SqlMap配置-->
  <bean id="sqlMapClient"
>
    <property name="configLocation" value="WEB-INF/sql-map-config.xml"/>
    <property name="dataSource" ref="dataSource"/>
  </bean>
  <!-- DAO定义-->
  ...
  <bean id="productDao">
    <property name="sqlMapClient" ref="sqlMapClient"/>
  </bean>
  ...
</beans>

可以发现,Spring在上述文件中分别配置了数据源和事务管理的策略,其中挪去了原先在IBatis文件中的配置。说明:这样做的好处是可以通过Spring IoC容器统一的管理资源,在稍后还可以看到,Spring提供的声明性事务管理就是借助于统一的数据源和事务管理配置。
SqlMapClientFactoryBean又是一个工厂bean,它暴露了两个关键属性用于注射IBatis配置文件和相关的数据源。在工厂内部,通过读取IBatis配置文件,Spring会创建出IBatis的核心组件SqlMapClient,并向相关的DAO进行注射。SqlMapProductDao继承了SqlMapClientDaoSupport,后者暴露出一个sqlMapClient属性,用于接受Spring的注射。SqlMapClientDaoSupport会对其中封装的SqlMapClientTemplate做相应的设置,所以DAO子类便可在取用SqlMapClientTemplate时正常地工作了。

10.3.4  添加声明式事务管理

以上的IBatis DAO可以很自方便地被注射到相应的业务对象,并参与到Spring提供的声明性事务中,配置如代码10.18所示。
代码10.18   applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN"
"http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
  <!-- 通用属性文件定义 -->
  <bean id="propertyConfigurer" >
    <property name="locations">
    <list>
         ...
        <value>WEB-INF/jdbc.properties</value>
      </list>
    </property>
  </bean>
  <!-- 业务对象定义 -->
  ...
  <bean id="baseTransactionProxy"  abstract="true">
    <property name="transactionManager" ref="transactionManager"/>
    <property name="transactionAttributes">
      <props>
        <prop key="insert*">PROPAGATION_REQUIRED</prop>
        <prop key="update*">PROPAGATION_REQUIRED</prop>
        <prop key="*">PROPAGATION_REQUIRED,readOnly</prop>
      </props>
    </property>
  </bean>
  <bean id="petStore" parent="baseTransactionProxy">
    <property name="target">
      <bean >
       ...
       <property name="productDao" ref="productDao"/>
        ...
      </bean>
  </bean>
</beans>

至此就基本完成了Spring IoC和IBatis的整合了,当然也可以通过编程的方式来使用Spring所提供的模板和支持类。

    
[2] 自定义BaseAdapter,兑现列表显示功能
    来源: 互联网  发布时间: 2014-02-18
自定义BaseAdapter,实现列表显示功能
public class AppInfo{  
	public String appName = null;//应用程序名
	public Drawable icon = null;//应用程序图片
	
}

 

 

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.ImageView;
import android.widget.TextView;

public class ListViewAdapter extends BaseAdapter{

	    private Context context;
	    private List<AppInfo> appList;

	    public ListViewAdapter(Context context, List<AppInfo> appList)
	    {
	        this.context = context;
	        this.appList = appList;
	    }

	    @Override
	    public int getCount()
	    {
	        // TODO Auto-generated method stub
	        return appList.size();
	    }

	    @Override
	    public Object getItem(int position)
	    {
	        // TODO Auto-generated method stub
	        return appList.get(position);
	    }

	    @Override
	    public long getItemId(int position)
	    {
	        // TODO Auto-generated method stub
	        return 0;
	    }

	    @Override
	    public View getView(int position, View convertView, ViewGroup parent)
	    {
	        // TODO Auto-generated method stub
	        View view = null;
	        ViewHolder holder = null;

	        LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);

	        if (convertView == null)
	        {
	            view = inflater.inflate(R.layout.list_item, null);
	            holder = new ViewHolder(view);
	            view.setTag(holder);
	        } else
	        {
	            view = convertView;
	            holder = (ViewHolder) convertView.getTag();
	        }        
	        AppInfo appInfo = (AppInfo)getItem(position);
	        holder.tvInfo.setText(appInfo.appName);
	        holder.imgInfo.setImageDrawable(appInfo.icon);
	        return view;
	    }

	    class ViewHolder
	    {
	        TextView tvInfo;
	        ImageView imgInfo;

	        public ViewHolder(View view)
	        {
	            tvInfo = (TextView) view.findViewById(R.id.tv01);
	            imgInfo = (ImageView) view.findViewById(R.id.img01);
	        }
	    }

	}

 

 

 

import android.app.Activity;
import android.app.AlertDialog;
import android.content.pm.PackageInfo;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.ImageButton;
import android.widget.ListView;
import java.util.*;

public class MyActivity extends Activity {
	
	    private ListView listView = null;
	    private List<AppInfo> appList = new ArrayList<AppInfo>();
	    private List<PackageInfo> manager = null;

	    @Override
	    public void onCreate(Bundle savedInstanceState)
	    {
	        super.onCreate(savedInstanceState);
	        setContentView(R.layout.main);

	        listView = (ListView) findViewById(R.id.mylist);

	        manager = getPackageManager().getInstalledPackages(0);
	        for (int i = 0; i < manager.size(); i++)
	        {
	            PackageInfo packageInfo = manager.get(i);
	            //应用程序信息存储到appinfo里
	            AppInfo appInfo = new AppInfo();
	            appInfo.appName = packageInfo.applicationInfo.loadLabel(getPackageManager()).toString();
	            appInfo.icon = packageInfo.applicationInfo.loadIcon(getPackageManager());
	            appList.add(appInfo);
	        }
	        
	        ListViewAdapter adapter = new ListViewAdapter(this, appList);
	        listView.setAdapter(adapter);
	    }
	}

 

 

 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
    
    <ImageView 
        android:id="@+id/img01"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        />
    <TextView  
        android:id="@+id/tv01"
        android:layout_width="fill_parent" 
        android:layout_height="wrap_content"         
        />
</LinearLayout>

 

 

 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
    <ListView
        android:id="@+id/mylist"  
        android:layout_width="fill_parent" 
        android:layout_height="wrap_content" 
        android:text="@string/hello"
        />
</LinearLayout>

 


    
[3] listview 几个主要属性
    来源: 互联网  发布时间: 2014-02-18
listview 几个重要属性
参考资料
http://www.cnblogs.com/over140/archive/2010/09/11/1823806.html
http://www.cnblogs.com/over140/archive/2010/11/19/1881445.html

引用

用心的朋友应该会发现,listview中在设置了背景之后。会有些问题。

1.、listview在拖动的时候背景图片消失变成黑色背景。等到拖动完毕我们自己的背景图片才显示出来。

2 、listview的上边和下边有黑色的阴影。

3、lsitview的每一项之间需要设置一个图片做为间隔。

针对以上问题 在listview的xml文件中设置一下语句。

问题1 有如下代码结解决 android:scrollingCache="false"

问题2 用如下代码解决:android:fadingEdge="none" 
问题3  用如下代码解决:  android:divider="@drawable/list_driver"  其中  @drawable/list_driver 是一个图片资源



总体如下

<ListView
  android:id="@+id/myListView01"
  android:layout_width="fill_parent"
  android:layout_height="287dip"
  android:fadingEdge="none" 
  android:divider="@drawable/list_driver"
  android:scrollingCache="false"
  android:background="@drawable/list">
  </ListView>


引用

由于这两天在做listView的东西,所以整理出来一些我个人认为比较特别的属性,通过设置这样的属性可以做出更加美观的列表
首先是stackFromBottom属性,这只该属性之后你做好的列表就会显示你列表的最下面,值为true和false
android:stackFromBottom="true"            
第二是transciptMode属性,需要用ListView或者其它显示大量Items的控件实时跟踪或者查看信息,并且希望最新的条目可以自动滚动到可视范围内。通过设置的控件transcriptMode属性可以将Android平台的控件(支持ScrollBar)自动滑动到最底部。
android:transcriptMode="alwaysScroll"   
第三cacheColorHint属性,很多人希望能够改变一下它的背景,使他能够符合整体的UI设计,改变背景背很简单只需要准备一张图片然后指定属性 android:background="@drawable/bg",不过不要高兴地太早,当你这么做以后,发现背景是变了,但是当你拖动,或者点击list空白位置的时候发现ListItem都变成黑色的了,破坏了整体效果。
如果你只是换背景的颜色的话,可以直接指定android:cacheColorHint为你所要的颜色,如果你是用图片做背景的话,那也只要将android:cacheColorHint指定为透明(#00000000)就可以了
第四divider属性,该属性作用是每一项之间需要设置一个图片做为间隔,或是去掉item之间的分割线
android:divider="@drawable/list_driver"  其中  @drawable/list_driver 是一个图片资源,如果不想显示分割线则只要设置为android:divider="@drawable/@null" 就可以了
第五fadingEdge属性,上边和下边有黑色的阴影
android:fadingEdge="none" 设置后没有阴影了~
第五scrollbars属性,作用是隐藏listView的滚动条,
android:scrollbars="none"与setVerticalScrollBarEnabled(true);的效果是一样的,不活动的时候隐藏,活动的时候也隐藏
第六fadeScrollbars属性,android:fadeScrollbars="true"  配置ListView布局的时候,设置这个属性为true就可以实现滚动条的自动隐藏和显示。

    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app...
▪Android Touch事件分发过程详解
▪Android中实现为TextView添加多个可点击的文本
▪Android程序设计之AIDL实例详解
▪Android显式启动与隐式启动Activity的区别介绍
▪Android按钮单击事件的四种常用写法总结
▪Android消息处理机制Looper和Handler详解
▪Android实现Back功能代码片段总结
▪Android实用的代码片段 常用代码总结
▪Android实现弹出键盘的方法
▪Android中通过view方式获取当前Activity的屏幕截...
▪Android提高之自定义Menu(TabMenu)实现方法
▪Android提高之多方向抽屉实现方法
▪Android提高之MediaPlayer播放网络音频的实现方法...
▪Android提高之MediaPlayer播放网络视频的实现方法...
▪Android提高之手游转电视游戏的模拟操控
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3