- Android 中的 MVC 模式:
一句话概括 MVC 的原理就是:
把数据获取和界面展现分开。
这样在更换了界面或模型时可以不影响对方,利于程序的维护。
Android 中使用 MVC 模式的例子有 ListView、GridView 等列表控件。如 ListView ,控件本身充当 View,Adapter 充当 Controllor,当模型中的数据有变化时(如增加删除数据),会调用 Adapter.notifyDataSetChanged
通知控件数据变化,这时 Adapter 会调用 getView
方法去重新显示控件中的内容。
层叠布局 FrameLayout:
FrameLayout 布局中的 View 都会以层叠的方式显示,类似于 Photoshop 的图层,放在最后的 View 会显示在最上层。FrameLayout 主要用于进行层次结构的布局。例如想把两个图像叠加到一起形成一张图像的效果就可以用 FrameLayout,这种叠加方式很像 Photoshop 的图层。xmlns:
xmlns:android 是 XML 文件中的命名空间,作用是防止属性冲突,类似于 Java 中的包命名空间 package 。 xmlns:android 的值不允许任意设置,xmlns:android 的值必须以http://schemas.android.com/apk/res
开头,然后加上定义了该属性的 R.java 文件所在的包名。在 R.java 文件中包含了属性名的定义。例如:如果使用系统属性,需要指定系统 R.java 文件的位置。该文件位于 res/android 目录中,因此,xmlns:android 值的最后是 android 。dp 和 sp :
dp 是密度无关像素的意思,也被称作 dip,和 px 相比,它在不同密度的屏幕中的显示比例将保持一致。sp 是可伸缩像素的意思,它采用了和 dp 同样的设计理念,解决了文字大小的适配问题。
什么叫密度? Android 中的密度就是屏幕每英寸所包含的像素数,通常以 dpi 为单位。比如一个手机屏幕的宽是 2 英寸长是 3 英寸,如果它的分辨率是 320480 像素,那这个屏幕的密度就是 160dpi,如果它的分辨率是 640960,那这个屏幕的密度就是320dpi。
根据 Android 的规定,在 160dpi 的屏幕上, 1dp 等于 1px,而在 320dpi 的屏幕上, 1dp就等于 2px。因此,使用 dp 来指定控件的宽和高,就可以保证控件在不同密度的屏幕中的显示比例保持一致。layout_gravity 和 gravity 的区别:
layout_gravity 指定了当前 View 在父 View 中的位置, 而 gravity 则指定了 View 中内容(文字、图像、子 View )的位置。
可以联想 layout_margin 和 padding 记忆,有 layout 前缀的都表示相对于父 View 的属性LinearLayout 中子元素的 gravity 属性:
这段代码中 TextView 不能完全居中,只会在竖直方向中居中。因为并不是所有的属性值在任何条件下都会起作用,layout_gravity 会受 LinearLayout orientation 属性的影响,例如在当 View 在水平线性布局时,layout_gravity 只有在竖直方向上的值才会起作用, 如 vertical_center。
要使 TextView 居中的话有两种解决方案:
- 使用 FrameLayout
- 在 LinearLayout 中添加属性 android:gravity="center", 不过会使所有子 View 都 会受影响。
- TextView 设置跳转链接:
TextView tv_link = (TextView) findViewById(R.id.tv_link);
String text = "跳到MainActivity";
SpannableString spanStr = new SpannableString(text);
spanStr.setSpan(new ClickableSpan() {
@Override
public void onClick(View widget) {
startActivity(new Intent(TestWeightActivity.this, MainActivity.class));
}
}, 0, text.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
tv_link.setText(spanStr);
//在单击链接时凡是有要执行的动作,都必须设置 LinkMovementMethod 对象
tv_link.setMovementMethod(LinkMovementMethod.getInstance());
-
判断某一应用是否已安装:
方法一:
public static boolean isWeixinAvilible(Context context) {
PackageManager packageManager = context.getPackageManager();// 获取packagemanager
List pinfo = packageManager.getInstalledPackages(0);// 获取所有已安装程序的包信息
if (pinfo != null) {
for (int i = 0; i < pinfo.size(); i++) {
String pn = pinfo.get(i).packageName;
if (pn.equals("com.tencent.mm")) {
return true;
}
}
}
return false;
}
方法二:
首先得到该程序的包名
这个连上手机 ADB,看 logcat 就能看到。比如:QQ 客户端的包名是 com.tencent.mobileqq 。然后通过 PackageManager 判断是否存在该包的程序
private boolean isAppInstalled(String pkgName) {
PackageInfo packageInfo = null;
try {
packageInfo = this.getPackageManager().getPackageInfo(pkgName, 0);
} catch (NameNotFoundException e) {
packageInfo = null;
}
return packageInfo != null;
}
- 跳转到手机应用市场
//跳到应用市场搜索页面
Uri uri = Uri.parse("market://search?q=QQ");
//跳转到应用市场某app的详情页
Uri uri = Uri.parse("market://details?id=com.tencent.mobileqq"); // id 为应用的 packageName
Intent intent = new Intent(Intent.ACTION_VIEW, uri);
startActivity(intent);
- Activity 跳转动画:
要先在 res/anim 目录下新建两个动画文件
startActivity(new Intent(this, Activity2.class));
overridePendingTransition(R.anim.fade_in, R.anim.fade_out);
- 自定义 Toast:
private void showMyToast() {
Toast mToast = new Toast(this);
View view = LayoutInflater.from(this).inflate(R.layout.layout_toast, null);
TextView tv_content = (TextView) view.findViewById(R.id.tv_toast_content);
tv_content.setText("hahahah~");
mToast.setView(view); //设置视图
mToast.setDuration(Toast.LENGTH_SHORT);
mToast.show();
}
- Toast 中的 makeText
Toast mToast = new Toast(this);
mToast.setText("222");
mToast.show();
这段代码会抛出找不到 TextView 的异常,只有通过 makeText 方法创建的Toast才会能使用 setText 方法,
因为 makeText 方法会创建一个带 TextView 的 View , 而直接new出来的 Toast 没有。