managedQuery()与getContentResolver().query()的区别:
Romain Guy写道:http://groups.google.com/group/android-developers/browse_thread/thread/9c887ac024b36798
managedQuery() will use ContentResolver's query(). The difference is
that with managedQuery() the activity will keep a reference to your
Cursor and close it whenever needed (in onDestroy() for instance.) If
you do query() yourself, you *will* have to manage the Cursor as a
sensitive resource. If you forget, for instance, to close() it in
onDestroy(), you will leak underlying resources (logcat will warn you
about it.)
mangedQuery会实际查询的工作还是调用ContentResolver的query这一点与getContentResolver一样,但managedQuery会让Activtiy来帮你管理你的cursor的,而不用你自己去管理。
如何通过XIB 创建自定义的UIViewTableCell
在使用UIViewTable的时候,很多时候会发现,基本的UITableViewCell并不能满足我们的所有需求,特别是个性化的需求。
那么如何通过XIB来创建自己的个性化的cell呢。
1。Add----New Filss---Cocoa Touch Classes---Object-C Class
创建一个 从 UITabelViewCell继承的类 UISpecialTableViewCell
2。Add---New Files----User Interface-----Empty XIB
创建一个空的 UISpecialTableViewCell.xib 文件,记住,XIB的名称一定要跟 签名的类的名称一致,也就是一模一样。
一定要选 Empty XIB类型,如果不是选的这个,那么创建的XIB里面的已经存在的那个UIView将不能调整高度,它的高度固定死了。
因为是空的XIB文件,所有往文件列表框中拖入一个 UIView的控件,然后将这个UIView的类名在属性器里面从UIView
改为UISpecialTableViewCell。
3。这样,就可以往这个新添加的View里面添加我们自己的个性化控件了,这个View就是我们的Cell的模板了。这个过程跟普通的XIB一样,没有什么特别的。
那么如何在代码中使用这个UISpecialTableViewCell呢?
代码如下:
好啦,这样就可以自己定制个性化的 UITableViewCell 啦!
android开发中会经常用来自定义的Adapter,如下就是一个简单的自定义Adapter实例。
import android.app.Activity;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
/**
* 自定义适配器通过ListView显示内容,这个比较重要需要掌握
* @author Dylan
*/
public class CustomAdapterActivity extends Activity {
private ListView mListView;
private CustomAdapter mAdapter;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
mListView = (ListView) findViewById(R.id.listview);
mAdapter = new CustomAdapter();
mListView.setAdapter(mAdapter);
mListView.setOnItemClickListener(new ItemClickListener());
}
private final class ItemClickListener implements OnItemClickListener {
// AdapterView<?> parent, --> ListView View view, ---> item int
// position,--> item的数据在Adapter中位置 long id---> item在listView中得位置
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
String name = (String) mAdapter.getItem(position);
Toast.makeText(getApplicationContext(), "name =" + name + ",position " + position, Toast.LENGTH_SHORT)
.show();
}
}
private final class CustomAdapter extends BaseAdapter {
private String[] names = new String[] { "无线和网络", "通话设置", "声音", "显示", "位置和安全", "应用程序", "账户与同步", "隐私权",
"SD卡和手机内存", "语言和键盘", "辅助功能", "日期和时间", "关于手机" };
private int[] images = new int[] { R.drawable.image01, R.drawable.image02, R.drawable.image03,
R.drawable.image04, R.drawable.image05, R.drawable.image06, R.drawable.image07, R.drawable.image08,
R.drawable.image09, R.drawable.image10, R.drawable.image11, R.drawable.image12, R.drawable.image13 };
private LayoutInflater mInflater;
public CustomAdapter() {
mInflater = getLayoutInflater();
}
// 描述adpter的大小(确定了listView的条目)
@Override
public int getCount() {
return names.length;
}
// Adapter对于的position的数据
@Override
public Object getItem(int position) {
return names[position];
}
// 得到item 在adapter所对应的位置
@Override
public long getItemId(int position) {
return position;
}
// 创建listview的item条目,把数据绑定给item int position, Adapter的下标 View
// convertView, 缓存的第一屏item的布局文件 ViewGroup parent ListView
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view = null;
if (convertView != null) {
view = convertView;
} else {
view = mInflater.inflate(R.layout.item, parent, false);
}
ImageView iv_header = (ImageView) view.findViewById(R.id.iv_header);
TextView tv_name = (TextView) view.findViewById(R.id.tv_name);
iv_header.setImageResource(images[position]);
tv_name.setText(names[position]);
return view;
}
/*
* @Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewCache viewCache = null;
if (convertView == null) {
viewCache = new ViewCache();
convertView = inflater.inflate(R.layout.folder_list_item, null);
viewCache.tvName = (TextView) convertView.findViewById(R.id.tv_folder_name);
viewCache.ivPreview = (ImageView) convertView.findViewById(R.id.iv_folder_preview);
convertView.setTag(viewCache);
} else {
viewCache = (ViewCache) convertView.getTag();
}
FileInfo fileInfo = arrayList.get(position);
viewCache.tvName.setText(new File(fileInfo.filePath).getName());
return convertView;
}
public static class ViewCache {
public ImageView ivPreview;
public TextView tvName;
}
*/
}
}