zoukankan      html  css  js  c++  java
  • 使用getIdentifier()获取资源Id (根据Id的名字直接定位取到资源)

    使用getIdentifier()方法可以方便的获各应用包下的指定资源ID。
    主要有两种方法:
    (1)方式一
    Resources resources = context.getResources();
    int indentify = resources.getIdentifier(org.loveandroid.androidtest:drawable/icon",null,null);
    if(indentify>0){
    icon = resources.getDrawable(indentify);
    } = resources.getDrawable(indentify);
    }

    1. 第一个参数格式是:包名 + : + 资源文件夹名 + / +资源名;是这种格式 然后其他的可以为null 


    (2)方式二
    Resources resources = context.getResources();
    int indentify= getResources().getIdentifier("icon""drawable""org.anddev.android.testproject");

    1. 第一个参数为ID名,第二个为资源属性是ID或者是Drawable,第三个为包名。  


    如果找到了,返回资源Id,如果找不到,返回0 。

    写了一个方法:获取资源ID,如果不存在返回0
    static int getResourceId(Context context,String name,String type,String packageName){
            Resources themeResources=null;
            PackageManager pm=context.getPackageManager();
            try {
                themeResources=pm.getResourcesForApplication(packageName);
                return themeResources.getIdentifier(name, type, packageName);
            } catch (NameNotFoundException e) {

                e.printStackTrace();
            }
            return 0;
     }

    从数据库里读取图片名称,然后调用图片。直接用R.drawable.?无法调用。查了好多地方最后找到了个方法,分享给大家,希望有帮助。
    主要由两种方法,个人建议第二种。
    1. 不把图片放在res/drawable下,而是存放在src某个package中(如:com.drawable.resource),这种情况下的调用方法为:
    String path = "com/drawable/resource/imageName.png";
    InputStream is = getClassLoader().getResourceAsStream(path);
    Drawable.createFromStream(is, "src");

    2. 如果还是希望直接使用res/drawable中的图片,就需要通过下面的方法了:
    假设创建工程的时候,填写的package名字为:com.test.image
    int resID = getResources().getIdentifier("imageName", "drawable", "com.test.image");
    Drawable image = getResources().getDrawable(resID);

    转 : http://blog.sina.com.cn/s/blog_5da93c8f0100zlrx.html

  • 相关阅读:
    拓扑排序模板
    杭电 2066 一个人的旅行
    杭电 1596 find the safest road (最小路径变形求最大安全度)
    【状态压缩DP】【BZOJ1087】【SCOI2005】互不侵犯king
    【bzoj1001】【最短路】【对偶图】【最大流转最小割】狼抓兔子题解
    [BZOJ1179][APIO2009][强连通分量Tarjan+spfa]ATM
    [BZOJ1194][HNOI2006][强连通分量Tarjan+dfs]潘多拉的盒子
    说一说ST表 讲一讲水题
    【强连通分量】tarjan算法及kosaraju算法+例题
    对拍程序讲解及源码举例
  • 原文地址:https://www.cnblogs.com/622698abc/p/3415192.html
Copyright © 2011-2022 走看看