- 浏览: 5825840 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (890)
- WindowsPhone (0)
- android (88)
- android快速迭代 (17)
- android基础 (34)
- android进阶 (172)
- android高级 (0)
- android拾遗 (85)
- android动画&效果 (68)
- Material Design (13)
- LUA (5)
- j2me (32)
- jQuery (39)
- spring (26)
- hibernate (20)
- struts (26)
- tomcat (9)
- javascript+css+html (62)
- jsp+servlet+javabean (14)
- java (37)
- velocity+FCKeditor (13)
- linux+批处理 (9)
- mysql (19)
- MyEclipse (9)
- ajax (7)
- wap (8)
- j2ee+apache (24)
- 其他 (13)
- phonegap (35)
最新评论
-
Memories_NC:
本地lua脚本终于执行成功了,虽然不是通过redis
java中调用lua脚本语言1 -
ZHOU452840622:
大神://处理返回的接收状态 这个好像没有监听到 遇 ...
android 发送短信的两种方式 -
PXY:
拦截部分地址,怎么写的for(int i=0;i<lis ...
判断是否登录的拦截器SessionFilter -
maotou1988:
Android控件之带清空按钮(功能)的AutoComplet ...
自定义AutoCompleteTextView -
yangmaolinpl:
希望有表例子更好。。。,不过也看明白了。
浅谈onInterceptTouchEvent、onTouchEvent与onTouch
http://blog.csdn.net/flying_vip_521/article/details/7656413
Android 之 远程图片获取和本地缓存
http://blog.csdn.net/xieqibao/article/details/6682128
Log输出到sdcard工具类
http://blog.csdn.net/flying_vip_521/article/details/7652572
GSPUtil
WebService for Android
获取手机ip地址工具类
工具类:字符串处理
工具类:日期处理
工具类:加密(java)
工具类:判断一个类是否是给定类的子类
android时时监听log
Android中StatFs获取系统/sdcard存储(剩余空间)大小
在存储文件时,为了保证有充足的剩余空间大小,通常需要知道系统内部或者sdcard的存储大小。
package com.net.util; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.net.HttpURLConnection; import java.net.MalformedURLException; import java.net.URL; import java.util.ArrayList; import java.util.List; import android.content.Context; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.os.Environment; import android.util.Log; /** * 图片下载工具类 * * @author gaozhibin * */ public class BitmapUtil { private static final String TAG = "BtimapUtil"; /** * 根据网址获得图片,优先从本地获取,本地没有则从网络下载 * * @param url 图片网址 * @param context 上下文 * @return 图片 */ public static Bitmap getBitmap(String url,Context context){ Log.e(TAG, "------url="+url); String imageName= url.substring(url.lastIndexOf("/")+1, url.length()); File file = new File(getPath(context),imageName); if(file.exists()){ Log.e(TAG, "getBitmap from Local"); return BitmapFactory.decodeFile(file.getPath()); } return getNetBitmap(url,file,context); } /** * 根据传入的list中保存的图片网址,获取相应的图片列表 * * @param list 保存图片网址的列表 * @param context 上下文 * @return 图片列表 */ public static List<Bitmap> getBitmap(List<String> list,Context context){ List<Bitmap> result = new ArrayList<Bitmap>(); for(String strUrl : list){ Bitmap bitmap = getBitmap(strUrl,context); if(bitmap!=null){ result.add(bitmap); } } return result; } /** * 获取图片的存储目录,在有sd卡的情况下为 “/sdcard/apps_images/本应用包名/cach/images/” * 没有sd的情况下为“/data/data/本应用包名/cach/images/” * * @param context 上下文 * @return 本地图片存储目录 */ private static String getPath(Context context){ String path = null; boolean hasSDCard = Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED); String packageName = context.getPackageName()+"/cach/images/"; if(hasSDCard){ path="/sdcard/apps_images/"+packageName; }else{ path="/data/data/"+packageName; } File file = new File(path); boolean isExist = file.exists(); if(!isExist){ file.mkdirs(); } return file.getPath(); } /** * 网络可用状态下,下载图片并保存在本地 * * @param strUrl 图片网址 * @param file 本地保存的图片文件 * @param context 上下文 * @return 图片 */ private static Bitmap getNetBitmap(String strUrl,File file,Context context) { Log.e(TAG, "getBitmap from net"); Bitmap bitmap = null; if(NetUtil.isConnnected(context)){ try { URL url = new URL(strUrl); HttpURLConnection con = (HttpURLConnection) url.openConnection(); con.setDoInput(true); con.connect(); InputStream in = con.getInputStream(); bitmap = BitmapFactory.decodeStream(in); FileOutputStream out = new FileOutputStream(file.getPath()); bitmap.compress(Bitmap.CompressFormat.PNG,100, out); out.flush(); out.close(); in.close(); } catch (MalformedURLException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally{ } } return bitmap; } }
Android 之 远程图片获取和本地缓存
http://blog.csdn.net/xieqibao/article/details/6682128
package com.net.util; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.util.List; import org.apache.http.HttpResponse; import org.apache.http.HttpStatus; import org.apache.http.NameValuePair; import org.apache.http.client.ClientProtocolException; import org.apache.http.client.entity.UrlEncodedFormEntity; import org.apache.http.client.methods.HttpGet; import org.apache.http.client.methods.HttpPost; import org.apache.http.client.methods.HttpUriRequest; import org.apache.http.impl.client.DefaultHttpClient; import org.apache.http.util.EntityUtils; import org.json.JSONException; import org.json.JSONObject; import android.content.Context; import android.net.ConnectivityManager; import android.net.NetworkInfo; import android.util.Log; import android.widget.Toast; public class NetUtil { private static final String TAG = "NetUtil"; /** * 网络连接是否可用 */ public static boolean isConnnected(Context context) { ConnectivityManager connectivityManager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE); if (null != connectivityManager) { NetworkInfo networkInfo[] = connectivityManager.getAllNetworkInfo(); if (null != networkInfo) { for (NetworkInfo info : networkInfo) { if (info.getState() == NetworkInfo.State.CONNECTED) { Log.e(TAG, "the net is ok"); return true; } } } } Toast.makeText(context, "网络连接失败", Toast.LENGTH_SHORT).show(); return false; } /** * 网络可用状态下,通过get方式向server端发送请求,并返回响应数据 * * @param strUrl 请求网址 * @param context 上下文 * @return 响应数据 */ public static JSONObject getResponseForGet(String strUrl, Context context) { if (isConnnected(context)) { return getResponseForGet(strUrl); } return null; } /** * 通过Get方式处理请求,并返回相应数据 * * @param strUrl 请求网址 * @return 响应的JSON数据 */ public static JSONObject getResponseForGet(String strUrl) { HttpGet httpRequest = new HttpGet(strUrl); return getRespose(httpRequest); } /** * 网络可用状态下,通过post方式向server端发送请求,并返回响应数据 * * @param market_uri 请求网址 * @param nameValuePairs 参数信息 * @param context 上下文 * @return 响应数据 */ public static JSONObject getResponseForPost(String market_uri, List<NameValuePair> nameValuePairs, Context context) { if (isConnnected(context)) { return getResponseForPost(market_uri, nameValuePairs); } return null; } /** * 通过post方式向服务器发送请求,并返回响应数据 * * @param strUrl 请求网址 * @param nameValuePairs 参数信息 * @return 响应数据 */ public static JSONObject getResponseForPost(String market_uri, List<NameValuePair> nameValuePairs) { if (null == market_uri || "" == market_uri) { return null; } HttpPost request = new HttpPost(market_uri); try { request.setEntity(new UrlEncodedFormEntity(nameValuePairs)); return getRespose(request); } catch (UnsupportedEncodingException e1) { e1.printStackTrace(); } return null; } /** * 响应客户端请求 * * @param request 客户端请求get/post * @return 响应数据 */ public static JSONObject getRespose(HttpUriRequest request) { try { HttpResponse httpResponse = new DefaultHttpClient().execute(request); int statusCode = httpResponse.getStatusLine().getStatusCode(); if (HttpStatus.SC_OK == statusCode) { String result = EntityUtils.toString(httpResponse.getEntity()); Log.i(TAG, "results=" + result); return new JSONObject(result); } } catch (ClientProtocolException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } catch (JSONException e) { e.printStackTrace(); } return null; } }
Log输出到sdcard工具类
http://blog.csdn.net/flying_vip_521/article/details/7652572
package com.innofidei; import java.io.File; import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Date; public class LocatUtil { private static String logToFileCommand = "logcat -v time -f "; public static void startLog(String saveiDir, String fileName) { SimpleDateFormat format = new SimpleDateFormat("yyMMdd_HHmmss"); String nowStr = format.format(new Date()); fileName = fileName + "_" + nowStr + ".txt"; new File(saveiDir).mkdirs(); try { Runtime.getRuntime().exec(logToFileCommand + saveiDir + fileName); } catch (IOException e) { e.printStackTrace(); } } }
GSPUtil
package org.join.weather.util; import java.util.List; import org.join.weather.WeatherActivity; import org.join.weather.WeatherActivity.OnActivityResumeAndPauseListener; import android.app.AlertDialog; import android.content.Context; import android.content.Intent; import android.location.Address; import android.location.Criteria; import android.location.Geocoder; import android.location.Location; import android.location.LocationListener; import android.location.LocationManager; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.preference.PreferenceManager.OnActivityResultListener; import android.provider.Settings; import android.util.Log; import android.widget.Toast; public class GPSUtil implements OnActivityResultListener, OnActivityResumeAndPauseListener { // WeatherActivity对象 private WeatherActivity weatherActivity; // LocationManager对象 private LocationManager locationManager; // Location对象 private Location location; // 当前位置提供者 private String provider; // 时间(秒) private long minTime = 60 * 1000; // 距离(米) private float minDistance = 500; // 定位方式 private int mode = 1; // 位置监听接口 private LocationListener mLocationListener = new LocationListener() { @Override public void onLocationChanged(final Location loc) { // 当坐标改变时触发此函数,如果Provider传进相同的坐标,它就不会被触发 Log.v("onLocationChanged", "=onLocationChanged"); if (loc != null) { location = loc; showLocationInfo(loc); } else { Toast.makeText(weatherActivity, "当前位置不可定位!", Toast.LENGTH_SHORT) .show(); // 注销监听事件 // locationManager.removeUpdates(mLocationListener); } } @Override public void onProviderDisabled(String provider) { // Provider被disable时触发此函数,比如GPS被关闭 Log.v("onProviderDisabled", "=onProviderDisabled"); } @Override public void onProviderEnabled(String provider) { // Provider被enable时触发此函数,比如GPS被打开 Log.v("onProviderEnabled", "=onProviderEnabled"); } @Override public void onStatusChanged(String provider, int status, Bundle extras) { // Provider的转态在可用、暂时不可用和无服务三个状态直接切换时触发此函数 Log.v("onStatusChanged", "=onStatusChanged"); } }; // 超时注销服务 private Handler myHandler = new Handler() { @Override public void handleMessage(Message msg) { if (null == location) { // 提示信息 Toast.makeText(weatherActivity, "当前位置不可定位!", Toast.LENGTH_SHORT) .show(); } // 注销监听事件 locationManager.removeUpdates(mLocationListener); } }; public GPSUtil(WeatherActivity weatherActivity, int mode) { this.weatherActivity = weatherActivity; weatherActivity.setOnActivityResultListener(this); weatherActivity.setOnResumeAndPauseListener(this); this.mode = mode; // 获得LocationManager服务 locationManager = (LocationManager) weatherActivity .getSystemService(Context.LOCATION_SERVICE); if (openGPSSettings()) { setLocationServer(mode); } else { Toast.makeText(weatherActivity, "请开启GPS!", Toast.LENGTH_SHORT) .show(); Intent intent = new Intent(Settings.ACTION_SECURITY_SETTINGS); // 此为设置完成后返回到获取界面 weatherActivity.startActivityForResult(intent, 0); } } public GPSUtil(WeatherActivity weatherActivity, int mode, long minTime, float minDistance) { this(weatherActivity, mode); this.minTime = minTime; this.minDistance = minDistance; } // 判断GPS模块是否存在或者是开启 private boolean openGPSSettings() { if (locationManager .isProviderEnabled(android.location.LocationManager.GPS_PROVIDER)) { return true; } return false; } // 更新当前位置信息(如果使用GPS,需要保证在室外,并且没有大建筑物遮挡,如果使用网络定位,要保证网络通畅) public void setLocationServer(int mode) { Toast.makeText(weatherActivity, "正在定位!", Toast.LENGTH_SHORT).show(); switch (mode) { case 1: { // GPS定位 if (locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER)) { provider = LocationManager.GPS_PROVIDER; location = locationManager.getLastKnownLocation(provider); // 设置监听器,自动更新的最小时间为间隔N秒或最小位移变化超过N米 locationManager.requestLocationUpdates(provider, minTime, minDistance, mLocationListener); Log.v("GPS定位", "GPS定位!"); } else { Log.v("GPS定位", "未提供GPS定位功能!"); } break; } case 2: { // NETWORK定位 provider = LocationManager.NETWORK_PROVIDER; location = locationManager.getLastKnownLocation(provider); // 设置监听器,自动更新的最小时间为间隔N秒或最小位移变化超过N米 locationManager.requestLocationUpdates(provider, minTime, minDistance, mLocationListener); Log.v("NETWORK定位", "NETWORK定位!"); break; } case 3: { // 查询符合条件的Location Provider来定位 // 获得Criteria对象(指定条件参数) Criteria criteria = new Criteria(); // 获得最好的单位效果 criteria.setAccuracy(Criteria.ACCURACY_FINE); criteria.setAltitudeRequired(false); criteria.setBearingRequired(false); criteria.setCostAllowed(false); // 使用省电模式 criteria.setPowerRequirement(Criteria.POWER_LOW); // 获得当前位置的提供者 provider = locationManager.getBestProvider(criteria, true); // 获得当前位置 location = locationManager.getLastKnownLocation(provider); if (null != provider) { // 设置监听器,自动更新的最小时间为间隔N秒或最小位移变化超过N米 locationManager.requestLocationUpdates(provider, minTime, minDistance, mLocationListener); } else { Log.v("provider", "null == provider"); } Log.v("最优定位", provider); break; } } if (null != location) { showLocationInfo(location); } // 延迟10秒 myHandler.sendEmptyMessageDelayed(0, 10 * 1000); } // 显示定位信息 private void showLocationInfo(Location loc) { String msg = ""; try { msg = "经度:" + location.getLongitude() + "\n"; msg += "纬度:" + location.getLatitude() + "\n"; Geocoder gc = new Geocoder(weatherActivity); List<Address> addresses = gc.getFromLocation( location.getLatitude(), location.getLongitude(), 1); // 相关信息 if (addresses.size() > 0) { msg += "AddressLine:" + addresses.get(0).getAddressLine(0) + "\n"; msg += "CountryName:" + addresses.get(0).getCountryName() + "\n"; msg += "Locality:" + addresses.get(0).getLocality() + "\n"; msg += "FeatureName:" + addresses.get(0).getFeatureName(); } } catch (Exception e) { msg = e.getMessage(); } new AlertDialog.Builder(weatherActivity).setMessage(msg) .setPositiveButton("确定", null).show(); } @Override public boolean onActivityResult(int requestCode, int resultCode, Intent data) { // 从设置GPS的Activity返回时 if (0 == requestCode) { if (openGPSSettings()) { setLocationServer(mode); } else { Toast.makeText(weatherActivity, "GPS仍未开启!", Toast.LENGTH_SHORT) .show(); } } return false; } // 在Activity恢复活动时,响应位置更新 @Override public void onResume() { if (null != provider) { locationManager.requestLocationUpdates(provider, minTime, minDistance, mLocationListener); } } // 在Activity暂停活动时,取消位置更新 @Override public void onPause() { if (null != locationManager) { locationManager.removeUpdates(mLocationListener); } } }
WebService for Android
获取手机ip地址工具类
package com.innofidei.location; import java.net.InetAddress; import java.net.UnknownHostException; import android.content.Context; import android.net.wifi.WifiManager; public class AdressUtil { public String getIp(Context myContext) { InetAddress address = getWifiIp(myContext); if (address != null) { return address.getHostAddress(); } return null; } private InetAddress getWifiIp(Context myContext) { if (myContext == null) { throw new NullPointerException("Global context is null"); } WifiManager wifiMgr = (WifiManager) myContext.getSystemService(Context.WIFI_SERVICE); if (isWifiEnabled(myContext)) { int ipAsInt = wifiMgr.getConnectionInfo().getIpAddress(); if (ipAsInt == 0) { return null; } else { return intToInet(ipAsInt); } } else { return null; } } private boolean isWifiEnabled(Context myContext) { if (myContext == null) { throw new NullPointerException("Global context is null"); } WifiManager wifiMgr = (WifiManager) myContext.getSystemService(Context.WIFI_SERVICE); if (wifiMgr.getWifiState() == WifiManager.WIFI_STATE_ENABLED) { return true; } else { return false; } } private InetAddress intToInet(int value) { byte[] bytes = new byte[4]; for (int i = 0; i < 4; i++) { bytes[i] = byteOfInt(value, i); } try { return InetAddress.getByAddress(bytes); } catch (UnknownHostException e) { // This only happens if the byte array has a bad length return null; } } private byte byteOfInt(int value, int which) { int shift = which * 8; return (byte) (value >> shift); } }
工具类:字符串处理
工具类:日期处理
工具类:加密(java)
工具类:判断一个类是否是给定类的子类
public class ClassUtils { /** * Checks if a class is a subclass of a class with the specified name. Used * as an instanceOf without having to load the class, useful when trying to * check for classes that might not be available in the runtime JRE. * * @param clazz * The class to check * @param className * The class name to look for in the super classes * @return true if the class extends a class by the specified name. */ public static boolean extendsClass(final Class<?> clazz, String className) { Class<?> superClass = clazz.getSuperclass(); while (superClass != null) { if (superClass.getName().equals(className)) { return true; } superClass = superClass.getSuperclass(); } return false; } }
android时时监听log
Android中StatFs获取系统/sdcard存储(剩余空间)大小
在存储文件时,为了保证有充足的剩余空间大小,通常需要知道系统内部或者sdcard的存储大小。
import java.io.File; import android.os.Environment; import android.os.StatFs; public class MemoryStatus { static final int ERROR = -1; /** * 外部存储是否可用 * @return */ static public boolean externalMemoryAvailable() { return android.os.Environment.getExternalStorageState().equals( android.os.Environment.MEDIA_MOUNTED); } /** * 获取手机内部可用空间大小 * @return */ static public long getAvailableInternalMemorySize() { File path = Environment.getDataDirectory(); StatFs stat = new StatFs(path.getPath()); long blockSize = stat.getBlockSize(); long availableBlocks = stat.getAvailableBlocks(); return availableBlocks * blockSize; } /** * 获取手机内部空间大小 * @return */ static public long getTotalInternalMemorySize() { File path = Environment.getDataDirectory(); StatFs stat = new StatFs(path.getPath()); long blockSize = stat.getBlockSize(); long totalBlocks = stat.getBlockCount(); return totalBlocks * blockSize; } /** * 获取手机外部可用空间大小 * @return */ static public long getAvailableExternalMemorySize() { if (externalMemoryAvailable()) { File path = Environment.getExternalStorageDirectory(); StatFs stat = new StatFs(path.getPath()); long blockSize = stat.getBlockSize(); long availableBlocks = stat.getAvailableBlocks(); return availableBlocks * blockSize; } else { return ERROR; } } /** * 获取手机外部空间大小 * @return */ static public long getTotalExternalMemorySize() { if (externalMemoryAvailable()) { File path = Environment.getExternalStorageDirectory(); StatFs stat = new StatFs(path.getPath()); long blockSize = stat.getBlockSize(); long totalBlocks = stat.getBlockCount(); return totalBlocks * blockSize; } else { return ERROR; } } static public String formatSize(long size) { String suffix = null; if (size >= 1024) { suffix = "KiB"; size /= 1024; if (size >= 1024) { suffix = "MiB"; size /= 1024; } } StringBuilder resultBuffer = new StringBuilder(Long.toString(size)); int commaOffset = resultBuffer.length() - 3; while (commaOffset > 0) { resultBuffer.insert(commaOffset, ','); commaOffset -= 3; } if (suffix != null) resultBuffer.append(suffix); return resultBuffer.toString(); } }
发表评论
-
NestedScrollView滚动到顶部固定子View悬停挂靠粘在顶端
2018-10-31 20:45 7011网上有一个StickyScrollView,称之为粘性Scro ... -
自定义Behavior实现AppBarLayout越界弹性效果
2017-03-31 09:33 10384一、继承AppBarLayout.Beha ... -
Android - 一种相似图片搜索算法的实现
2017-03-31 09:33 2632算法 缩小尺寸。 将图片缩小到8x8的尺寸,总共64个 ... -
使用SpringAnimation实现带下拉弹簧动画的 ScrollView
2017-03-30 11:30 2859在刚推出的 Support Library 25.3.0 里面 ... -
Android为应用添加角标(Badge)
2017-03-30 11:21 61951.需求简介 角标是什么意思呢? 看下图即可明了: 可 ... -
Android端与笔记本利用局域网进行FTP通信
2017-03-23 10:17 988先看图 打开前: 打开后: Activity类 ... -
PorterDuffColorFilter 在项目中的基本使用
2017-03-03 10:58 1361有时候标题栏会浮在内容之上,而内容会有颜色的变化,这时候就要求 ... -
ColorAnimationView 实现了滑动Viewpager 时背景色动态变化的过渡效果
2017-02-24 09:41 2231用法在注释中: import android.anima ... -
迷你轻量级全方向完美滑动处理侧滑控件SlideLayout
2017-01-16 16:53 2602纯手工超级迷你轻量级全方向完美滑动处理侧滑控件(比官方 sup ... -
Effect
2017-01-05 09:57 0https://github.com/JetradarMobi ... -
动态主题库Colorful,容易地改变App的配色方案
2016-12-27 14:49 2572Colorful是一个动态主题库,允许您很容易地改变App的配 ... -
对视图的对角线切割DiagonalView
2016-12-27 14:23 1126提供对视图的对角线切割,具有很好的用户定制 基本用法 ... -
仿淘宝京东拖拽商品详情页上下滚动黏滞效果
2016-12-26 16:53 3505比较常用的效果,有现成的,如此甚好!:) import ... -
让任意view具有滑动效果的SlideUp
2016-12-26 09:26 1712基本的类,只有一个: import android.a ... -
AdvancedWebView
2016-12-21 09:44 16https://github.com/delight-im/A ... -
可设置圆角背景边框的按钮, 通过调节色彩明度自动计算按下(pressed)状态颜色
2016-11-02 22:13 1931可设置圆角背景边框的的按钮, 通过调节色彩明度自动计算按下(p ... -
网络请求库相关
2016-10-09 09:35 62https://github.com/amitshekhari ... -
ASimpleCache一个简单的缓存框架
2015-10-26 22:53 2185ASimpleCache 是一个为android制定的 轻量级 ... -
使用ViewDragHelper实现的DragLayout开门效果
2015-10-23 10:55 3424先看一下图,有个直观的了解,向下拖动handle就“开门了”: ... -
保证图片长宽比的同时拉伸图片ImageView
2015-10-16 15:40 3740按比例放大图片,不拉伸失真 import android. ...
相关推荐
本文实例讲述了Android开发之超强图片工具类BitmapUtil。分享给大家供大家参考,具体如下: 说明:为了方便大家使用,本人把大家常用的图片处理代码集中到这个类里 使用了LruCache与SoftReference /** * 图片加载...
3. **BitmapUtil**: 图片处理工具类,用于处理图片的加载、缩放、裁剪、压缩等。在Android应用中,图片的优化对于性能和用户体验至关重要,因此BitmapUtil能够减少内存消耗,防止OOM(内存溢出)问题。 4. **...
1. **BitmapUtil**:处理图像的工具类,包括压缩图片、裁剪图片、转换为Base64字符串等功能,对内存管理至关重要,可以避免因大图导致的OOM问题。 2. **DateUtil**:处理日期和时间的工具类,提供了格式化日期、...
- **BitmapUtil**: 图片处理工具类,可能包含图片的压缩、裁剪、转换等功能。 - **NetworkUtil**: 检查网络状态,判断网络连接类型(如Wi-Fi、移动数据)等。 - **JSONUtil**: 解析和生成JSON数据,可以集成Gson...
在Android应用开发中,工具类(Utils类)是开发者经常使用的辅助代码集合,它们封装了各种通用功能,以便在项目中方便地复用。在这个"Android快速开发系列"中,我们将探讨10个非常实用的工具类,这些工具类可以帮助...
AnimationUtils 动画工具类 AppUtils APP相关信息工具类 AssetDatabaseOpenHelper 目录资源获取 Base64 加密 BitmapUtil 获取Bitmap和对Bitmap的操作 ChannelUtil 获取市场号 Colors 颜色工具类 包括常用的色值 DES ...
3. **BitmapUtil**: 图片处理工具类,包括图片压缩、裁剪、转换等操作。例如,`compressBitmap()`用于压缩图片以减少内存消耗,`decodeSampledBitmapFromResource()`则用于根据屏幕尺寸加载适合的图片大小,防止OOM...
bitmap 缓存工具类,实现缓存sd卡以及内存功能,
3. **BitmapUtil**: 图片处理工具类,包含图片压缩、裁剪、加载等操作。例如,`compressBitmap()` 可以用于减少图片内存占用,`cropBitmap()` 可实现图片的裁剪。 4. **IOUtil**: 输入输出工具类,处理文件读写、流...
4. **BitmapUtil**:位图处理工具类 - `compressBitmap(Bitmap bitmap, int quality)`:压缩Bitmap,减少内存占用。 - `decodeSampledBitmapFromResource(Resources res, int resId, int reqWidth, int reqHeight)...
- **BitmapUtil**:处理图片资源,包括压缩、裁剪、转换为其他格式等。 - **DateUtil**:处理日期时间,提供格式化、比较、计算差值等功能。 - **SharedPreferencesUtil**:封装SharedPreferences操作,便于...
囊括了一大部分Android应用开发过程当中常用的工具类。工具类来源整理自网络和自己编写。 所有的工具类简介 (a - z): 类 介绍 AnimationUtils Animation 工具类 AppUtils APP 相关信息工具类 ...
工具类有:AppUtil、BitmapUtil、DateUtil、JsonUtil、LogUtil、MeasureUtil、NetWorkUtil、PreferencesUtil、ReflectUtil、SDCardUtil、ScreenUtil、XmlUtil、ColorUtil、ExitActivityUtil、FileUtil、HttpUtil、...
4. **图片处理**:BitmapUtil则涉及图片的加载、压缩、裁剪等操作,比如`compressBitmap(Bitmap bitmap, int quality)`用于压缩Bitmap以减少内存占用。 5. **日志打印**:LogUtil提供了一种统一的日志打印方式,...
此外,BitmapUtil可能是处理图像的工具类,它可能包含图片的加载、压缩、缓存等功能。在Android中,图片资源往往较大,合理处理可以节省内存,防止应用因内存泄漏而崩溃。 文件操作也是常见需求,FileUtil可能提供...
Android史上最全Util工具类集锦: 1.AppUtil 2.BitmapUtil 3.DataUtil 4.FileUtil 5.MobleInfoUtil 6.NetUtil 7.QRUtils(二维码生成工具) 8.ScreenUtil 9.SDCardUtil 10.StringUtils 吐血总结,希望对大家有用
这个是我自己收集整理的一些常用的工具类 有好的工具类,欢迎提交PR 作者微博: @海淀区小鬼风尘 QQ群欢迎大家加入:391513287 增加常用库的README_LIB 常用库 内容说明 工具 描述 AnimationUtils 动画工具...
3. **BitmapUtil**:位图处理工具类,用于图片的压缩、加载、缓存等。 4. **NetworkUtil**:网络状态检测与网络请求辅助工具类。 5. **DateUtil**:日期时间处理工具类,提供了日期的格式化、比较和转换等功能。 6. ...
BitmapUtils工具类主要用于帮助开发者高效地处理Bitmap对象,包括但不限于图片的合成、放大缩小、旋转等操作。在提供的代码片段中,我们可以看到BitmapUtils类包含以下几个关键方法: 1. `init(Context context, ...