1. 相关文件夹介绍css
在Android项目文件夹里面,主要的资源文件是放在res文件夹里面的。assets文件夹是存放不进行编译加工的原生文件,即该文件夹里面的文件不会像xml,java文件被预编译,能够存放一些图片,html,js, css等文件。在后面会介绍如何读取assets文件夹的资源!html
res文件夹里面的多个文件夹的各自介绍(来自网上的Android开发指南中文版内容):java
目录Directoryandroid |
资源类型Resource Types数组 |
res/anim/app |
XML文件,它们被编译进逐帧动画(frame by frame animation)或补间动画(tweened animation)对象ide |
res/drawable/函数 |
.png、.9.png、.jpg文件,它们被编译进如下的Drawable资源子类型中:工具 要得到这种类型的一个资源,可使用Resource.getDrawable(id)布局 为了获取资源类型,使用mContext.getResources().getDrawable(R.drawable.imageId) 注意:放在这里的图像资源可能会被aapt工 具自动地进行无损压缩优化。好比,一个真彩色但并不须要256色的PNG可能会被转换为一个带调色板的8位PNG。这使得同等质量的图片占用更少的资源。 因此咱们得意识到这些放在该目录下的二进制图像在生成时可能会发生变化。若是你想读取一个图像位流并转换成一个位图(bitmap),请把图像文件放在 res/raw/目录下,这样能够避免被自动优化。 |
res/layout/ |
被编译为屏幕布局(或屏幕的一部分)的XML文件。参见布局声明(Declaring Layout) |
res/values/ |
能够被编译成不少种类型的资源的XML文件。 注意: 不像其余的res/文件夹,它能够保存任意数量的文件,这些文件保存了要建立资源的描述,而不是资源自己。XML元素类型控制这些资源应该放在R类的什么地方。 尽管这个文件夹里的文件能够任意命名,不过下面使一些比较典型的文件(文件命名的惯例是将元素类型包含在该名称之中): array.xml 定义数组 colors.xml 定义color drawable和颜色的字符串值(color string values)。使用Resource.getDrawable()和Resources.getColor()分别得到这些资源。 dimens.xml定义尺寸值(dimension value)。使用Resources.getDimension()得到这些资源。 strings.xml定义字符串(string)值。使用Resources.getString()或者Resources.getText()获取这些资源。getText()会保留在UI字符串上应用的丰富的文本样式。 styles.xml 定义样式(style)对象。 |
res/xml/ |
任意的XML文件,在运行时能够经过调用Resources.getXML()读取。 |
res/raw/ |
直接复制到设备中的任意文件。它们无需编译,添加到你的应用程序编译产生的压缩文件中。要使用这些资源,能够调用Resources.openRawResource(),参数是资源的ID,即R.raw.somefilename。 |
在项目文件夹的gen文件夹里面有个R.java,咱们日常引用的资源主要引用这个类的变量。
注意:R类是自动生成的,而且它不能被手动修改。当资源发生变更时,它会自动修改。
下面是一个引用资源的语法:
R.resource_type.resource_name 或者 android.R.resource_type.resource_name
其中resource_type是R的子类,保存资源的一个特定类型。resource_name是在XML文件定义的资源的name属性,或者有其余文件类型为资源定义的文件名(不包含扩展名,这指的是drawable文件夹里面的icon.png相似的文件,name=icon)。 Android包含了不少标准资源,如屏幕样式和按钮背景。要在代码中引用这些资源,你必须使用android进行限定,如android.R.drawable.button_background。
下面是官方给出的一些在代码中使用已编译资源的正确和错误用法的例子:
// Load a background for the current screen from a drawable resource. this.getWindow().setBackgroundDrawableResource(R.drawable.my_background_image); // WRONG Sending a string resource reference into a // method that expects a string. this.getWindow().setTitle(R.string.main_title); // RIGHT Need to get the title from the Resources wrapper. this.getWindow().setTitle(Resources.getText(R.string.main_title)); // Load a custom layout for the current screen. setContentView(R.layout.main_screen); // Set a slide in animation for a ViewFlipper object. mFlipper.setInAnimation(AnimationUtils.loadAnimation(this, R.anim.hyperspace_in)); // Set the text on a TextView object. TextView msgTextView = (TextView)findViewByID(R.id.msg); msgTextView.setText(R.string.hello_message);
查了SDK Doc,才明白为何window.setTitle要先Resources.getText,原来setTitle的参数是 CharSequence,Resources.getText(int)返回的是CharSequence;而其余setText的参数有的是 CharSequence,有的是int(这就是Resources变量值)。
同时官方还给了两个使用系统资源的例子:
//在屏幕上显示标准应用程序的图标 public class MyActivity extends Activity { public void onStart() { requestScreenFeatures(FEATURE_BADGE_IMAGE); super.onStart(); setBadgeResource(android.R.drawable.sym_def_app_icon); } } //应用系统定义的标准"绿色背景"视觉处理 public class MyActivity extends Activity public void onStart() { super.onStart(); setTheme(android.R.style.Theme_Black); } }
1) 引用自定义的资源
android:text="@string/hello"
这里使用"@"前缀引入对一个资源的引用--在@[package:]type/name形式中后面的文本是资源的名称。在这种状况下,咱们不须要指定包名,由于咱们引用的是咱们本身包中的资源。type是xml子节点名,name是xml属性名:
<?xml version="1.0" encoding="utf-8"?> <resources> <string name="hello">Hello World, HelloDemo!</string> </resources>
2) 引用系统资源
android:textColor="@android :color/opaque_red" 指定package: android
3) 引用主题属性
另一种资源值容许你引用当前主题中的属性的值。这个属性值只能在样式资源和XML属性中使用;它容许你经过将它们改变为当前主题提供的标准变化来改变UI元素的外观,而不是提供具体的值。
android:textColor="?android:textDisabledColor"
注意,这和资源引用很是相似,除了咱们使用一个"?"前缀代替了"@"。当你使用这个标记时,你就提供了属性资源的名称,它将会在主题中被查 找--由于资源工具知道须要的属性资源,因此你不须要显示声明这个类型(若是声明,其形式就 是?android:attr/android:textDisabledColor)。除了使用这个资源的标识符来查询主题中的值代替原始的资源,其命 名语法和"@"形式一致:?[namespace:]type/name,这里类型可选。
我的理解这个替换资源主要用于适应多种规格的屏幕,以及国际化。对于这部分的内容,请参考http://androidappdocs.appspot.com/guide/topics/resources/resources-i18n.html,之后再研究!
语法:
<color
name="color_name">#color_value</color>
能够保存在res/values/colors.xml (文件名能够任意)。
xml引用:android:textColor="@color/color_name"
Java引用: int color = Resources.getColor(R.color.color_name)
其中#color_value有如下格式(A表明Alpha通道):
#RGB
#ARGB
#RRGGBB
#AARRGGBB
xml示例(声明两个颜色,第一个不透明,第二个透明色):
<?xml version="1.0" encoding="utf-8"?> <resources> <color name="opaque_red">#f00</color> <color name="translucent_red">#80ff0000</color> </resources>
语法:
<drawable
name="color_name">color_value</drawable>
能够保存在res/values/colors.xml。
xml引用:android:background="@drawable/color_name"
java引用:Drawable redDrawable = Resources.getDrawable(R.drawable.color_name)
color_name和上面的同样。我的认为,通常状况下使用color属性,当须要用到paintDrawable时才使用drawable属性。
xml示例:
<?xml version="1.0" encoding="utf-8"?> <resources> <drawable name="opaque_red">#f00</drawable> <drawable name="translucent_red">#80ff0000</drawable> </resources>
通常放在res/drawable/里面。官方提示png (preferred), jpg (acceptable), gif (discouraged),看来通常使用png格式比较好!
xml引用 @[package:]drawable/some_file
java引用 R.drawable.some_file 引用是不带扩展名
语法:
<dimen
name="dimen_name">dimen_value单位</dimen>
通常保存为res/values/dimen.xml。
度量单位:
px(象素): 屏幕实际的象素,常说的分辨率1024*768pixels,就是横向1024px, 纵向768px,不一样设备显示效果相同。
in(英寸): 屏幕的物理尺寸, 每英寸等于2.54厘米。
mm(毫米): 屏幕的物理尺寸。
pt(点) : 屏幕的物理尺寸。1/72英寸。
dp/dip : 与密度无关的象素,一种基于屏幕密度的抽象单位。在每英寸160点的显示器上,1dp = 1px。但dp和px的比例会随着屏幕密度的变化而改变,不一样设备有不一样的显示效果。
sp : 与刻度无关的象素,主要用于字体显示best for textsize,做为和文字相关大小单位。
XML: android:textSize="@dimen/some_name"
Java: float dimen = Resources.getDimen(R.dimen.some_name)
xml示例:
<?xml version="1.0" encoding="utf-8"?> <resources> <dimen name="one_pixel">1px</dimen> <dimen name="double_density">2dp</dimen> <dimen name="sixteen_sp">16sp</dimen> </resources>
下面是官方给出的正确/错误的例子:
//不使用转义符则须要用双引号包住整个string <string name="good_example">"This'll work"</string> //使用转义符 <string name="good_example_2">This\'ll also work</string> //错误 <string name="bad_example">This won't work!</string> //错误 不可以使用html转义字符 <string name="bad_example_2">XML encodings won't work either!</string>
对于带格式的string,例如在字符串中某些文字设置颜色,可使用html标签。对于这类型的string,须要进行某些处理,在xml里面不能够被其余资源引用。官方给了一个例子来对比普通string和带格式string的使用:
<?xml version="1.0" encoding="utf-8"?> <resources> <string name="simple_welcome_message">Welcome!</string> <string name="styled_welcome_message">We are <b><i>so</i></b> glad to see you.</string> </resources>
Xml代码
<TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:textAlign="center" android:text="@string/simple_welcome_message"/>
Java代码
// Assign a styled string resource to a TextView on the current screen. CharSequence str = getString(R.string.styled_welcome_message); TextView tv = (TextView)findViewByID(R.id.text); tv.setText(str);
另外对于带风格/格式的string的处理,就麻烦一点点。官方给了一个例子:
<?xml version="1.0" encoding="utf-8"?> <resources> <string name="search_results_resultsTextFormat">%1$d results for <b>&quot;%2$s&quot;</b></string> </resources>
这里的%1$d是个十进制数字,%2$s是字符串。当咱们把某个字符串赋值给%2$s以前,须要用htmlEncode(String)函数处理那个字符串:
//title是咱们想赋值给%2$s的字符串 String escapedTitle = TextUtil.htmlEncode(title);
而后用String.format() 来实现赋值,接着用fromHtml(String) 获得格式化后的string:
String resultsTextFormat = getContext().getResources().getString(R.string.search_results_resultsTextFormat); String resultsText = String.format(resultsTextFormat, count, escapedTitle); CharSequence styledResults = Html.fromHtml(resultsText);
assets文件夹里面的文件都是保持原始的文件格式,须要用AssetManager以字节流的形式读取文件。
1. 先在Activity里面调用getAssets()来获取AssetManager引用。
2. 再用AssetManager的open(String fileName, int accessMode)方法则指定读取的文件以及访问模式就能获得输入流InputStream。
3. 而后就是用已经open file 的inputStream读取文件,读取完成后记得inputStream.close()。
4.调用AssetManager.close()关闭AssetManager。
须要注意的是,来自Resources和Assets 中的文件只能够读取而不能进行写的操做
如下为从Raw文件中读取:
public String getFromRaw(){ try { InputStreamReader inputReader = new InputStreamReader( getResources().openRawResource(R.raw.test1)); BufferedReader bufReader = new BufferedReader(inputReader); String line=""; String Result=""; while((line = bufReader.readLine()) != null) Result += line; return Result; } catch (Exception e) { e.printStackTrace(); } }
如下为直接从assets读取
public String getFromAssets(String fileName){ try { InputStreamReader inputReader = new InputStreamReader( getResources().getAssets().open(fileName) ); BufferedReader bufReader = new BufferedReader(inputReader); String line=""; String Result=""; while((line = bufReader.readLine()) != null) Result += line; return Result; } catch (Exception e) { e.printStackTrace(); } }
固然若是你要获得内存流的话也能够直接返回内存流!