android tv box launcher开发之添加自定义apk

在开发launcher中通常有这个需求就是在主界面上预留空白控件,可以让用户从apps中自己选择apk放入。
1.   点击空白控件跳转到选择apk的布局中,所以我们需要写一个布局用来存放所有的apk,这里我使用的是activity,当然也可以用framlayout。
public class Test extends Activity implements AdapterView.OnItemClickListener{
   
   
    private GridView gv;
    private final static String TAG = "Test";
    private final static String NAME = "item_name";
    private final static String ICON = "item_icon";
    private final static String SELECTION = "item_selection";
    private final static String BACKGROUND = "item_background";
    private final static String COMPONENT_NAME = "component name";

    private final static int duration = 300;

    private ImageView img_screen_shot = null;
    private ImageView img_screen_shot_keep = null;
    private ImageView img_dim = null;

    private CustomView thisView = null;
    private Context mContext = null;

    private String[] list_custom_apps;
    private String str_custom_apps;
    private Drawable bitmap;
    private String str_name; 

    private int transY = 0;
    private int homeShortcutCount;

    final static Object mLock = new Object[0];
    private View mSource;
    private int mMode = -1;
    private int mPos = -1;
    private int resultCode = 3;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_custom_apps);
    mContext = Launcher.context;
        mMode = 4;
    gv =(GridView) findViewById(R.id.grid_add_apps);
        gv.setOnItemClickListener(this);
    displayView();
    }

    @Override
    protected void onPause() {
    super.onPause();
    }

    @Override
    protected void onStop() {
    Log.d(TAG,"onStop---------------onStop");
        super.onStop();
    }

    @Override
    protected void onDestroy() {
    Log.d(TAG,"onDestroy---------------onDestroy"+str_custom_apps);
        super.onDestroy();
    }
    /*
    * press down key sendBroadcast back launcher.java and send packageName
    */
    public boolean dispatchKeyEvent (KeyEvent event) {
        if (event.getAction() == KeyEvent.ACTION_DOWN) {
            switch (event.getKeyCode()) {
                case KeyEvent.KEYCODE_BACK:
                    Intent intent = new Intent();
            intent.putExtra("pkg",str_custom_apps);
                intent.setAction("com.ff.pkg");
                this.sendBroadcast(intent);
                    Log.d(TAG, "KeyEvent.KEYCODE_BACK............");
                    break;
            }
        }

        return super.dispatchKeyEvent(event);
    }

/*
*      list_current Have been selected apk
*      item_img_unsel  status img
*      
*/
    private  List<ArrayMap<String, Object>> getAppList() {
        List<ArrayMap<String, Object>> list = new ArrayList<ArrayMap<String, Object>>();
        List<ArrayMap<String, Object>> list_all = ((Launcher)mContext).getAppDataLoader().getShortcutList(Launcher.MODE_APP);
        List<ArrayMap<String, Object>> list_current = ((Launcher)mContext).getAppDataLoader().getShortcutList(mMode);
        homeShortcutCount = 0;

        for (int i = 0; i < list_all.size(); i++) {
            ArrayMap<String, Object> map = new ArrayMap<String, Object>();
            map.put(SELECTION, R.drawable.item_img_unsel);
            for (int j = 0; j < list_current.size() - 1; j++) {
                if (TextUtils.equals(list_all.get(i).get(AppDataLoader.COMPONENT_NAME).toString(),
                        list_current.get(j).get(AppDataLoader.COMPONENT_NAME).toString())) {
                        map.put(SELECTION, R.drawable.item_img_unsel);
                    if (mMode == Launcher.MODE_HOME) {
                        homeShortcutCount++;
                    }
                    break;
                }
            }
            map.put(NAME, list_all.get(i).get(AppDataLoader.NAME));
            map.put(ICON, list_all.get(i).get(AppDataLoader.ICON));
            map.put(BACKGROUND, R.drawable.item_child_6);
            map.put(COMPONENT_NAME, list_all.get(i).get(AppDataLoader.COMPONENT_NAME));
            list.add(map);
        }

        return list;
    }

    private void displayView() {
        LocalAdapter ad = new LocalAdapter(mContext,
                getAppList(),
                R.layout.add_apps_grid_item,
                new String[] {ICON, NAME, SELECTION, BACKGROUND},
                new int[] {R.id.item_type, R.id.item_name, R.id.item_sel, R.id.relative_layout});
        gv.setAdapter(ad);
    }

    private void updateView() {
        ((BaseAdapter)gv.getAdapter()).notifyDataSetChanged();
    }


    @Override
    public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
    ArrayMap<String, Object> it
ROM Toolbox Pro ROM Toolbox是任何有根用户的MUST HAVE应用程序。 ROM Toolbox将Titanium Backup,ROM Manager,Root Explorer,SetCPU,MetaMorph,Autorun Manager,终端仿真器,脚本管理器,SD Booster,BuildProp编辑器,字体安装程序,引导动画安装程序和更多应用程序等应用程序整合到一体机中应用程序!以下是您将找到的一些功能列表: ★ROM管理★ ☆从越来越多的ROM中安装ROM和主题。包括AOKP,CyanogenMod和其他流行的ROM。 ☆创建,管理和恢复nandroid备份 ☆擦除数据,缓存,dalvik缓存,电池统计 ☆从SD卡安装多个ROM和ZIP ★应用程序管理器★ ☆批量备份和恢复应用程序及其数据 ☆安排备份在特定时间运行 ☆从nandroid备份恢复应用程序 ☆备份/恢复文本消息,书签,帐户等。 ☆备份您的应用程序到Dropbox ☆冻结/除霜系统和用户应用程序 ☆备份/恢复Android市场链接 ☆任务管理器 ☆自动批量卸载 ☆通过电子邮件将您的应用程序发送给朋友 ☆将任何用户应用程序移动到SD卡 ☆清理dalvik-cache ☆Zipalign,修复权限,擦除数据和缓存,强制关闭任何应用程序 ★Root Explorer★ ☆访问整个android的文件系统(包括难以捉摸的数据文件夹!)。 ☆批量复制/粘贴,压缩,焦油,删除,移动任何文件或文件夹 ☆更改文件权限和所有权 ☆查看,编辑和共享文件 ☆文件管理器与两个面板,以便于管理 ★Scripter和终端仿真器★ ☆以root身份创建和运行脚本 ☆将脚本设置为在启动时运行 ★自动启动管理器★ ☆启用/禁用启动时运行的应用程序 ☆启用/禁用任何广播接收器,活动或服务 ★重启★ 重启恢复,掉电,引导程序等 ★字体安装程序★ ☆从巨大的列表或从您的SD卡安装自定义字体 ☆将字体设置为收藏夹并将其发送给朋友 ★启动动画安装程序★ ☆从巨大的集合或从你的SD卡安装自定义启动动画 ☆预览启动动画 ☆从GIF文件创建启动动画 ☆每次启动时都有一个新的随机启动动画! ★主题管理器和状态栏图标转换器★ ☆创建和安装完整主题 ☆通过安装wifi,信号,GPS等自定义图标自定义您的状态栏。 ☆将状态栏中的电池图标从200列表中更改为自定义图标+ ★Boot Logo Changer★ ☆更改支持手机的启动徽标 ★主题选择主题★ ☆查看TMobile主题选择器的主题列表 ★设置CPU★ ☆SetCPU和缩放调速器 ☆CPU配置文件 ☆内核调整,以加快性能 ★Build.prop Editor★ ☆轻松编辑你的build.prop ☆改变lcd密度,提高电池寿命,提高性能 ★自动内存管理器★ ☆设置minfree值并从预设中选择。在引导时应用值 ★SD助推器★ ☆提高SD卡的速度
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值