android 实用代码片段整理
android 常用代码片段,前1-10条是从网上摘录,向原作者致谢。后面为自己整理。
1、设置窗口格式为半透明 getWindow().setFormat(PixelFormat.TRANSLUCENT); 2、Android中在非UI线程里更新View的不同方法: * Activity.runOnUiThread( Runnable ) * View.post( Runnable ) * View.postDelayed( Runnable, long ) * Hanlder 3、全屏显示窗口 requestWindowFeature(Window.FEATURE_NO_TITLE); getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); 4、取得屏幕大小 方法A: WindowManager windowManager = getWindowManager(); Display display = windowManager.getDefaultDisplay(); hAndW[0] = display.getWidth(); hAndW[1] = display.getHeight(); 方法B: DisplayMetrics dm = new DisplayMetrics(); getWindowManager().getDefaultDisplay().getMetrics(dm); hAndW[0] = dm.widthPixels; hAndW[1] = dm.heightPixels; 5、调浏览器 载入网址 Uri uri = Uri.parse("http://www.google.com"); Intent it = new Intent(Intent.ACTION_VIEW, uri); startActivity(it); 6、取得内存大小 ActivityManager.MemoryInfo outInfo = new ActivityManager.MemoryInfo(); activityManager.getMemoryInfo(outInfo); //可用内存 outInfo.availMem //是否在低内存状态 outInfo.lowMemory 取得ScrollView的实际高度 scrollview.getHeight() scrollview.getMeasuredHeight() scrollview.compute() scrollview.getLayoutParams().height 7、监听App安装/卸载事件 A.Define a class derived from class BroadcastReceiver; B.Register broadcast receiver; MyBroadcastReceiver myReceiver = new MyBroadcastReceiver(); IntentFilter filter = new IntentFilter(Intent.ACTION_PACKAGE_INSTALL); filter.addAction(Intent.ACTION_PACKAGE_REMOVED); filter.addAction(Intent.ACTION_PACKAGE_ADDED); filter.addAction(Intent.ACTION_PACKAGE_CHANGED); filter.addAction(Intent.ACTION_PACKAGE_RESTARTED); ... filter.addDataScheme("package"); //This line is very important. Otherwise, broadcast can't be received. registerReceiver(myReceiver, filter); Notes: The package name is Intent.mData. Intent.mData is not available in SDK 1.0, but it can be retrieved by calling Intent.getDataString(); 8、取得IP地址 A. //Connect via WIFI 通过wifi WifiManager wifiManager = (WifiManager) getSystemService(WIFI_SERVICE); WifiInfo wifiInfo = wifiManager.getConnectionInfo(); int ipAddress = wifiInfo.getIpAddress(); B. //Connect via GPRS通过gprs public String getLocalIpAddress(){ try{ for(Enumeration<NetworkInterface> en = NetworkInterface.getNetworkInterfaces(); en.hasMoreElements();){ NetworkInterface intf = en.nextElement(); for (Enumeration<InetAddress> enumIpAddr = intf.getInetAddresses(); enumIpAddr.hasMoreElements();){ InetAddress inetAddress = enumIpAddr.nextElement(); if (!inetAddress.isLoopbackAddress()){ return inetAddress.getHostAddress().toString(); } } } }catch (SocketException ex){ Log.e(S.TAG, ex.toString()); } return null; } 9、ListView 后面adapter数据已更改,但是ListView没有收到Notification 首先,必须将 更新adapter数据的代码放在:Handler.post(Runnable)方法中执行; 然后,如果Adapter数据的来源如果是cursor(CursorAdapter)的话 可以cursor.requery一下,如果是别的可以强制调用一下notifyChange, notifyChange 会调用 invalidate 进行重绘; 10、模拟HOME键 Intent i=new Intent(Intent.ACTION_MAIN); i.addCategory(Intent.CATEGORY_HOME); i.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK); context.startActivity(i); 11、设置焦点 editText.setFocusable(true); editText.requestFocus(); editText.setFocusableInTouchMode(true); 12:在一个应用中去调用另一个app 例如: if (Utils.isAvilible(context, "com.netschool.main.ui")) { Intent i = new Intent(); ComponentName cn = new ComponentName("com.netschool.main.ui", "com.netschool.main.ui.SplashScreenActivity"); i.setComponent(cn); startActivity(i); } else { Uri uri = Uri.parse(context.getString(R.string.url_zhuanti_download)); Intent it = new Intent(Intent.ACTION_VIEW, uri); it.setData(uri); startActivity(it); } 13:andoroid TextView 显示特殊字符 String course_jianjie ="xxxxxxxxxx"; //字符串中有 \r\n 需要替换为 <br/> String temp =course_jianjie.replaceAll("\\r\\n", "<br/>"); //用html 来显示 CharSequence styledText = Html.fromHtml(temp); //设置要显示的控件 mCourseDescTv.setText(styledText); 14:使用NotificationManager触发多个Notification,只显示最后一个的问题 只要每个不同的Intent对应传递一个独立的ID就可以了,以上函数修改如下(增加ID参数): private Notification genreNotification(Context context, int icon, String tickerText, String title, String content, Intent intent, int id){ Notification notification = new Notification(icon, tickerText, System.currentTimeMillis()); // 问题就在这里的id了 PendingIntent pendIntent = PendingIntent.getActivity(context, id, intent, PendingIntent.FLAG_UPDATE_CURRENT); notification.setLatestEventInfo(context, title, content, pendIntent); notification.flags |= Notification.FLAG_AUTO_CANCEL; return notification; } ... mNotificationManager.notify(ID_1, genreNotification(mContext, ICON_RES, notifyText1, notifyTitle1, notifyText1, intent_1, ID_1)); ... mNotificationManager.notify(ID_2, genreNotification(mContext, ICON_RES, notifyText2, notifyTitle2, notifyText2, intent_2, ID_2)); ... mNotificationManager.notify(ID_3, genreNotification(mContext, ICON_RES, notifyText3, notifyTitle3, notifyText3, intent_3, ID_3)); 15: adb 命令截图 adb shell /system/bin/screencap -p /sdcard/screenshot.png(保存到SDCard) adb pull /sdcard/screenshot.png d:/screenshot.png(保存到电脑) 16:跳出for循环 OK: for(int i=0;i<100;i++){ if(i==10){ break OK; } } 17:使用viewPager加载超过3页 有时会报出 The specified child already has a parent. You must call removeView() on the child's parent first 的错误 此时:可以简单的用 mViewPager.setOffscreenPageLimit(3);解决 备注:单这不是万能之策,也不是优选之策 18: /** * @Description:调节音量大小 * @author: jrh * @date: 2014-11-13 下午3:06:46 * @return: void * @param percent */ private void onVolumeSlide(float percent) { if (mVolume == -1) { mVolume = mAudioManager.getStreamVolume(AudioManager.STREAM_MUSIC); if (mVolume < 0) { mVolume = 0; } mOperationBg.setImageResource(R.drawable.video_volumn_bg); mVolumeBrightnessLayout.setVisibility(View.VISIBLE); } int index = (int) ((percent * mMaxVolume) + mVolume); if (index > mMaxVolume) { index = mMaxVolume;// 最大音量 } else if (index < 0) { index = 0;// 静音 } // 变更声音 mAudioManager.setStreamVolume(AudioManager.STREAM_MUSIC, index, 0); // 变更进度条 ViewGroup.LayoutParams lp = mOperationPercent.getLayoutParams(); lp.width = findViewById(R.id.operation_full).getLayoutParams().width * index / mMaxVolume; mOperationPercent.setLayoutParams(lp); } 19 /** * @Description:调节屏幕亮度 * @author: jrh * @date: 2014-11-13 下午3:17:40 * @return: void * @param percent */ private void onBrightnessSlide(float percent) { if (mBrightness < 0) { mBrightness = getWindow().getAttributes().screenBrightness; if (mBrightness <= 0.00f) { mBrightness = 0.50f; } else if (mBrightness < 0.01f) { mBrightness = 0.01f; } // 显示 mOperationBg.setImageResource(R.drawable.video_brightness_bg); mVolumeBrightnessLayout.setVisibility(View.VISIBLE); } WindowManager.LayoutParams lpa = getWindow().getAttributes(); lpa.screenBrightness = mBrightness + percent; if (lpa.screenBrightness > 1.0f) { lpa.screenBrightness = 1.0f;// 最亮 } else if (lpa.screenBrightness < 0.01f) { lpa.screenBrightness = 0.01f; } getWindow().setAttributes(lpa); ViewGroup.LayoutParams lp = mOperationPercent.getLayoutParams(); lp.width = (int) (findViewById(R.id.operation_full).getLayoutParams().width * lpa.screenBrightness); mOperationPercent.setLayoutParams(lp); } 20:viewpager + fragment 布局时有时会报下面的错误 11-14 13:52:45.266: E/AndroidRuntime(4561): FATAL EXCEPTION: main 11-14 13:52:45.266: E/AndroidRuntime(4561): java.lang.NullPointerException 11-14 13:52:45.266: E/AndroidRuntime(4561): at android.support.v4.app.FragmentManagerImpl.saveFragmentBasicState(FragmentManager.java:1576) 解决方法: 在继承fragment的里面重写 @Override public void onSaveInstanceState(Bundle outState) { // TODO Auto-generated method stub super.onSaveInstanceState(outState); setUserVisibleHint(true); } 21:service 服务并不是另开一个线程 ,处理service 时最好单独开线程进行处理 22:不要在receiver 里面处理耗时工作 23:如果布局时: 想要在字中间加空格 可以使用 " ;" html 的空格实体编号添加。注意:一个汉字相当于 两个空格字符。 24:volatile java 关键字 保证了线程可以读取其他线程的写入值、 Thread.join() 方法保证了该线程优先执行 其他线程等待 Thread.yied() 方法 让出时间让其它线程可以执行 如何停止线程? 不要随意调用 Thread.stop()方法 ,该方法不是正确的停止线程方法 会导致一些其他的问题 使用推出的旗杆标志 :如设置 boolean 值等 结束时及时清理资源 使用代码逻辑来使得线程执行结束 (使thread 线程内部的代码 任务执行完毕) 25:如何在TextVeiw下加入一条线 TextView tv = new TextView(); tv.getPaint().setFlags(Paint.UNDERLINE_TEXT_FLAG); 26:android 4.4 以上无法在外置SD卡创建文件夹 解决方法: @A File dirFile = new File(temp.trim()); if (!dirFile.exists()) {// 对于4.4以上版本特别重要 getApplicationContext().getExternalFilesDir(null); dirFile.mkdirs(); } @B 文件路径:/android/data/包名/ 27:在: android:targetSdkVersion="18" 随着版本号的改变 界面元素,显示方式是不一样的 28:android 获取所有存储卡的地址 private String[] getSdCard() { StorageManager sm = (StorageManager) getSystemService(Context.STORAGE_SERVICE); String[] paths = null; try { paths = (String[]) sm.getClass().getMethod("getVolumePaths", null) .invoke(sm, null); } catch (IllegalAccessException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IllegalArgumentException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (InvocationTargetException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (NoSuchMethodException e) { // TODO Auto-generated catch block e.printStackTrace(); } return paths; } 29:百度地图 出现问题 A:报错 java.lang.UnsatisfiedLinkError: Couldn't load BaiduMapSDK_v3_2_0_15 from loader dalvik.system.PathClassLoader[dexPath=/data/app/com.znxh.haohao-1.apk,libraryPath=/data/app-lib/com.znxh.haohao-1]: findLibrary returned null 解决方法: 1:现在libs下建armeabi文件夹,然后加入.so库文件; 2:如果上述方法不行:再在libs下建armeabi-v7a文件夹,再导入相应.so库文件 3:定位时一定要在mainfest 文件中注册服务: <service android:name="com.baidu.location.f" android:enabled="true" android:process=":remote" > </service> 30:处理图片上传的工具类 /* * 上传头像 * * @param urlStr url地址 * * @param userid 用户id * * @param urlStr 要上传的图片 */ public static Runnable upLoadFile(final Handler handler, final String urlString, final String userid, final File file) { Runnable runnable = new Runnable() { @Override public void run() { int res = 0; String result = null; String BOUNDARY = UUID.randomUUID().toString(); // 边界标识 随机生成 String PREFIX = "--", LINE_END = "\r\n"; String CONTENT_TYPE = "multipart/form-data"; // 内容类型 try { URL url = new URL(urlString); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setReadTimeout(2000); conn.setConnectTimeout(2000); conn.setDoInput(true); // 允许输入流 conn.setDoOutput(true); // 允许输出流 conn.setUseCaches(false); // 不允许使用缓存 conn.setRequestMethod("POST"); // 请求方式 conn.setRequestProperty("Charset", "UTF-8"); // 设置编码 conn.setRequestProperty("connection", "keep-alive"); conn.setRequestProperty("Content-Type", CONTENT_TYPE + ";boundary=" + BOUNDARY); if (file != null) { /** * 当文件不为空时执行上传 */ DataOutputStream dos = new DataOutputStream(conn.getOutputStream()); StringBuffer sb = new StringBuffer(); sb.append("--" + BOUNDARY + "\r\n"); sb.append("Content-Disposition: form-data; name=\"userid\"" + "\r\n"); sb.append("\r\n"); sb.append(userid + "\r\n"); sb.append(PREFIX); sb.append(BOUNDARY); sb.append(LINE_END); /** * 这里重点注意: name里面的值为服务器端需要key 只有这个key 才可以得到对应的文件 filename是文件的名字,包含后缀名 */ sb.append("Content-Disposition: form-data; name=\"photo\"; filename=\"" + file.getName() + "\"" + LINE_END); sb.append("Content-Type: image/pjpeg; charset=" + "UTF-8" + LINE_END); sb.append(LINE_END); dos.write(sb.toString().getBytes()); InputStream is = new FileInputStream(file); byte[] bytes = new byte[1024]; int len = 0; while ((len = is.read(bytes)) != -1) { dos.write(bytes, 0, len); } is.close(); dos.write(LINE_END.getBytes()); byte[] end_data = (PREFIX + BOUNDARY + PREFIX + LINE_END).getBytes(); dos.write(end_data); dos.flush(); /** * 获取响应码 200=成功 当响应成功,获取响应的流 */ res = conn.getResponseCode(); Log.i("return code", "response code:" + res); Log.i("userid", "" + userid); if (res == 200) { InputStream input = conn.getInputStream(); StringBuffer sb1 = new StringBuffer(); int ss; while ((ss = input.read()) != -1) { sb1.append((char) ss); } result = sb1.toString(); Log.i("return", "result : " + result); Message message = Message.obtain(); message.what = 666; handler.sendMessage(message); } else { Log.i("return", "request error"); } } } catch (MalformedURLException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } }; return runnable; }
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。