如何在android中使GridView的每个项目(图像和名称)都被正方形包围?

时间:2019-02-18 20:25:13

标签: android android-fragments gridview grid android-gridlayout

在GridView中,一个图像和文本作为项出现,因此我想将正方形作为边框作为每个图像和文本都在该正方形内与图像一样。 GridView的每个项目(图像和名称)在android中都被正方形包围,但无法像下面的图像那样进行。 enter image description here 按照图像我想在每个文本上添加圆角,并且图像应该像图像正方形一样被包围,我该怎么办? 我该怎么做才能使每张gridview的每一个图像都被正方形包围

xml:

<?xml version="1.0" encoding="utf-8"?>

  <LinearLayout xmlns:tools="http://schemas.android.com/tools"
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:background="#d3d3d3"
    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"
    >

        <GridView
            android:id="@+id/gridView"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:numColumns="auto_fit"
            android:columnWidth="90dp"
            android:horizontalSpacing="10dp"
            android:verticalSpacing="18dp"
            android:gravity="center"
            android:stretchMode="columnWidth">    
        </GridView>
    </LinearLayout>

片段

public class GridCateFragment   extends Fragment {

//Web api url

    View rootView;
    //RecyclerView recyclerViewInstitutions;
    //CustomListAdapter institutionAdapter;
    //ArrayList<Movie> institutions;

    public static final String TAG_IMAGE_URL = "image";
    public static final String TAG_NAME = "name";

    //GridView Object
    private GridView gridView;

    //ArrayList for Storing image urls and titles
    private ArrayList<String> images;
    private ArrayList<String> names;
    public GridCateFragment() {    
    }

    @Override
    public void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);    
    }

    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        rootView = inflater.inflate(R.layout.fragment_gridcatefragment, container, false);
        gridView = (GridView) rootView.findViewById(R.id.gridView);

        images = new ArrayList<>();
        names = new ArrayList<>();
        getData();
//        getClientsList();
        return rootView;

    }

    private void getData(){
        String tag_string_req = "req_register";
        String url = AppConfig.Base_Url +AppConfig.App_api+AppConfig.URL_Cat;
        //Showing a progress dialog while our app fetches the data from url
        final ProgressDialog loading = ProgressDialog.show(getContext(), "Please wait...","Fetching data...",false,false);

        //Creating a json array request to get the json from our api

        final StringRequest jsonObjReq = new StringRequest(Request.Method.GET,url, new Response.Listener<String>() {
            @Override
            public void onResponse(String response) {

                        //Dismissing the progressdialog on response
                        loading.dismiss();

                try {    
                    String jsonObjReq = null;
                    JSONObject obj = new JSONObject(String.valueOf(response));
                    String status = obj.getString("status");
                    String message = obj.getString("message");
                    Log.d(TAG, "Register Response1: " + status);
                    Log.d(TAG, "Register Response2: " + message);
                    JSONObject obj1 = new JSONObject(String.valueOf(obj));
                    JSONObject result = obj.getJSONObject("result");
                    Log.d(TAG, "Register Response3: " + result);
                    JSONArray category = result.getJSONArray("category");
                    Log.d(TAG, "Register Response4: " + category);

                    for (int i = 0; i < category.length(); i++) {
                        JSONObject object = category.getJSONObject(i);
                        Log.d(TAG, "Register Response5: " + object);
                        String k =object.getString("image");
                        String l=(object.getString("name"));
                        Log.d("feedArray", " " + k);
                        Log.d("feedArray1", " " + l);
                        //getting image url and title from json object
                        names.add(l);
                        images.add(k);

                        Log.d("feedArrayListAfterParse", " " + object.getString("name"));
                        Log.d("feedArrayListAfterPa1", " " + object.getString("id"));
                        Log.d("feedArrayListAfte", " " + object.getString("image"));
                    }       
                }
catch (JSONException e){
                        e.printStackTrace();
                    }


                GridViewAdapter gridViewAdapter = new GridViewAdapter(getContext(),names,images);

                //Adding adapter to gridview
                gridView.setAdapter(gridViewAdapter);

                }
              },
                new Response.ErrorListener() {
                    @Override
                    public void onErrorResponse(VolleyError error) {    
                    }
                }
        );

        //Creating a request queue
        RequestQueue requestQueue = Volley.newRequestQueue(getContext());
        //Adding our request to the queue
        requestQueue.add(jsonObjReq);
    }

}

适配器

public class GridViewAdapter extends BaseAdapter {

    //Imageloader to load images
    private ImageLoader imageLoader;

    //Context
    private Context context;

    //Array List that would contain the urls and the titles for the images
    private ArrayList<String> names;
    private ArrayList<String> images;

    public GridViewAdapter (Context context, ArrayList<String> names, ArrayList<String> images){
        //Getting all the values
        this.context = context;
        this.names = names;
        this.images = images;

    }

    @Override
    public int getCount() {
        return images.size();
    }

    @Override
    public Object getItem(int position) {
        return images.get(position);
    }

    @Override
    public long getItemId(int position) {
        return 0;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        //Creating a linear layout
        LinearLayout linearLayout = new LinearLayout(context);
        linearLayout.setOrientation(LinearLayout.VERTICAL);

        //Creating a textview to show the title
        TextView textView = new TextView(context);
        textView.setText(names.get(position));

        //NetworkImageView
        NetworkImageView networkImageView = new NetworkImageView(context);

        //networkImageView.setImageResource(mThumbIds[position]);
        networkImageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
        networkImageView.setLayoutParams(new GridView.LayoutParams(200, 200));

        //Initializing ImageLoader
        imageLoader = CustomVolleyRequest.getInstance(context).getImageLoader();
        imageLoader.get(images.get(position), ImageLoader.getImageListener(networkImageView, R.mipmap.ic_launcher, android.R.drawable.ic_dialog_alert));

        //Setting the image url to load
        networkImageView.setImageUrl(images.get(position),imageLoader);

        //Scaling the imageview
        networkImageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
        //networkImageView.setLayoutParams(new GridView.LayoutParams(200,200));

        //Adding views to the layout

        linearLayout.addView(networkImageView);
        linearLayout.addView(textView);

        //Returnint the layout
        return linearLayout;
    }
}

0 个答案:

没有答案