当前位置: 编程技术>移动开发
本页文章导读:
▪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)
Product.xml(映射文件)
10.3.2 衔接IBatis配置和DAO实现
接着给出IBatis的基本配置文件
sql-map-config.xml(配置文件)
在宠物店中,该文件仅包含了所有领域对象的映射文件,而挪走了关于IBatis的事务和数据源配置(即IBatis配置文件中的transactionManager元素和它的子元素dataSource)。注意:在稍后将要给出的Spring配置文件中接手了这些配置,这是一个整合点。在宠物店中,持久和数据访问都是通过DAO来实现的。对于Product,存在一个与其对应的SqlMapProductDao SqlMapProductDao.java
上述代码中出现了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配置文件)
可以发现,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
至此就基本完成了Spring IoC和IBatis的整合了,当然也可以通过编程的方式来使用Spring所提供的模板和支持类。
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就可以实现滚动条的自动隐藏和显示。
参考资料
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就可以实现滚动条的自动隐藏和显示。
最新技术文章: