android开发小汇3

获取字宽
GetTextWidth.java 外部引用原始文档
1
2
3
4
5
public static float GetTextWidth(String text, float Size) {
        TextPaint FontPaint = new TextPaint();
        FontPaint.setTextSize(Size);
        return FontPaint.measureText(text);
    }


Android系统详解之获取图片和视频的缩略图
1
2
3
4
5
6
7
8
从Android 2.2开始系统新增了一个缩略图ThumbnailUtils类,位于framework的android.media.ThumbnailUtils位置,可以帮助我们从mediaprovider中获取系统中的视频或图片文件的缩略图,该类提供了三种静态方法可以直接调用获取。

1.
static Bitmap createVideoThumbnail(String filePath, int kind) //获取视频文件的缩略图,第一个参数为视频文件的位置,比如/sdcard/android123.3gp,而第二个参数可以为MINI_KIND或 MICRO_KIND最终和分辨率有关
2.
static Bitmap extractThumbnail(Bitmap source, int width, int height, int options) //直接对Bitmap进行缩略操作,最后一个参数定义为OPTIONS_RECYCLE_INPUT ,来回收资源
3.
static Bitmap extractThumbnail(Bitmap source, int width, int height) // 这个和上面的方法一样,无options选项
获取视频缩略图 外部引用原始文档
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
public static Bitmap getVideoThumbnail(ContentResolver cr, Uri uri) {  
        Bitmap bitmap = null;  
        BitmapFactory.Options options = new BitmapFactory.Options();  
        options.inDither = false;  
        options.inPreferredConfig = Bitmap.Config.ARGB_8888;  
        Cursor cursor = cr.query(uri,new String[] { MediaStore.Video.Media._ID }, null, null, null);   
      
        if (cursor == null || cursor.getCount() == 0) {  
            return null;  
        }  
        cursor.moveToFirst();  
        String videoId = cursor.getString(cursor.getColumnIndex(MediaStore.Video.Media._ID));  //image id in image table.s  
  
        if (videoId == null) {  
        return null;  
        }  
        cursor.close();  
        long videoIdLong = Long.parseLong(videoId);  
        bitmap = MediaStore.Video.Thumbnails.getThumbnail(cr, videoIdLong,Images.Thumbnails.MICRO_KIND, options);  
  
        return bitmap;  
        }  
获取sd卡中视频缩略图 外部引用原始文档
  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
import java.io.File;
import android.app.Activity;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.media.ThumbnailUtils;
import android.os.Bundle;
import android.os.Environment;
import android.provider.MediaStore;
import android.widget.ImageView;
/**
 * 获取图片和视频的缩略图
 * 这两个方法必须在2.2及以上版本使用,因为其中使用了ThumbnailUtils这个类
 */
public class AndroidTestActivity extends Activity {
 private ImageView imageThumbnail;
 private ImageView videoThumbnail;

 /** Called when the activity is first created. */
 @Override
 public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.main);

  imageThumbnail = (ImageView) findViewById(R.id.image_thumbnail);
  videoThumbnail = (ImageView) findViewById(R.id.video_thumbnail);

  String imagePath = Environment.getExternalStorageDirectory()
    .getAbsolutePath()
    + File.separator
    + "photo"
    + File.separator
    + "yexuan.jpg";

  String videoPath = Environment.getExternalStorageDirectory()
    .getAbsolutePath()
    + File.separator
    + "video"
    + File.separator
    + "醋点灯.avi";
  
  imageThumbnail.setImageBitmap(getImageThumbnail(imagePath, 60, 60));
  videoThumbnail.setImageBitmap(getVideoThumbnail(videoPath, 60, 60,
    MediaStore.Images.Thumbnails.MICRO_KIND));
 }

 /**
  * 根据指定的图像路径和大小来获取缩略图
  * 此方法有两点好处:
  *     1. 使用较小的内存空间,第一次获取的bitmap实际上为null,只是为了读取宽度和高度,
  *        第二次读取的bitmap是根据比例压缩过的图像,第三次读取的bitmap是所要的缩略图。
  *     2. 缩略图对于原图像来讲没有拉伸,这里使用了2.2版本的新工具ThumbnailUtils,使
  *        用这个工具生成的图像不会被拉伸。
  * @param imagePath 图像的路径
  * @param width 指定输出图像的宽度
  * @param height 指定输出图像的高度
  * @return 生成的缩略图
  */
 private Bitmap getImageThumbnail(String imagePath, int width, int height) {
  Bitmap bitmap = null;
  BitmapFactory.Options options = new BitmapFactory.Options();
  options.inJustDecodeBounds = true;
  // 获取这个图片的宽和高,注意此处的bitmap为null
  bitmap = BitmapFactory.decodeFile(imagePath, options);
  options.inJustDecodeBounds = false; // 设为 false
  // 计算缩放比
  int h = options.outHeight;
  int w = options.outWidth;
  int beWidth = w / width;
  int beHeight = h / height;
  int be = 1;
  if (beWidth < beHeight) {
   be = beWidth;
  } else {
   be = beHeight;
  }
  if (be <= 0) {
   be = 1;
  }
  options.inSampleSize = be;
  // 重新读入图片,读取缩放后的bitmap,注意这次要把options.inJustDecodeBounds 设为 false
  bitmap = BitmapFactory.decodeFile(imagePath, options);
  // 利用ThumbnailUtils来创建缩略图,这里要指定要缩放哪个Bitmap对象
  bitmap = ThumbnailUtils.extractThumbnail(bitmap, width, height,
    ThumbnailUtils.OPTIONS_RECYCLE_INPUT);
  return bitmap;
 }

 /**
  * 获取视频的缩略图
  * 先通过ThumbnailUtils来创建一个视频的缩略图,然后再利用ThumbnailUtils来生成指定大小的缩略图。
  * 如果想要的缩略图的宽和高都小于MICRO_KIND,则类型要使用MICRO_KIND作为kind的值,这样会节省内存。
  * @param videoPath 视频的路径
  * @param width 指定输出视频缩略图的宽度
  * @param height 指定输出视频缩略图的高度度
  * @param kind 参照MediaStore.Images.Thumbnails类中的常量MINI_KIND和MICRO_KIND。
  *            其中,MINI_KIND: 512 x 384,MICRO_KIND: 96 x 96
  * @return 指定大小的视频缩略图
  */
 private Bitmap getVideoThumbnail(String videoPath, int width, int height,
   int kind) {
  Bitmap bitmap = null;
  // 获取视频的缩略图
  bitmap = ThumbnailUtils.createVideoThumbnail(videoPath, kind);
  System.out.println("w"+bitmap.getWidth());
  System.out.println("h"+bitmap.getHeight());
  bitmap = ThumbnailUtils.extractThumbnail(bitmap, width, height,
    ThumbnailUtils.OPTIONS_RECYCLE_INPUT);
  return bitmap;
 }
 
}



Android的WebSettings的getUserAgentString方法
getUserAgentString.java 外部引用原始文档
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
public synchronized String getUserAgentString() {
    if (DESKTOP_USERAGENT.equals(mUserAgent) ||
            IPHONE_USERAGENT.equals(mUserAgent) ||
            !mUseDefaultUserAgent) {
        return mUserAgent;
    }

    boolean doPostSync = false;
    synchronized(sLockForLocaleSettings) {
       Locale currentLocale = Locale.getDefault();
       if (!sLocale.equals(currentLocale)) {
           sLocale = currentLocale;
           mUserAgent = getCurrentUserAgent();
           mAcceptLanguage = getCurrentAcceptLanguage();
           doPostSync = true;
       }
   }
   if (doPostSync) {
       postSync();
   }
   return mUserAgent;
}

private synchronized String getCurrentUserAgent() {
    Locale locale;
    synchronized(sLockForLocaleSettings) {
        locale = sLocale;
    }
    StringBuffer buffer = new StringBuffer();
    // Add version
    final String version = Build.VERSION.RELEASE;
    if (version.length() > 0) {
        buffer.append(version);
    } else {
        // default to "1.0"
        buffer.append("1.0");
    }  
    buffer.append("; ");
    final String language = locale.getLanguage();
    if (language != null) {
        buffer.append(language.toLowerCase());
        final String country = locale.getCountry();
        if (country != null) {
            buffer.append("-");
            buffer.append(country.toLowerCase());
        }
    } else {
        // default to "en"
        buffer.append("en");
    }
    
    final String model = Build.MODEL;
    if (model.length() > 0) {
        buffer.append("; ");
        buffer.append(model);
    }
    final String id = Build.ID;
    if (id.length() > 0) {
        buffer.append(" Build/");
        buffer.append(id);
    }
    final String base = mContext.getResources().getText(
            com.android.internal.R.string.web_user_agent).toString();
    return String.format(base, buffer);
}



android webview 自定client
MyWebViewClient.java 外部引用原始文档
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
private class MyWebViewClient extends WebViewClient {
  public boolean shouldOverrideUrlLoading(WebView view , String url){
       if (Uri.parse(url).getHost().equals("")) {
           return false;
       }
       Intent intent = new Intent(Intent.ACTION_VIEW , Uri.parse(url));
       startActivity(intent);
       return true;
   }
}
 
webView.setWebViewClient(new MyWebViewClient());



DefaultHttpClient使用概览
DefaultHttpClient.java 外部引用原始文档
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
try {
	DefaultHttpClient client = new DefaultHttpClient();
	HttpGet request = new HttpGet("http://www.google.com");
	HttpResponse response = client.execute(request);
 
	InputStream content = response.getEntity().getContent();
 
	// ...
 
} catch (ClientProtocolException e) {
	e.printStackTrace();
} catch (IOException e) {
	e.printStackTrace();
}
MainActivity.java 外部引用原始文档
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
public class MainActivity extends Activity {
 
	private TextView myTextView;
 
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
 
		myTextView = (TextView) findViewById(R.id.my_text_view);
 
		myTextView.setText(R.string.hello_world);
	}
}
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity" >
 
    <TextView
        android:id="@+id/my_text_view"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:text="@string/hello_world" />
 
</RelativeLayout>
R-strings.xml 外部引用原始文档
1
2
3
4
5
6
7
<?xml version="1.0" encoding="utf-8"?>
<resources>
 
    <string name="app_name">Example</string>
    <string name="hello_world">Hello world!</string>
 
</resources>
async-task.java 外部引用原始文档
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
private class ParlezVousTask extends AsyncTask<String, Void, Boolean> {
 
	@Override
	protected void onPreExecute() {
		// exécuté dans l'UIThread
	}
 
	@Override
	protected Boolean doInBackground(String... params) {
 
		// exécuté sur un autre thread
 
		return true;
	}
 
	@Override
	protected void onPostExecute(Boolean result) {
		// exécuté dans l'UIThread
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值