layout_picture_list.xml
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="@drawable/app_bg"
android:orientation="vertical" >
<ViewSwitcher
android:id="@+id/viewswitcher_news_top"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center" >
</ViewSwitcher>
<ListView
android:id="@+id/picture_id"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:cacheColorHint="@color/transparent"
android:divider="#00000000"
android:listSelector="#00000000" />
</FrameLayout>
PictureListActivity.java
package com.cps.media.ui.picture;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONArray;
import org.json.JSONObject;
import com.cps.media.R;
import com.cps.media.model.PictureItem;
import com.cps.media.util.CONST;
import com.cps.media.util.Util;
import android.app.Activity;
import android.content.Intent;
import android.graphics.Bitmap;
import android.net.Uri;
import android.os.AsyncTask;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.ViewSwitcher;
import android.widget.AdapterView.OnItemClickListener;
public class PictureListActivity extends Activity {
private ListView mListView;
private MyAdapter mAdapter;
private List<PictureItem> mList;
private ViewSwitcher viewSwitcher;
private int mId;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.layout_picture_list);
mListView = (ListView) findViewById(R.id.picture_id);
mId = getIntent().getIntExtra("id", 1);
viewSwitcher = (ViewSwitcher) findViewById(R.id.viewswitcher_news_top);
viewSwitcher.addView(getLayoutInflater().inflate(
R.layout.layout_progress_page, null));
requestData();
}
private void requestData() {
viewSwitcher.setVisibility(View.VISIBLE);
viewSwitcher.showNext();
Thread t = new Thread() {
@Override
public void run() {
super.run();
HttpClient client = new DefaultHttpClient();
StringBuilder builder = new StringBuilder();
int error = 1;
JSONArray array = null;
HttpGet myget = new HttpGet(CONST.URL_PICTURE_LIST.replace("{0}", mId+""));
try {
HttpResponse response = client.execute(myget);
BufferedReader reader = new BufferedReader(
new InputStreamReader(response.getEntity()
.getContent()));
for (String s = reader.readLine(); s != null; s = reader
.readLine()) {
builder.append(s);
}
JSONObject jsonObject = new JSONObject(builder.toString());
error = jsonObject.getInt("errno");
String errormsg = jsonObject.getString("errmsg");
Log.v("wgp", "url=" + myget.getURI().toString());
Log.v("wgp", "error=" + error);
Log.v("wgp", "errormsg=" + errormsg);
if (error == 0) {
array = jsonObject.getJSONArray("data");
PictureItem item;
mList = new ArrayList<PictureItem>();
for (int i = 0; i < array.length(); i++) {
item = new PictureItem();
item.setId(array.getJSONObject(i).getInt("id"));
item.setTitle(array.getJSONObject(i).getString(
"title"));
item.setImgUrl(array.getJSONObject(i).getString(
"img"));
mList.add(item);
}
if (mList.size() == 0) {
handler.sendEmptyMessage(-1);
} else {
handler.sendEmptyMessage(1);
}
}
} catch (Exception e) {
e.printStackTrace();
handler.sendEmptyMessage(-1);
} finally {
}
}
};
t.start();
}
Handler handler = new Handler() {
public void handleMessage(android.os.Message msg) {
if (msg.what == 1) {
mAdapter = new MyAdapter();
mListView.setAdapter(mAdapter);
mListView.setOnItemClickListener(mListItemListener);
}
viewSwitcher.setVisibility(View.INVISIBLE);
}
};
private OnItemClickListener mListItemListener = new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position,
long id) {
Intent intent = new Intent(Intent.ACTION_VIEW);
intent.setDataAndType(Util.getHttpImageURI(mList.get(position).getImgUrl()), "image/*");
startActivity(intent);
}
};
class MyAdapter extends BaseAdapter {
private AsyncImageTask mImageTask;
@Override
public int getCount() {
// TODO Auto-generated method stub
return mList.size();
}
@Override
public Object getItem(int position) {
// TODO Auto-generated method stub
return mList.get(position);
}
@Override
public long getItemId(int position) {
// TODO Auto-generated method stub
return mList.get(position).getId();
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView == null) {
holder = new ViewHolder();
convertView = getLayoutInflater().inflate(
R.layout.layout_picture_list_item, null);
holder.tv_name = (TextView) convertView
.findViewById(R.id.name_id);
holder.tv_image = (ImageView) convertView
.findViewById(R.id.type_image_id);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
mImageTask = new AsyncImageTask(holder.tv_image);
mImageTask.execute(mList.get(position).getImgUrl());
holder.tv_name.setText(mList.get(position).getTitle());
return convertView;
}
class ViewHolder {
TextView tv_name;
ImageView tv_image;
int type;
}
private class AsyncImageTask extends AsyncTask<String, Integer, Object> {
private ImageView image;
public AsyncImageTask(ImageView image) {
this.image = image;
}
@Override
protected Object doInBackground(String... params) {
try {
if(Util.CPSE_CACHE.exists())
return Util.getHttpImageURI(params[0]);
else{
return Util.getHttpBitmap(params[0]);
}
} catch (Exception e) {
// TODO: handle exception
}
return null;
}
@Override
protected void onPostExecute(Object result) {
// TODO Auto-generated method stub
super.onPostExecute(result);
if (image != null && result != null) {
if(result instanceof Uri){
image.setImageURI((Uri)result);
}else if(result instanceof Bitmap){
image.setImageBitmap((Bitmap)result);
}
} else if (image != null && result == null) {
image.setImageResource(R.drawable.news_default);
}
}
}
}
}
相关推荐
A picture list control
picture.html和picture_list.html需要放到templates/当前所以模板目录/article下面 大功告成,可以浏览http://网址/文章频道目录/picture.php看看了 频道下的栏目,用http://网址/文章频道目录/picture.php?catid=...
flutter_showcase_app 演示:Flutter演示应用程序。A showcase app for displaying image lists, developed on Flutter 。Uses BLOC pattern, SQFLite database, Streams, Repository pattern. 。...
它使用与开发人员工具中的Home Assistant完全相同的引擎。...update boolean false false 启用每次实体更改时刷新卡的功能picture_elements_mode boolean false false 启用图片元素模式entities list f
具体代码如下所示: ... picture_list = [] for dir,dir_abs,files in os.walk(dirs): for file in files: if file.endswith('.gif'): picture_list.append(os.path.join(dir,file)) return pi
如果谁要用这个资源,请先把 CDemoDlg类中加的 头文件的 CStatic m_pot; 和 DDX_Control(pDX, IDC_BU_UPANDDOWN, m_pot); 删除,谢谢。或者全部重新编译
在MFC的ListCtrl类中插入图片,按钮,颜色,edit控件,右键菜单,和气泡提示功能等,对大家扩展ListrCtrl类也许会有帮助
头像列表控件。qq中的头像列表本控件实现一样的功能。你可以自由添加删除列表类,向列表类添加删除列表项,支持事件操作!可以定义列表类按钮正常、指向、鼠标按下时显示的图片,滚动条的图片
基于Ant Design Upload listType=“picture-card“ 实现多图上传以及点击预览图片的组件,使用有问题可以留言
通过输入+char add [name] [displayname] [picture_url]来创建+char add [name] [displayname] [picture_url]通过输入+char add [name] [displayname] [picture_url] npc创建npc +char add [name] [displayname] ...
使用opencv模拟雷达扫描显示,扫描到的目标点,由rand函数随机产生,最终用于显示,目标识别后,显示目标。工程中的示例图片。
verify that file /system/etc/hawkview/sensor_list_cfg.ini is properly configured! ; ;vip_dev(x)_pos: sensor position, "rear" or "front", if vip_define_sensor_list = 1,vip_dev(x)_pos must be ...
struct sensor_item sensor_list_t[] = { // name i2c_addr sensor type sensor size sensor max pclk (请参照OV2640/GC2155配置) { "gc2145" , 0x78, SENSOR_YUV , PIXEL_NUM_2M , CORE_CLK_RATE_FOR_2M}, ...
struct sensor_item sensor_list_t[] = { // name i2c_addr sensor type sensor size sensor max pclk { "hm1375" , 0x48, SENSOR_YUV , PIXEL_NUM_2M , CORE_CLK_RATE_FOR_2M}, { "hm5065" , 0x3e, SENSOR...
头像列表控件,与QICQ中的头像列表一样的功能。 可以自由添加删除列表类,向列表类添加删除列表项,支持事件操作!可以定义列表类按钮正常、指向、鼠标按下时显示的图片,滚动条的图片!
verify that file /system/etc/hawkview/sensor_list_cfg.ini is properly configured! ; ;vip_dev(x)_pos: sensor position, "rear" or "front", if vip_define_sensor_list = 1,vip_dev(x)_pos must be ...
Title:Schriftenreihe Information und Recht Publisher:Beck'sche Verlagsbuchhandlung Length:544 pages Vorwort. . . . . ....Inhaltsübersicht....Abbildungsverzeichnis....Abkürzungsverzeichnis ....
image_list.txt文件应包含: 文件名 焦距 这是image_list.txt的示例: # Filename focal_length DSC_0184.jpg 830 DSC_0185.jpg 830 DSC_0186.jpg 830 DSC_0187.jpg 830 DSC_0171.jpg 830 DSC_0172.jpg 8
list_add_tail(&dev->devlist, &devlist); dev->vfd = vfd; vfe_print("V4L2 device registered as %s\n",video_device_node_name(vfd)); /*initial video buffer queue*/ videobuf_queue_dma_contig_init(&...
PopupMenu Frm_menu.List, , Picture1(3).Left, Picture1(3).Top Picture1(3).Height 10 Case 4 '模式菜单 PopupMenu Frm_menu.model, , Picture1(4).Left, Picture1(4).Top Picture1(4).Height 10 Case 5, ...