Reputation: 1200
I am Creating a gallery application..It is described here. http://www.androidhive.info/2012/02/android-gridview-layout-tutorial/
I am able to achieve this from drawable resources.. What i need is i want to fetch image url as json from server and to display it.. My Json Format is: http://52.42.251.70/testData/imagelist.php
Fragment Code:
public void onActivityCreated(Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
GridView gridView = (GridView)getView().findViewById(R.id.grid_view);
// Instance of ImageAdapter Class
gridView.setAdapter(new ImageAdapter(this.getActivity()));
/**
* On Click event for Single Gridview Item
* */
gridView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
Intent i = new Intent(getActivity(), FullImageActivity.class);
// passing array index
i.putExtra("id", position);
startActivity(i);
}
});
}
Imageadapter.java
public class ImageAdapter extends BaseAdapter {
private Context mContext;
JSONObject jsonobject;
DatabaseUserTable myDatadb;
JSONArray jsonarray;
String imageUrl = "";
String id = "";
ArrayList<String> Urls = new ArrayList<String>();
// Keep all Images in array
public Integer[] mThumbIds = {
R.drawable.imagewall,R.drawable.imagewall,
R.drawable.imagewall,R.drawable.imagewall,
R.drawable.imagewall,R.drawable.imagewall,
R.drawable.imagewall,R.drawable.imagewall,
R.drawable.imagewall,R.drawable.imagewall,
R.drawable.imagewall,R.drawable.imagewall,
R.drawable.imagewall,R.drawable.imagewall,
R.drawable.imagewall
};
// Constructor
public ImageAdapter(Context c){
mContext = c;
}
@Override
public int getCount() {
return mThumbIds.length;
}
@Override
public Object getItem(int position) {
return mThumbIds[position];
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ImageView imageView = new ImageView(mContext);
imageView.setImageResource(mThumbIds[position]);
imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
imageView.setLayoutParams(new GridView.LayoutParams(220, 220));
return imageView;
}
}
Upvotes: 1
Views: 3364
Reputation: 31
You can use picasso library to do the same.
configuration
put compile 'com.squareup.picasso:picasso:2.5.2'
in your module level build.gradle file.
Uses
replace imageView.setImageResource(mThumbIds[position]);
with Picasso.with(getActivity()).load("URL of the image").into(imageView);
For your url it seems a list of image urls. so you can pass this list to your adapter after getting the response.
Upvotes: 2
Reputation: 5329
Here is simple solution:
The new data on the server: https://dl.dropboxusercontent.com/u/31298901/demo/demo_image.txt
The AndroidManifest.xml file
<uses-permission android:name="android.permission.INTERNET" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
MainActivity class
public class MainActivity extends AppCompatActivity {
GridView gridView;
MyGridAdapter myGridAdapter;
private static String DATA_URL = "https://dl.dropboxusercontent.com/u/31298901/demo/demo_image.txt";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
gridView = (GridView) findViewById(R.id.gridview);
getData();
}
private void getData(){
RequestQueue queue = Volley.newRequestQueue(this);
StringRequest stringRequest = new StringRequest(Request.Method.GET, DATA_URL, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
try {
JSONObject jsonObject = new JSONObject(response);
JSONArray allImageArray = jsonObject.optJSONArray("images");
if(allImageArray != null && allImageArray.length() > 0){
ArrayList<ImageObject> imageObjects = new ArrayList<>();
for(int i = 0; i < allImageArray.length();i++){
JSONObject jsonItem = allImageArray.optJSONObject(i);
imageObjects.add(new ImageObject(jsonItem));
}
myGridAdapter= new MyGridAdapter(MainActivity.this, imageObjects);
runOnUiThread(new Runnable() {
@Override
public void run() {
gridView.setAdapter(myGridAdapter);
}
});
}
} catch (Exception e){
}
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
}
});
stringRequest.setRetryPolicy(new DefaultRetryPolicy(6000, DefaultRetryPolicy.DEFAULT_MAX_RETRIES, DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));
queue.add(stringRequest);
}
}
The layout for MainActivity activity_layout.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.android.vad.gridview.MainActivity">
<GridView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/gridview"
android:columnWidth="120dp"
android:verticalSpacing="10dp"
android:numColumns="auto_fit">
</GridView>
</RelativeLayout>
GridAdapter.java
public class MyGridAdapter extends BaseAdapter{
private Context context;
private ArrayList<ImageObject> imageObjects;
private LayoutInflater mLayoutInflate;
public MyGridAdapter (Context context, ArrayList<ImageObject> imageObjects){
this.context = context;
this.imageObjects = imageObjects;
this.mLayoutInflate = LayoutInflater.from(context);
}
public int getCount() {
if(imageObjects != null) return imageObjects.size();
return 0;
}
@Override
public Object getItem(int position) {
if(imageObjects != null && imageObjects.size() > position) return imageObjects.get(position);
return null;
}
@Override
public long getItemId(int position) {
if(imageObjects != null && imageObjects.size() > position) return imageObjects.get(position).getId();
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder viewHolder = null;
if (convertView == null) {
viewHolder = new ViewHolder();
convertView = mLayoutInflate.inflate(R.layout.imageitem, parent,
false);
viewHolder.imageView = (ImageView) convertView.findViewById(R.id.image);
convertView.setTag(viewHolder);
} else {
viewHolder = (ViewHolder) convertView.getTag();
}
ImageObject imageObject = (ImageObject) getItem(position);
if(imageObject != null) {
Glide
.with(context)
.load(imageObject.getImageUrl())
.centerCrop()
.crossFade()
.into(viewHolder.imageView);
}
return convertView;
}
private class ViewHolder {
public ImageView imageView;
}
}
imageitem.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="80dp"
android:layout_height="120dp">
<ImageView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/image"/>
</LinearLayout>
ImageObject.java
public class ImageObject {
private int id;
private String imageUrl;
public ImageObject(){
}
public ImageObject(JSONObject jsonObject){
if(jsonObject == null) return;
this.id = jsonObject.optInt("id");
this.imageUrl = jsonObject.optString("imageUrl");
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getImageUrl() {
return imageUrl;
}
public void setImageUrl(String imageUrl) {
this.imageUrl = imageUrl;
}
}
Dependencies in gradle build
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
testCompile 'junit:junit:4.12'
compile 'com.android.support:appcompat-v7:23.4.0'
compile 'com.github.bumptech.glide:glide:3.7.0'
compile 'com.mcxiaoke.volley:library:1.0.19'
}
Upvotes: 1