android控件大全及用法_学双人舞一步一步教学

android控件大全及用法_学双人舞一步一步教学GridView用于显示二维滚动网格的View。同ListView一样,他的数据项也是从ListAdapter中产生。关于他的使用方法可参见官网的示例GridView 。下面先了解下GridView中常用到的属性:1、android:numColumn:指定GridView的列数,如果指定为auto_fit,则可能根据控件的大小自动调整每行显示的列数。2、android:st

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

GridView 用于显示二维滚动网格的View。同ListView一样,他的数据项也是从ListAdapter中产生。关于他的使用方法可参见官网的示例GridView 。

下面先了解下GridView中常用到的属性:

1、android:numColumn : 指定GridView的列数,如果指定为auto_fit , 则可能根据控件的大小自动调整每行显示的列数。

2、android:strechMode : 伸缩模式 , 值为none (不可伸缩)、 spacingWidth(伸缩列之间的间隔空隙) 、 columnWidth(每列伸缩大小一样) 、 spacingWidthUniform(均匀拉伸各列之间的距离) 。

3、 android:columnWidth :  指定列宽度。

关于GridView属性的介绍就到这里。今天通过做一个类似于launcher功能的小程序来学习GridView。先看看程序效果:

android控件大全及用法_学双人舞一步一步教学

下面一步一步实现该功能:

1、activity使用的布局文件,文中指定显示3列 。widget_gridview_layout.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <GridView
        android:id="@+id/show_app_grid_view"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:numColumns="3"
        android:smoothScrollbar="true"
        android:verticalSpacing="10dp" >
    </GridView>

</LinearLayout>

Jetbrains全家桶1年46,售后保障稳定

2、GridView中每个Item的布局文件grid_item_view.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="100dp"
    android:orientation="vertical" >

    <ImageView
        android:id="@+id/application_icon"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:contentDescription="@string/app_name"
        android:src="@drawable/toggle" />

    <TextView
        android:id="@+id/application_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:ellipsize="marquee"
        android:singleLine="true"
        android:textAppearance="?android:attr/textAppearanceSmall" />
    <!--
        android:focusable="true"
        android:focusableInTouchMode="true"


    -->

</LinearLayout>

注意:在代码中如果添加了上面注释的部分,则不会响应GridView 的onItemClick 方法。

3、WidgetGridViewActivity.java

package com.xy.zt.selfdefinewieget;

import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.content.pm.ApplicationInfo;
import android.content.pm.PackageManager;
import android.graphics.drawable.Drawable;
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.GridView;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;

import java.util.ArrayList;
import java.util.List;

public class WidgetGridViewActivity extends Activity {
    private GridView mAppGrid;
    private BaseAdapter mAdapter;
    PackageManager mPackManager;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.widget_gridview_layout);
        init();
    }

    private void init() {
        mAppGrid = (GridView) findViewById(R.id.show_app_grid_view);
        mPackManager = getPackageManager();
        List<ApplicationInfo> packInfo = mPackManager
                .getInstalledApplications(PackageManager.COMPONENT_ENABLED_STATE_ENABLED);

        mAdapter = new ApplicationAdapter(this, packInfo);
        mAppGrid.setAdapter(mAdapter);
        mAppGrid.setOnItemClickListener(new OnItemClickListener() {

            public void onItemClick(AdapterView<?> adaper, View v, int position, long id) {
                ApplicationInfo pInfo = (ApplicationInfo) mAdapter.getItem(position);
                Intent appIntent = mPackManager.getLaunchIntentForPackage(pInfo.packageName);
                if (appIntent == null) {
                    Toast.makeText(v.getContext(), "this is not a launcher activity !...",
                            Toast.LENGTH_SHORT).show();
                    return;
                }
                appIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
                startActivity(appIntent);
            }

        });
    }

    private static class ApplicationAdapter extends BaseAdapter {
        private List<ApplicationInfo> mAppList;
        private LayoutInflater mInflater;
        private PackageManager mPackageManager;
        private Context mContext;

        public ApplicationAdapter(Context context, List<ApplicationInfo> appList) {
            if (context == null || appList == null)
                throw new IllegalArgumentException(
                        "exits null arguments  in constructor method of ApplicationAdapter ! ");
            mInflater = LayoutInflater.from(context);
            mAppList = new ArrayList<ApplicationInfo>();
            int len = appList.size();
            ApplicationInfo app;
            mPackageManager = context.getPackageManager();
            for (int i = 0; i < len; i++) {
                app = appList.get(i);
                if (mPackageManager.getLaunchIntentForPackage(app.packageName) == null) {
                    continue;
                }
                mAppList.add(app);
            }
            mContext = context;
        }

        public int getCount() {
            return mAppList.size();
        }

        public Object getItem(int position) {
            return mAppList.get(position);
        }

        public long getItemId(int position) {
            return position;
        }

        public View getView(int position, View convertView, ViewGroup parent) {
            AppHolder holder;
            if (convertView == null) {
                convertView = mInflater.inflate(R.layout.grid_item_view, null);
                holder = new AppHolder();
                convertView.setTag(holder);
            } else {
                holder = (AppHolder) convertView.getTag();
            }
            holder.mAppIcon = (ImageView) convertView.findViewById(R.id.application_icon);
            holder.mAppName = (TextView) convertView.findViewById(R.id.application_name);
            initGridViewItem(mAppList.get(position), holder.mAppIcon, holder.mAppName);
            return convertView;
        }

        private void initGridViewItem(ApplicationInfo pInfo, ImageView img, TextView name) {
            String appName =
                    mPackageManager.getApplicationLabel(pInfo).toString();
            Drawable appIcon =
                    mPackageManager.getApplicationIcon(pInfo);
            img.setImageDrawable(appIcon);
            name.setText(appName);
//            final String packageName = pInfo.packageName;
            // name.setOnClickListener(new OnClickListener() {
            // public void onClick(View arg0) {
            // doLaunchApp(packageName);
            // }
            // });
            // img.setOnClickListener(new OnClickListener() {
            // public void onClick(View arg0) {
            // doLaunchApp(packageName);
            // }
            // });
        }

        // private void doLaunchApp(String packageName) {
        // Intent appIntent =
        // mPackageManager.getLaunchIntentForPackage(packageName);
        // Log.d("app_info", "start app from packageName : " + packageName);
        // mContext.startActivity(appIntent);
        // }

        private static class AppHolder {
            public ImageView mAppIcon;
            public TextView mAppName;
        }
    }
}

注意:上述代码中的注释部分的代码,添加后效果类似于XML文件中的android:focusable=”true” .

该部分代码主要使用到了PackageManager。PackManager.getInstalledApplications(PackageManager.COMPONENT_ENABLED_STATE_ENABLED);获取系统安装的应用程序信息。

在ApplicationAdapter的构造函数中有这么一段代码:

ApplicationInfo app;
            mPackageManager = context.getPackageManager();
            for (int i = 0; i < len; i++) {
                app = appList.get(i);
                if (mPackageManager.getLaunchIntentForPackage(app.packageName) == null) {
                    continue;
                }
                mAppList.add(app);
            }

它对初始的List做了一个简单的过滤,使得所有的图标点击后都能够进入响应的app。

下面代码加载应用的名称和图标信息:

String appName =
       mPackageManager.getApplicationLabel(pInfo).toString();
Drawable appIcon =
       mPackageManager.getApplicationIcon(pInfo);

在代码

ApplicationInfo pInfo = (ApplicationInfo) mAdapter.getItem(position);
                Intent appIntent = mPackManager.getLaunchIntentForPackage(pInfo.packageName);
                if (appIntent == null) {
                    Toast.makeText(v.getContext(), "this is not a launcher activity !...",
                            Toast.LENGTH_SHORT).show();
                    return;
                }
                appIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
                startActivity(appIntent);

中通过packageManager获取category为Launcher 的Activity的intent。 如果intent == null , 给出一个提示(系统中有些应用是没有入口activity的)。

4、在ViewData.java中添加如下内容(此部分内容可选,如有不清楚的地方参见一步一步学android控件(之一) —— 开始篇

public static final int GRID_ID = EXPANDABLE_LIST_VIEW_ID + 1;
    public static final String GRID_NAME = "GridView";
private static final ViewData mGridView = new ViewData(GRID_NAME,
            GRID_ID);
View_Datas.add(mGridView);

WidgetsAdapter的handleItemClicked中添加如下内容:

case ViewData.GRID_ID:
                intent.setClass(mContext, WidgetGridViewActivity.class);
                mContext.startActivity(intent);
                break;

以上就是GridView的全部内容,下一个控件progressBar。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/234973.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Xray基础使用介绍

    Xray基础使用介绍官方使用文档:https://docs.xray.cool/#xray简介xray是一款功能强大的安全评估工具,由多名经验丰富的一线安全从业者呕心打造而成,主要特性有:检测速度快。发包速度快;漏洞检测算法高效。支持范围广。大至OWASPTop10通用漏洞检测,小至各种CMS框架POC,均可以支持。代码质量高。编写代码的人员素质高,通过CodeReview、单元测试、集成测试等多层验证来提高代码可靠性。高级可定制。通过配置文件暴露了引擎的各种参数,通过修改配置文件可以极大的客

  • MyEclipse或Eclipse按住ctrl点击方法,提示Problems finding implementations或无法跳转的问题解决[通俗易懂]

    MyEclipse或Eclipse按住ctrl点击方法,提示Problems finding implementations或无法跳转的问题解决[通俗易懂]MyEclipse或Eclipse按住ctrl点击方法,提示Problems finding implementations或无法跳转的问题解决

  • 局域网文件传输软件[通俗易懂]

    局域网文件传输软件[通俗易懂]在公司实习了一个周,虽然很累,但也感觉有所得,此次项目是做一个局域网两台计算机之间的文件传输。我用的主要控件为winsock控件,用其TCP协议。至于用此控件连接两台计算机书上都有介绍,我主要介绍一下我传送文件的思想和方法:首先,将要传送的文件分成指定大小的N个包,大小不能超过8K因为TCP每次最多发送8K数据,最后一个包可能会小于其它包。然后在每个包加个包头,因为接收端需要通过包头知道传送过来的

  • ajax处理跨域_django跨域解决方案

    ajax处理跨域_django跨域解决方案原文:Javascript跨域和Ajax跨域解决方案 摘要:跨域请求,顾名思义,就是一个站点中的资源去访问另外一个不同域名站点上的资源。这种情况很常见,比如说通过style标签加载外部样式表文件、通过img标签加载外部图片、通过script标签加载外部脚本文件、通过Webfont加载字体文件等等。默认情况下,脚本访问文档属性等数据采用的是同源策略(Sameorigi…

  • mysql慢日志查询_mysql开启慢查询日志

    mysql慢日志查询_mysql开启慢查询日志通过命令查看慢查询最长时间,一般默认10sSHOWVARIABLESLIKE’long_query_time我们可以修改该时间,比如我在这里设置为1s,方便测试。SETlong_query_time=1通过命令SHOWVARIABLESLIKE’%query%’;可以看到,log_slow_queries默认是OFF,我们必须要打开它,SETGLOBALslow_query_l

    2022年10月14日
  • webstorm 2022 激活码(注册激活)[通俗易懂]

    (webstorm 2022 激活码)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.cn/100143.html1PA3AFINM4-eyJsaWNlbnNlSW…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号