36个Android开发常用代码片段
//36个Android开发常用代码片段
//拨打电话
public static void call(Context context, String phoneNumber) { context.startActivity( new Intent(Intent.ACTION_CALL, Uri.parse( "tel:" + phoneNumber))); } //跳转至拨号界面
public static void callDial(Context context, String phoneNumber) { context.startActivity( new Intent(Intent.ACTION_DIAL, Uri.parse( "tel:" + phoneNumber))); } //发送短信
public static void sendSms(Context context, String phoneNumber, String content) { Uri uri = Uri.parse( "smsto:" + (TextUtils.isEmpty(phoneNumber) ? "" : phoneNumber)); Intent intent = new Intent(Intent.ACTION_SENDTO, uri); intent.putExtra( "sms_body" , TextUtils.isEmpty(content) ? "" : content); context.startActivity(intent); } //唤醒屏幕并解锁
public static void wakeUpAndUnlock(Context context){ KeyguardManager km= (KeyguardManager) context.getSystemService(Context.KEYGUARD_SERVICE); KeyguardManager.KeyguardLock kl = km.newKeyguardLock( "unLock" ); //解锁 kl.disableKeyguard(); //获取电源管理器对象 PowerManager pm=(PowerManager) context.getSystemService(Context.POWER_SERVICE); //获取PowerManager.WakeLock对象,后面的参数|表示同时传入两个值,最后的是LogCat里用的Tag PowerManager.WakeLock wl = pm.newWakeLock(PowerManager.ACQUIRE_CAUSES_WAKEUP | PowerManager.SCREEN_DIM_WAKE_LOCK, "bright" ); //点亮屏幕 wl.acquire(); //释放 wl.release(); } //需要添加权限 <uses-permission android:name= "android.permission.WAKE_LOCK" /> <uses-permission android:name= "android.permission.DISABLE_KEYGUARD" /> //判断当前App处于前台还是后台状态
public static boolean isApplicationBackground( final Context context) { ActivityManager am = (ActivityManager) context .getSystemService(Context.ACTIVITY_SERVICE); @SuppressWarnings ( "deprecation" ) List<ActivityManager.RunningTaskInfo> tasks = am.getRunningTasks( 1 ); if (!tasks.isEmpty()) { ComponentName topActivity = tasks.get( 0 ).topActivity; if (!topActivity.getPackageName().equals(context.getPackageName())) { return true ; } } return false ; } //需要添加权限 <uses-permission android:name= "android.permission.GET_TASKS" /> //判断当前手机是否处于锁屏(睡眠)状态
public static boolean isSleeping(Context context) { KeyguardManager kgMgr = (KeyguardManager) context .getSystemService(Context.KEYGUARD_SERVICE); boolean isSleeping = kgMgr.inKeyguardRestrictedInputMode(); return isSleeping; } //判断当前是否有网络连接
public static boolean isOnline(Context context) { ConnectivityManager manager = (ConnectivityManager) context .getSystemService(Activity.CONNECTIVITY_SERVICE); NetworkInfo info = manager.getActiveNetworkInfo(); if (info != null && info.isConnected()) { return true ; } return false ; } //判断当前是否是WIFI连接状态
public static boolean isWifiConnected(Context context) { ConnectivityManager connectivityManager = (ConnectivityManager) context .getSystemService(Context.CONNECTIVITY_SERVICE); NetworkInfo wifiNetworkInfo = connectivityManager .getNetworkInfo(ConnectivityManager.TYPE_WIFI); if (wifiNetworkInfo.isConnected()) { return true ; } return false ; } //安装APK
public static void installApk(Context context, File file) { Intent intent = new Intent(); intent.setAction( "android.intent.action.VIEW" ); intent.addCategory( "android.intent.category.DEFAULT" ); intent.setType( "application/vnd.android.package-archive" ); intent.setDataAndType(Uri.fromFile(file), "application/vnd.android.package-archive" ); intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); context.startActivity(intent); } //判断当前设备是否为手机
public static boolean isPhone(Context context) { TelephonyManager telephony = (TelephonyManager) context .getSystemService(Context.TELEPHONY_SERVICE); if (telephony.getPhoneType() == TelephonyManager.PHONE_TYPE_NONE) { return false ; } else { return true ; } } //获取当前设备宽高,单位px
@SuppressWarnings ( "deprecation" ) public static int getDeviceWidth(Context context) { WindowManager manager = (WindowManager) context .getSystemService(Context.WINDOW_SERVICE); return manager.getDefaultDisplay().getWidth(); } @SuppressWarnings ( "deprecation" ) public static int getDeviceHeight(Context context) { WindowManager manager = (WindowManager) context .getSystemService(Context.WINDOW_SERVICE); return manager.getDefaultDisplay().getHeight(); } //获取当前设备的IMEI,需要与上面的isPhone()一起使用
@TargetApi (Build.VERSION_CODES.CUPCAKE) public static String getDeviceIMEI(Context context) { String deviceId; if (isPhone(context)) { TelephonyManager telephony = (TelephonyManager) context .getSystemService(Context.TELEPHONY_SERVICE); deviceId = telephony.getDeviceId(); } else { deviceId = Settings.Secure.getString(context.getContentResolver(), Settings.Secure.ANDROID_ID); } return deviceId; } //获取当前设备的MAC地址
public static String getMacAddress(Context context) { String macAddress; WifiManager wifi = (WifiManager) context .getSystemService(Context.WIFI_SERVICE); WifiInfo info = wifi.getConnectionInfo(); macAddress = info.getMacAddress(); if ( null == macAddress) { return "" ; } macAddress = macAddress.replace( ":" , "" ); return macAddress; } //获取当前程序的版本号
public static String getAppVersion(Context context) { String version = "0" ; try { version = context.getPackageManager().getPackageInfo( context.getPackageName(), 0 ).versionName; } catch (PackageManager.NameNotFoundException e) { e.printStackTrace(); } return version; } //收集设备信息,用于信息统计分析
public static Properties collectDeviceInfo(Context context) { Properties mDeviceCrashInfo = new Properties(); try { PackageManager pm = context.getPackageManager(); PackageInfo pi = pm.getPackageInfo(context.getPackageName(), PackageManager.GET_ACTIVITIES); if (pi != null ) { mDeviceCrashInfo.put(VERSION_NAME, pi.versionName == null ? "not set" : pi.versionName); mDeviceCrashInfo.put(VERSION_CODE, pi.versionCode); } } catch (PackageManager.NameNotFoundException e) { Log.e(TAG, "Error while collect package info" , e); } Field[] fields = Build. class .getDeclaredFields(); for (Field field : fields) { try { field.setAccessible( true ); mDeviceCrashInfo.put(field.getName(), field.get( null )); } catch (Exception e) { Log.e(TAG, "Error while collect crash info" , e); } } return mDeviceCrashInfo; } public static String collectDeviceInfoStr(Context context) { Properties prop = collectDeviceInfo(context); Set deviceInfos = prop.keySet(); StringBuilder deviceInfoStr = new StringBuilder( "{\n" ); for (Iterator iter = deviceInfos.iterator(); iter.hasNext();) { Object item = iter.next(); deviceInfoStr.append( "\t\t\t" + item + ":" + prop.get(item) + ", \n" ); } deviceInfoStr.append( "}" ); return deviceInfoStr.toString(); } //是否有SD卡
public static boolean haveSDCard() { return android.os.Environment.getExternalStorageState().equals( android.os.Environment.MEDIA_MOUNTED); } //动态隐藏软键盘
@TargetApi (Build.VERSION_CODES.CUPCAKE) public static void hideSoftInput(Activity activity) { View view = activity.getWindow().peekDecorView(); if (view != null ) { InputMethodManager inputmanger = (InputMethodManager) activity .getSystemService(Context.INPUT_METHOD_SERVICE); inputmanger.hideSoftInputFromWindow(view.getWindowToken(), 0 ); } } @TargetApi (Build.VERSION_CODES.CUPCAKE) public static void hideSoftInput(Context context, EditText edit) { edit.clearFocus(); InputMethodManager inputmanger = (InputMethodManager) context .getSystemService(Context.INPUT_METHOD_SERVICE); inputmanger.hideSoftInputFromWindow(edit.getWindowToken(), 0 ); } //动态显示软键盘
@TargetApi (Build.VERSION_CODES.CUPCAKE) public static void showSoftInput(Context context, EditText edit) { edit.setFocusable( true ); edit.setFocusableInTouchMode( true ); edit.requestFocus(); InputMethodManager inputManager = (InputMethodManager) context .getSystemService(Context.INPUT_METHOD_SERVICE); inputManager.showSoftInput(edit, 0 ); } //动态显示或者是隐藏软键盘
@TargetApi (Build.VERSION_CODES.CUPCAKE) public static void toggleSoftInput(Context context, EditText edit) { edit.setFocusable( true ); edit.setFocusableInTouchMode( true ); edit.requestFocus(); InputMethodManager inputManager = (InputMethodManager) context .getSystemService(Context.INPUT_METHOD_SERVICE); inputManager.toggleSoftInput(InputMethodManager.SHOW_FORCED, 0 ); } //主动回到Home,后台运行
public static void goHome(Context context) { Intent mHomeIntent = new Intent(Intent.ACTION_MAIN); mHomeIntent.addCategory(Intent.CATEGORY_HOME); mHomeIntent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED); context.startActivity(mHomeIntent); } //获取状态栏高度
//注意,要在onWindowFocusChanged中调用,在onCreate中获取高度为0 @TargetApi (Build.VERSION_CODES.CUPCAKE) public static int getStatusBarHeight(Activity activity) { Rect frame = new Rect(); activity.getWindow().getDecorView().getWindowVisibleDisplayFrame(frame); return frame.top; } //获取状态栏高度+标题栏(ActionBar)高度
//(注意,如果没有ActionBar,那么获取的高度将和上面的是一样的,只有状态栏的高度) public static int getTopBarHeight(Activity activity) { return activity.getWindow().findViewById(Window.ID_ANDROID_CONTENT) .getTop(); } //获取MCC+MNC代码 (SIM卡运营商国家代码和运营商网络代码)
//仅当用户已在网络注册时有效, CDMA 可能会无效(中国移动:46000 //46002, 中国联通:46001,中国电信:46003) public static String getNetworkOperator(Context context) { TelephonyManager telephonyManager = (TelephonyManager) context .getSystemService(Context.TELEPHONY_SERVICE); return telephonyManager.getNetworkOperator(); } //返回移动网络运营商的名字
//(例:中国联通、中国移动、中国电信) 仅当用户已在网络注册时有效, //CDMA 可能会无效) public static String getNetworkOperatorName(Context context) { TelephonyManager telephonyManager = (TelephonyManager) context .getSystemService(Context.TELEPHONY_SERVICE); return telephonyManager.getNetworkOperatorName(); } //返回移动终端类型
PHONE_TYPE_NONE :0 手机制式未知
PHONE_TYPE_GSM :1 手机制式为GSM,移动和联通
PHONE_TYPE_CDMA :2 手机制式为CDMA,电信
PHONE_TYPE_SIP:3
public static int getPhoneType(Context context) { TelephonyManager telephonyManager = (TelephonyManager) context .getSystemService(Context.TELEPHONY_SERVICE); return telephonyManager.getPhoneType(); } //判断手机连接的网络类型(2G,3G,4G)
//联通的3G为UMTS或HSDPA,移动和联通的2G为GPRS或EGDE,电信的2G为CDMA,电信的3G为EVDO public class Constants { /** * Unknown network class */ public static final int NETWORK_CLASS_UNKNOWN = 0 ; /** * wifi net work */ public static final int NETWORK_WIFI = 1 ; /** * "2G" networks */ public static final int NETWORK_CLASS_2_G = 2 ; /** * "3G" networks */ public static final int NETWORK_CLASS_3_G = 3 ; /** * "4G" networks */ public static final int NETWORK_CLASS_4_G = 4 ; } public static int getNetWorkClass(Context context) { TelephonyManager telephonyManager = (TelephonyManager) context .getSystemService(Context.TELEPHONY_SERVICE); switch (telephonyManager.getNetworkType()) { case TelephonyManager.NETWORK_TYPE_GPRS: case TelephonyManager.NETWORK_TYPE_EDGE: case TelephonyManager.NETWORK_TYPE_CDMA: case TelephonyManager.NETWORK_TYPE_1xRTT: case TelephonyManager.NETWORK_TYPE_IDEN: return Constants.NETWORK_CLASS_2_G; case TelephonyManager.NETWORK_TYPE_UMTS: case TelephonyManager.NETWORK_TYPE_EVDO_0: case TelephonyManager.NETWORK_TYPE_EVDO_A: case TelephonyManager.NETWORK_TYPE_HSDPA: case TelephonyManager.NETWORK_TYPE_HSUPA: case TelephonyManager.NETWORK_TYPE_HSPA: case TelephonyManager.NETWORK_TYPE_EVDO_B: case TelephonyManager.NETWORK_TYPE_EHRPD: case TelephonyManager.NETWORK_TYPE_HSPAP: return Constants.NETWORK_CLASS_3_G; case TelephonyManager.NETWORK_TYPE_LTE: return Constants.NETWORK_CLASS_4_G; default : return Constants.NETWORK_CLASS_UNKNOWN; } } //判断当前手机的网络类型(WIFI还是2,3,4G)
//需要用到上面的方法 public static int getNetWorkStatus(Context context) { int netWorkType = Constants.NETWORK_CLASS_UNKNOWN; ConnectivityManager connectivityManager = (ConnectivityManager) context .getSystemService(Context.CONNECTIVITY_SERVICE); NetworkInfo networkInfo = connectivityManager.getActiveNetworkInfo(); if (networkInfo != null && networkInfo.isConnected()) { int type = networkInfo.getType(); if (type == ConnectivityManager.TYPE_WIFI) { netWorkType = Constants.NETWORK_WIFI; } else if (type == ConnectivityManager.TYPE_MOBILE) { netWorkType = getNetWorkClass(context); } } return netWorkType; } //px-dp转换
public static int dip2px(Context context, float dpValue) { final float scale = context.getResources().getDisplayMetrics().density; return ( int ) (dpValue * scale + 0 .5f); } public static int px2dip(Context context, float pxValue) { final float scale = context.getResources().getDisplayMetrics().density; return ( int ) (pxValue / scale + 0 .5f); } //px-sp转换
public static int px2sp(Context context, float pxValue) { final float fontScale = context.getResources().getDisplayMetrics().scaledDensity; return ( int ) (pxValue / fontScale + 0 .5f); } public static int sp2px(Context context, float spValue) { final float fontScale = context.getResources().getDisplayMetrics().scaledDensity; return ( int ) (spValue * fontScale + 0 .5f); } //把一个毫秒数转化成时间字符串
//格式为小时/分/秒/毫秒(如:24903600 –> 06小时55分03秒600毫秒) /** * @param millis * 要转化的毫秒数。 * @param isWhole * 是否强制全部显示小时/分/秒/毫秒。 * @param isFormat * 时间数字是否要格式化,如果true:少位数前面补全;如果false:少位数前面不补全。 * @return 返回时间字符串:小时/分/秒/毫秒的格式(如:24903600 --> 06小时55分03秒600毫秒)。 */ public static String millisToString( long millis, boolean isWhole, boolean isFormat) { String h = "" ; String m = "" ; String s = "" ; String mi = "" ; if (isWhole) { h = isFormat ? "00小时" : "0小时" ; m = isFormat ? "00分" : "0分" ; s = isFormat ? "00秒" : "0秒" ; mi = isFormat ? "00毫秒" : "0毫秒" ; } long temp = millis; long hper = 60 * 60 * 1000 ; long mper = 60 * 1000 ; long sper = 1000 ; if (temp / hper > 0 ) { if (isFormat) { h = temp / hper < 10 ? "0" + temp / hper : temp / hper + "" ; } else { h = temp / hper + "" ; } h += "小时" ; } temp = temp % hper; if (temp / mper > 0 ) { if (isFormat) { m = temp / mper < 10 ? "0" + temp / mper : temp / mper + "" ; } else { m = temp / mper + "" ; } m += "分" ; } temp = temp % mper; if (temp / sper > 0 ) { if (isFormat) { s = temp / sper < 10 ? "0" + temp / sper : temp / sper + "" ; } else { s = temp / sper + "" ; } s += "秒" ; } temp = temp % sper; mi = temp + "" ; if (isFormat) { if (temp < 100 && temp >= 10 ) { mi = "0" + temp; } if (temp < 10 ) { mi = "00" + temp; } } mi += "毫秒" ; return h + m + s + mi; } 格式为小时/分/秒/毫秒(如:24903600 –> 06小时55分03秒)。 /** * * @param millis * 要转化的毫秒数。 * @param isWhole * 是否强制全部显示小时/分/秒/毫秒。 * @param isFormat * 时间数字是否要格式化,如果true:少位数前面补全;如果false:少位数前面不补全。 * @return 返回时间字符串:小时/分/秒/毫秒的格式(如:24903600 --> 06小时55分03秒)。 */ public static String millisToStringMiddle( long millis, boolean isWhole, boolean isFormat) { return millisToStringMiddle(millis, isWhole, isFormat, "小时" , "分钟" , "秒" ); } public static String millisToStringMiddle( long millis, boolean isWhole, boolean isFormat, String hUnit, String mUnit, String sUnit) { String h = "" ; String m = "" ; String s = "" ; if (isWhole) { h = isFormat ? "00" + hUnit : "0" + hUnit; m = isFormat ? "00" + mUnit : "0" + mUnit; s = isFormat ? "00" + sUnit : "0" + sUnit; } long temp = millis; long hper = 60 * 60 * 1000 ; long mper = 60 * 1000 ; long sper = 1000 ; if (temp / hper > 0 ) { if (isFormat) { h = temp / hper < 10 ? "0" + temp / hper : temp / hper + "" ; } else { h = temp / hper + "" ; }
36个Android开发常用代码片段的更多相关文章
- Android开发常用代码片段
拨打电话 public static void call(Context context, String phoneNumber) { context.startActivity( new Inten ...
- Android 中常用代码片段
一:AsyncTask 的使用 (1)activity_main.xml <TextView android:id="@+id/tvInfo" android:layout_ ...
- swift开发常用代码片段
// 绑定事件 cell.privacySwitch.addTarget(self, action: #selector(RSMeSettingPrivacyViewController.switch ...
- 转--Android实用的代码片段 常用代码总结
这篇文章主要介绍了Android实用的代码片段 常用代码总结,需要的朋友可以参考下 1:查看是否有存储卡插入 复制代码 代码如下: String status=Environment.getE ...
- 转发—Android开发常用的插件及工具
作者:蓝之风 出处:http://www.cnblogs.com/vaiyanzi/ Android开发常用的插件及工具 1.GitHub,这个不管是做安卓还是其他,只要是开发就必上的网站,也是天朝没 ...
- Android开发常用工具汇总
Android开发常用工具汇总,本文章不断更新完善 一.数据库小工具Sqlite Developer SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它的设计目标是嵌入式的, ...
- C#常用代码片段备忘
以下是从visual studio中整理出来的常用代码片段,以作备忘 快捷键: eh 用途: 类中事件实现函数模板 private void MyMethod(object sender, Event ...
- Android开发常用开源框架:图片处理
https://blog.csdn.net/SGQ_CSDN/article/details/79910709 Android开发常用开源框架:图片处理 框架名称 功能描述 Android Unive ...
- Vue3.0常用代码片段和开发插件
Vue3 Snippets for Visual Studio Code Vue3 Snippets源码 Vue3 Snippets下载 This extension adds Vue3 Code S ...
随机推荐
- High Voltage Boost Supply
http://learn.adafruit.com/ice-tube-clock-kit/design Tubes such as VFDs, Nixies, Decatrons, etc requi ...
- 3D单机游戏《天鹰教》源码发布(二)
3D单机游戏<天鹰教>源码发布 作者 作者: 游蓝海 博客: http://blog.csdn.net/you_lan_hai mail: you_lan_hai@foxmail. ...
- 在Linux下使用sprintf代替atoi实现整型转化为char*
程序中需要用到将整型转化为char*类型,然后将两个char*类型的变量拼接.将整型转化为char*自然想到了itoa函数: 头文件:#include <stdio.h> char *it ...
- 模拟出ios中流行的黑色背景底
[activityIndicatorView setBackgroundColor:[UIColor colorWithRed: green: blue: alpha:0.4]]; 用上面的语法,可以 ...
- arcgis10.5新功能图形缓冲
摘要 在输入要素周围某一指定距离内创建缓冲区多边形.在要素周围生成缓冲区时,大部分制图形状对缓冲区末端(端头)和拐角(连接)可用. 插图
- kafka分区原理图
一个Topic的多个分区,被分布在kafka集群中的多个server上.每一个分区都有一个server为"leader";leader负责全部的读写操作,假设leader失效,那么 ...
- flashcache的实现与分析
最近,由于项目需要,在做关于flashcache的一些工作,主要涉及模块组织.元数据管理及数据分布.读写流程分析.数据在磁盘和 cache(SSD)之间的调度.缺点及可优化方向等一些方面的分析研究.也 ...
- Python3.6学习笔记(四)
错误.调试和测试 程序运行中,可能会遇到BUG.用户输入异常数据以及其它环境的异常,这些都需要程序猿进行处理.Python提供了一套内置的异常处理机制,供程序猿使用,同时PDB提供了调试代码的功能,除 ...
- strchr实现
char* strchr(char*s,charc) { while(*s!='\0'&&*s!=c) { ++s; } return*s==c?s:NULL; } // strchr ...
- 最小二乘法least square
上研究生的时候接触的第一个Loss function就是least square.最近又研究了一下,做个总结吧. 定义看wiki就够了.公式如下 E(w)=12∑n=1N{y−xWT}2E(w)=12 ...