Android安卓PAD平板专用QQ破解版下载
下载地址:http://u.115.com/file/f6bc0f0b51#
cdDJR_qqforpad_android.apk
原载:http://www.anzhuo.cn/thread-12302-1-1.html
Wizzer's Blog
下载地址:http://u.115.com/file/f6bc0f0b51#
cdDJR_qqforpad_android.apk
原载:http://www.anzhuo.cn/thread-12302-1-1.html
Google Android开发团队的老大安迪鲁宾此前已经透露Android 2.3即将在12月6日发布,眼看日子越来越近了,大家对Andriod 2.3都抱着什么样的心情?来看看Android 2.3姜饼系统令人为之兴奋的十大理由:
1. 新加入的视频聊天功能
鉴于FaceTime让苹果有很多谈资,Google打算在2.3版系统中加入视频聊天功能予以回击。这意味着Google特意作出一款应用来与苹 果竞争,当然会不会用就看你自己的选择了。苹果或许认为他们已把视频聊天做的完美无缺了,但Google会不会带来新的惊喜,我们拭目以待。
2. 应用程序与系统更加融为一体
Android最大的缺点之一就是其应用看起来不像是系统的功能或是系统一部分,而更多的像是一些小扩展。Phandroid最近声称,Google将彻底对应用套件进行革新,使得其设计风格更加统一,类似于iOS的感觉。
3. 全面反击苹果
最近几个月,iOS 4.1和4.2抓住了智能手机领域的主动权。姜饼将在圣诞节前夕这一关键时期给Android一轮猛烈的宣传攻势,同时也希望与那些在智能手机大战中还没选定方向的大佬们达成共识。
4. 设计力求简洁
Android是高手,但是iOS在视觉和感觉方面确实要更好一些。无论如何,姜饼会有一个改进了的系统通知栏,同时用Android的绿色取代了 以前单调,容易让人觉得疲倦、难受的的瓦灰色。随着Palm以前的web OS UI(Palm webOS是一个嵌入式操作系统,以Linux内核为主体并加上部份Palm公司开发的专有软件)工程师来加入Google,我们可以期待更加华丽的体 验。
5. 自定义外观的终结
自从姜饼在今年夏天第一次被提起开始,已经有了大量关于深层社交网络一体化及时髦的UI设计的讨论。这意味着OEM厂商不再觉得有使用其自定义外观的必要。更重要的是,这意味着在未来等待更新系统的情况应该会大幅减少。
6. Android平板电脑长什么样儿
Google曾多次指出Froyo(Android 2.2系统代号)并不是为平板电脑而开发,同时暗示姜饼是。虽然平板电脑操作系统的新版本要等到1月份,但新版本的发布应该会给我们清晰地指出真正的Android平板与ipad的竞争格局会是什么样子。
7. 引发竞争对手提升游戏
永远不要低估一个新的操作系统可能带给对手的恐慌以及最终促使他们提供更新更好服务的能力。姜饼必将会影响苹果对于iOS4.X及后续系统的计划,而诺基亚无疑也会考虑如何在来年的MeeGo系统中包含类似的功能。
8. 速度才是关键
据传,只有运行512M内存和1G处理器的手机才会受邀参加姜饼的聚会。虽然这引起了不少的质疑,但同时也意味着使用姜饼系统的手机将都是最高端的手机。
9. 丰富多样的新机
尽管目前为止只有HTC Desire HD及Desire Z采用姜饼系统,而Galaxy S也仅仅配备了Android 2.2。但相信会有更多新手机会采用最新的姜饼系统。关于三星制造的Nexus 2最先采用姜饼系统的消息随处可见。随着圣诞节的来临,希望会有更多的进展。
10. 当前的Android手机将获得更多功能
如果你的手机符合姜饼的系统要求,那么姜饼会让你重新爱上你手里那款“年迈”的Android手机。不过你也不要指望三星、HTC、索爱等厂商最近几个月内能拿出什么好东西。
摘自:http://www.74phone.com/?p=495
是Android上的一个新浪微博的客户端,目的是实现手机上街拍发布图片和地理位置信息到微博的功能。
现阶段主要实现以下功能:
1. 通过MyCity拍照,可以把图片发布到微博
2. 通过MyCity获得GPS地理位置,分享到微博(通过google地图展示)
3. 用户可以附加100字以内的说明文字
下载地址: /MyCity.apk
使用说明:
按MENU键或第一次按发布键绑定微博帐号,进行拍照后附加文字发布微博,若在室外空旷处运行获得GPS地理位置信息后程序会自动在微博内容中添加google地图链接。
更新日志:
1、2010-11-18 9:00 修改位置信息未添加到微博中的bug,囧,我的错。
要特别注意,图片的文件名要为 pic 才会被新浪接收。
Map map = new HashMap(); map.put("source", "appkey");//改成自己的key map.put("status", txt); postImg("http://api.t.sina.com.cn/statuses/upload.json",map,Environment.getExternalStorageDirectory()+ "/temp.jpg" ,"帐号名字","密码");
/** * 直接通过HTTP协议提交数据到服务器,实现表单提交功能 * @param actionUrl 上传路径 * @param params 请求参数 key为参数名,value为参数值 * @param filename 上传文件 * @param username 用户名 * @param password 密码 */ private void postImg(String actionUrl,Map<String, String> params, String filename,String username,String password) { try { String BOUNDARY = "--------------et567z"; //数据分隔线 String MULTIPART_FORM_DATA = "Multipart/form-data"; URL url = new URL(actionUrl); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setDoInput(true);//允许输入 conn.setDoOutput(true);//允许输出 conn.setUseCaches(false);//不使用Cache conn.setRequestMethod("POST"); conn.setRequestProperty("Connection", "Keep-Alive"); conn.setRequestProperty("Charset", "UTF-8"); conn.setRequestProperty("Content-Type", MULTIPART_FORM_DATA + ";boundary=" + BOUNDARY); String usernamePassword=username+":"+password; conn.setRequestProperty("Authorization","Basic "+new String(SecBase64.encode(usernamePassword.getBytes()))); StringBuilder sb = new StringBuilder(); //上传的表单参数部分,格式请参考文章 for (Map.Entry<String, String> entry : params.entrySet()) {//构建表单字段内容 sb.append("--"); sb.append(BOUNDARY); sb.append("\r\n"); sb.append("Content-Disposition: form-data; name=\""+ entry.getKey() + "\"\r\n\r\n"); sb.append(entry.getValue()); sb.append("\r\n"); } // System.out.println(sb.toString()); DataOutputStream outStream = new DataOutputStream(conn.getOutputStream()); outStream.write(sb.toString().getBytes());//发送表单字段数据 byte[] content = readFileImage(filename); //上传的文件部分,格式请参考文章 //System.out.println("content:"+content.toString()); StringBuilder split = new StringBuilder(); split.append("--"); split.append(BOUNDARY); split.append("\r\n"); split.append("Content-Disposition: form-data;name=\"pic\";filename=\"temp.jpg\"\r\n"); split.append("Content-Type: image/jpg\r\n\r\n"); System.out.println(split.toString()); outStream.write(split.toString().getBytes()); outStream.write(content, 0, content.length); outStream.write("\r\n".getBytes()); byte[] end_data = ("--" + BOUNDARY + "--\r\n").getBytes();//数据结束标志 outStream.write(end_data); outStream.flush(); int cah = conn.getResponseCode(); // if (cah != 200) throw new RuntimeException("请求url失败:"+cah); if(cah == 200)//如果发布成功则提示成功 { /*读返回数据*/ //String strResult = EntityUtils.toString(httpResponse.getEntity()); new AlertDialog.Builder(Main.this) // Main.this视情况而定,这个一般是指当前显示的Activity对应的XML视窗。 .setTitle("")// 设置对话框的标题 .setPositiveButton("确定",// 设置对话框的确认按钮 new DialogInterface.OnClickListener() {// 设置确认按钮的事件 public void onClick(DialogInterface dialog, int which) { }}) .setMessage(" 发布成功 ")// 设置对话框的内容 .show(); } else if(cah == 400) { new AlertDialog.Builder(Main.this) // Main.this视情况而定,这个一般是指当前显示的Activity对应的XML视窗。 .setTitle("")// 设置对话框的标题 .setPositiveButton("确定",// 设置对话框的确认按钮 new DialogInterface.OnClickListener() {// 设置确认按钮的事件 public void onClick(DialogInterface dialog, int which) { }}) .setMessage(" 发布失败 \n 不可连续发布相同内容 ")// 设置对话框的内容 .show(); }else{ throw new RuntimeException("请求url失败:"+cah); } // InputStream is = conn.getInputStream(); // int ch; // StringBuilder b = new StringBuilder(); // while( (ch = is.read()) != -1 ){ // b.append((char)ch); // } outStream.close(); conn.disconnect(); } catch (IOException e) { e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } } public static byte[] readFileImage(String filename) throws IOException { BufferedInputStream bufferedInputStream = new BufferedInputStream( new FileInputStream(filename)); int len = bufferedInputStream.available(); byte[] bytes = new byte[len]; int r = bufferedInputStream.read(bytes); if (len != r) { bytes = null; throw new IOException("读取文件不正确"); } bufferedInputStream.close(); return bytes; }
//POST发布文本信息 public void sendMsg(String status,String username,String password){ HttpClient httpclient = new DefaultHttpClient(); HttpPost httppost = new HttpPost("http://api.t.sina.com.cn/statuses/update.json"); //NameValuePair实现请求参数的封装 List params = new ArrayList (); params.add(new BasicNameValuePair("source", "4016954419")); params.add(new BasicNameValuePair("status", status)); try { //添加请求参数到请求对象 httppost.setEntity(new UrlEncodedFormEntity(params, HTTP.UTF_8)); httppost.getParams().setBooleanParameter(CoreProtocolPNames.USE_EXPECT_CONTINUE, false); String data=username+":"+password; httppost.addHeader("Authorization","Basic "+new String(SecBase64.encode(data.getBytes()))); httppost.addHeader("Content-Type", "application/x-www-form-urlencoded"); //发送请求并等待响应 HttpResponse httpResponse = new DefaultHttpClient().execute(httppost); //若状态码为200 ok if(httpResponse.getStatusLine().getStatusCode() == 200) { //读返回数据 //String strResult = EntityUtils.toString(httpResponse.getEntity()); new AlertDialog.Builder(Main.this) // Main.this视情况而定,这个一般是指当前显示的Activity对应的XML视窗。 .setTitle("")// 设置对话框的标题 .setPositiveButton("确定",// 设置对话框的确认按钮 new DialogInterface.OnClickListener() {// 设置确认按钮的事件 public void onClick(DialogInterface dialog, int which) { }}) .setMessage(" 发布成功 ")// 设置对话框的内容 .show(); } else if(httpResponse.getStatusLine().getStatusCode() == 400) { new AlertDialog.Builder(Main.this) // Main.this视情况而定,这个一般是指当前显示的Activity对应的XML视窗。 .setTitle("")// 设置对话框的标题 .setPositiveButton("确定",// 设置对话框的确认按钮 new DialogInterface.OnClickListener() {// 设置确认按钮的事件 public void onClick(DialogInterface dialog, int which) { }}) .setMessage(" 发布失败 \n 不可连续发布相同内容 ")// 设置对话框的内容 .show(); } } catch (ClientProtocolException e) { e.printStackTrace(); et.setText(et.getText()+" Error1:"+e.getMessage()); } catch (IOException e) { e.printStackTrace(); et.setText(et.getText()+" Error2:"+e.getMessage()); } catch (Exception e) { e.printStackTrace(); et.setText(et.getText()+" Error3:"+e.getMessage()); } }
package wizzer.cn.app; public class SecBase64 { private static final byte[] encodingTable = { (byte) 'A', (byte) 'B', (byte) 'C', (byte) 'D', (byte) 'E', (byte) 'F', (byte) 'G', (byte) 'H', (byte) 'I', (byte) 'J', (byte) 'K', (byte) 'L', (byte) 'M', (byte) 'N', (byte) 'O', (byte) 'P', (byte) 'Q', (byte) 'R', (byte) 'S', (byte) 'T', (byte) 'U', (byte) 'V', (byte) 'W', (byte) 'X', (byte) 'Y', (byte) 'Z', (byte) 'a', (byte) 'b', (byte) 'c', (byte) 'd', (byte) 'e', (byte) 'f', (byte) 'g', (byte) 'h', (byte) 'i', (byte) 'j', (byte) 'k', (byte) 'l', (byte) 'm', (byte) 'n', (byte) 'o', (byte) 'p', (byte) 'q', (byte) 'r', (byte) 's', (byte) 't', (byte) 'u', (byte) 'v', (byte) 'w', (byte) 'x', (byte) 'y', (byte) 'z', (byte) '0', (byte) '1', (byte) '2', (byte) '3', (byte) '4', (byte) '5', (byte) '6', (byte) '7', (byte) '8', (byte) '9', (byte) '+', (byte) '/' }; private static final byte[] decodingTable; static { decodingTable = new byte[128]; for (int i = 0; i < 128; i++) { decodingTable[i] = (byte) -1; } for (int i = 'A'; i <= 'Z'; i++) { decodingTable[i] = (byte) (i - 'A'); } for (int i = 'a'; i <= 'z'; i++) { decodingTable[i] = (byte) (i - 'a' + 26); } for (int i = '0'; i <= '9'; i++) { decodingTable[i] = (byte) (i - '0' + 52); } decodingTable['+'] = 62; decodingTable['/'] = 63; } //加密 public static byte[] encode(byte[] data) { byte[] bytes; int modulus = data.length % 3; if (modulus == 0) { bytes = new byte[(4 * data.length) / 3]; } else { bytes = new byte[4 * ((data.length / 3) + 1)]; } int dataLength = (data.length - modulus); int a1; int a2; int a3; for (int i = 0, j = 0; i < dataLength; i += 3, j += 4) { a1 = data[i] & 0xff; a2 = data[i + 1] & 0xff; a3 = data[i + 2] & 0xff; bytes[j] = encodingTable[(a1 >>> 2) & 0x3f]; bytes[j + 1] = encodingTable[((a1 << 4) | (a2 >>> 4)) & 0x3f]; bytes[j + 2] = encodingTable[((a2 << 2) | (a3 >>> 6)) & 0x3f]; bytes[j + 3] = encodingTable[a3 & 0x3f]; } int b1; int b2; int b3; int d1; int d2; switch (modulus) { case 0: break; case 1: d1 = data[data.length - 1] & 0xff; b1 = (d1 >>> 2) & 0x3f; b2 = (d1 << 4) & 0x3f; bytes[bytes.length - 4] = encodingTable[b1]; bytes[bytes.length - 3] = encodingTable[b2]; bytes[bytes.length - 2] = (byte) '='; bytes[bytes.length - 1] = (byte) '='; break; case 2: d1 = data[data.length - 2] & 0xff; d2 = data[data.length - 1] & 0xff; b1 = (d1 >>> 2) & 0x3f; b2 = ((d1 << 4) | (d2 >>> 4)) & 0x3f; b3 = (d2 << 2) & 0x3f; bytes[bytes.length - 4] = encodingTable[b1]; bytes[bytes.length - 3] = encodingTable[b2]; bytes[bytes.length - 2] = encodingTable[b3]; bytes[bytes.length - 1] = (byte) '='; break; } return bytes; } //解密 public static byte[] decode(byte[] data) { byte[] bytes; byte b1; byte b2; byte b3; byte b4; data = discardNonBase64Bytes(data); if (data[data.length - 2] == '=') { bytes = new byte[(((data.length / 4) - 1) * 3) + 1]; } else if (data[data.length - 1] == '=') { bytes = new byte[(((data.length / 4) - 1) * 3) + 2]; } else { bytes = new byte[((data.length / 4) * 3)]; } for (int i = 0, j = 0; i < (data.length - 4); i += 4, j += 3) { b1 = decodingTable[data[i]]; b2 = decodingTable[data[i + 1]]; b3 = decodingTable[data[i + 2]]; b4 = decodingTable[data[i + 3]]; bytes[j] = (byte) ((b1 << 2) | (b2 >> 4)); bytes[j + 1] = (byte) ((b2 << 4) | (b3 >> 2)); bytes[j + 2] = (byte) ((b3 << 6) | b4); } if (data[data.length - 2] == '=') { b1 = decodingTable[data[data.length - 4]]; b2 = decodingTable[data[data.length - 3]]; bytes[bytes.length - 1] = (byte) ((b1 << 2) | (b2 >> 4)); } else if (data[data.length - 1] == '=') { b1 = decodingTable[data[data.length - 4]]; b2 = decodingTable[data[data.length - 3]]; b3 = decodingTable[data[data.length - 2]]; bytes[bytes.length - 2] = (byte) ((b1 << 2) | (b2 >> 4)); bytes[bytes.length - 1] = (byte) ((b2 << 4) | (b3 >> 2)); } else { b1 = decodingTable[data[data.length - 4]]; b2 = decodingTable[data[data.length - 3]]; b3 = decodingTable[data[data.length - 2]]; b4 = decodingTable[data[data.length - 1]]; bytes[bytes.length - 3] = (byte) ((b1 << 2) | (b2 >> 4)); bytes[bytes.length - 2] = (byte) ((b2 << 4) | (b3 >> 2)); bytes[bytes.length - 1] = (byte) ((b3 << 6) | b4); } return bytes; } //解密 public static byte[] decode(String data) { byte[] bytes; byte b1; byte b2; byte b3; byte b4; data = discardNonBase64Chars(data); if (data.charAt(data.length() - 2) == '=') { bytes = new byte[(((data.length() / 4) - 1) * 3) + 1]; } else if (data.charAt(data.length() - 1) == '=') { bytes = new byte[(((data.length() / 4) - 1) * 3) + 2]; } else { bytes = new byte[((data.length() / 4) * 3)]; } for (int i = 0, j = 0; i < (data.length() - 4); i += 4, j += 3) { b1 = decodingTable[data.charAt(i)]; b2 = decodingTable[data.charAt(i + 1)]; b3 = decodingTable[data.charAt(i + 2)]; b4 = decodingTable[data.charAt(i + 3)]; bytes[j] = (byte) ((b1 << 2) | (b2 >> 4)); bytes[j + 1] = (byte) ((b2 << 4) | (b3 >> 2)); bytes[j + 2] = (byte) ((b3 << 6) | b4); } if (data.charAt(data.length() - 2) == '=') { b1 = decodingTable[data.charAt(data.length() - 4)]; b2 = decodingTable[data.charAt(data.length() - 3)]; bytes[bytes.length - 1] = (byte) ((b1 << 2) | (b2 >> 4)); } else if (data.charAt(data.length() - 1) == '=') { b1 = decodingTable[data.charAt(data.length() - 4)]; b2 = decodingTable[data.charAt(data.length() - 3)]; b3 = decodingTable[data.charAt(data.length() - 2)]; bytes[bytes.length - 2] = (byte) ((b1 << 2) | (b2 >> 4)); bytes[bytes.length - 1] = (byte) ((b2 << 4) | (b3 >> 2)); } else { b1 = decodingTable[data.charAt(data.length() - 4)]; b2 = decodingTable[data.charAt(data.length() - 3)]; b3 = decodingTable[data.charAt(data.length() - 2)]; b4 = decodingTable[data.charAt(data.length() - 1)]; bytes[bytes.length - 3] = (byte) ((b1 << 2) | (b2 >> 4)); bytes[bytes.length - 2] = (byte) ((b2 << 4) | (b3 >> 2)); bytes[bytes.length - 1] = (byte) ((b3 << 6) | b4); } return bytes; } private static byte[] discardNonBase64Bytes(byte[] data) { byte[] temp = new byte[data.length]; int bytesCopied = 0; for (int i = 0; i < data.length; i++) { if (isValidBase64Byte(data[i])) { temp[bytesCopied++] = data[i]; } } byte[] newData = new byte[bytesCopied]; System.arraycopy(temp, 0, newData, 0, bytesCopied); return newData; } private static String discardNonBase64Chars(String data) { StringBuffer sb = new StringBuffer(); int length = data.length(); for (int i = 0; i < length; i++) { if (isValidBase64Byte((byte) (data.charAt(i)))) { sb.append(data.charAt(i)); } } return sb.toString(); } private static boolean isValidBase64Byte(byte b) { if (b == '=') { return true; } else if ((b < 0) || (b >= 128)) { return false; } else if (decodingTable[b] == -1) { return false; } return true; } //测试类 public static void main(String[] args) { String data = "wizzer@qq.com:etpass"; byte[] result = SecBase64.encode(data.getBytes());// 加密 System.out.println("Basic "+data); System.out.println("Basic "+new String(result)); System.out.println(new String(SecBase64.decode(new String(result))));// 解密 } }
private void getLocation() { LocationManager locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE); locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 200, 0, locationListener); } private final LocationListener locationListener = new LocationListener() { public void onLocationChanged(Location location) { //当坐标改变时触发此函数,如果Provider传进相同的坐标,它就不会被触发 // log it when the location changes if (location != null) { Lat.setText(String.valueOf(location.getLatitude())); Lon.setText(String.valueOf(location.getLongitude())); } } public void onProviderDisabled(String provider) { // Provider被disable时触发此函数,比如GPS被关闭 } public void onProviderEnabled(String provider) { // Provider被enable时触发此函数,比如GPS被打开 } public void onStatusChanged(String provider, int status, Bundle extras) { // Provider的转态在可用、暂时不可用和无服务三个状态直接切换时触发此函数 } };
public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // Hide the window title. requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.main); imageView = (ImageView) this.findViewById(R.id.iv1); Button button = (Button) this.findViewById(R.id.bt1); button.setOnClickListener(new OnClickListener() { public void onClick(View v) { Intent intent = new Intent("android.media.action.IMAGE_CAPTURE"); intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri .fromFile(new File(Environment .getExternalStorageDirectory(), "temp.jpg"))); intent.putExtra(MediaStore.EXTRA_VIDEO_QUALITY, 0); startActivityForResult(intent, 0); } }); } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { if (requestCode == 0 && resultCode == Activity.RESULT_OK) { this.imageView.setImageDrawable(Drawable.createFromPath(new File( Environment.getExternalStorageDirectory(), "temp.jpg") .getAbsolutePath())); } }
public boolean onKeyDown(int keyCode, KeyEvent event) { //按下键盘上返回按钮 if(keyCode == KeyEvent.KEYCODE_BACK){ new AlertDialog.Builder(Main.this) // Main.this视情况而定,这个一般是指当前显示的Activity对应的XML视窗。 .setTitle("")// 设置对话框的标题 .setMessage(" 确定退出? ")// 设置对话框的内容 .setPositiveButton("确定",// 设置对话框的确认按钮 new DialogInterface.OnClickListener() {// 设置确认按钮的事件 public void onClick(DialogInterface dialog, int which) { //退出程序 android.os.Process.killProcess(android.os.Process.myPid()); }}) .setNegativeButton("取消",// 设置对话框的取消按钮 new DialogInterface.OnClickListener() {// 设置取消按钮的事件 public void onClick(DialogInterface dialog, int which) { // 如果你什么操作都不做,可以选择不写入任何代码 dialog.cancel(); }} ).show(); return true; }else{ return super.onKeyDown(keyCode, event); } }
Android产品主管Gaurav Jain在今年7月份时候谈及Google音乐服务的时候曾表示,该服务将于下一代智能手机操作系统Android 2.3(开发代号Gingerbread姜饼)一起发布,日期初步定在今年第四季度。如今第四季度已经过了快一半了,Android 2.3呢?
今天,国外IT网站Intomobile爆料称,据可信来源证实,Gingerbread SDK将在11月11日发布,刚好于首款采用该系统的三星Nexus Two的发布日期相近。
上月底,Google在公司总部前的草坪上新增了姜饼小人的雕塑,按照惯例,这款系统不久就会发布了。而近日发布的Google Maps 4.6版应用中也隐藏了新系统的一些踪迹,有人指出目前这款应用已经内置了部分Android 2.3版系统的界面元素。种种迹象表明,Android 2.3确实已经不远了。(来源:驱动之家[原创])
你以为 Android 是开放的吗?Google 采用了一系列的控制手段来保证每一部 Android 手机上都有它指定的软件和硬件规格。然而,他们同时又利用 Android SDK 里面的 Apache 许可证来大肆鼓吹 Android 是开放的。
没错,Google 的移动平台是当前最聪明的利用开源来驱动商业议程的实现。但在我们深入探讨这个为什么之前,我们先说说为什么 Android 的成功和开源并没有什么关系吧。
是什么成就了 Android
虽然早期饱受质疑,Google 的 Android 移动平台已经在移动行业得到了营运商和手机厂商的广泛支持,仅剩固执的诺基亚。Android 从 08 年的一款机型发展到 10 年的 50 多款,发展之快让绝大多数的业内观察家们吃惊。
Android 的成功和开源毫无关系。它的成功依靠下列三个主要因素:
JAVA手机网[www.cnjm.net] - 苹果. 这点看起来很奇怪,Android 竟然是靠它的主要对手发家的?让我来分析下。在 iPhone 空前绝后的成功以及苹果对网络营运商傲慢苛刻的态度下,营运商们迫切的在寻找一种更便宜的选择。因此这些第一层最大的营运商们开始积极的用 Android 来开发手机给那些买不起 iPhone 的用户,更重要的是,他们不需要每卖一部手机就给 Apple 300 欧元以上的回扣。
- 全世界的营运商们迫切希望自己鹤立鸡群. Android 给他们提供了一个统一的软件平台。他们可以很方便的定制自己想要的系统,而且花费的代价也很低(3 个月的时间,这个比 SavaJe 12 个月以上的定制周期要短很多)。对大型的营运商来说,Android 也降低了他们在智能手机软件方面的投资。这也是为什么大多数的 Android 手机项目背后都是营运商和 OEM 厂商的组合。
JAVA手机网[www.cnjm.net] - 高通. 这个市值 100 亿美元的芯片厂商对 Android 的崛起功不可没。手机开发产商可以直接拿高通已经为 Android 集成好的方案,在 9-12 个月的时间内向市场上推广。(相比起来摩托罗拉的 CLIQ 花了 16 个月,而 HTC G1 则花费了 2 年多的时间)。除了高通,我们还有 TI 的 OMAP3 平台(摩托罗拉 Droid/Milestone 基于此方案)。ST Ericsson 和 Broadcom 也在做 Android 的集成方案。
JAVA手机网[www.cnjm.net]
换句话说,在 Android 手机上,大多数的 OEM 预算花在了定制方面。而 Symbian 的绝大部分预算花在无线通信的移植和硬件整合上了(Symbian 2001 年所做决定的结果)。总的来说,Android 使 OEM 厂商可以大幅削减研发预算,把钱花在定制这个刀刃上。当然我们不能忘记 Android 是免费的。这个免费让众多厂商激动不已。
话说回来,Android 用开源来做市场宣传,非常成功的搅乱了整个行业,导致了诺基亚对 Symbian 的收购以及 Windows Mobile 的全面崩溃(不过译者觉得 iPhone OS 4 的多重任务机制的发布让 WP7 真正成了杯具帝)。不过更重要的是,利用开源的名号和 Google 的魅力,Android 吸引了成千上万的开发者,虽然 Android 并不能让开发者们赚到很多钱,而且 Android 手机的数量不到苹果产品的十分之一(连支持收费的国家都比苹果少6倍)。
在开源的面纱后面
让人更惊讶的是 Android 到底有多封闭,尽管外面包裹着 Google“不作恶”的口号和 Apache 授权许可证模式。借用亨利福特在 Model-T 相关的书里的一句话:“任何人都可以自由挑选 Android 的颜色,只要那是黑色”(anyone can have Android in their own colour as long as it’s black)。Android 是一个绝好的商业案例——展现一家公司是如何用开源来赢得关注和社区参与,而且同时保持一个非常严密的商业运作。
JAVA手机网[www.cnjm.net] Google 是如何控制着每台 Android 手机里采用什么服务、软件和硬件的?这个搜索巨人建立了一套很完善的控制管理系统。为了挖掘更多的信息,我们花了两个月,和很多与 Android 有着紧密联系的内部人士进行了讨论。我们发掘出的事实让人震惊。从宏观方面说,Google 控制 Android 手机构成以下八宗罪:
1. 私有分支. Android 有多个私有分支,这些只给几个特定合作伙伴,往往是那些开发 Android 的 OEM 厂商,而且这些只提供给需要知道的人。这些私有分支比已经公布的 SDK 要超前起码 6 个月,也是 OEM 厂商可以保持竞争力的关键。而公开的 SDK 则是为第三方应用提供私有分支里发布的最新功能。
2. 封闭的评估流程. 所有的代码评估员似乎都是 Google 员工,也就是说从社区提交的代码只有 Google 才有权力决定是否接受。而且 Google 内部还流传着“并非此处发明”的一种思考文化,他们觉得 Google 员工写的代码是天下无敌。随便问任何一个给 Android 提交过补丁的人,你会得到一样的答复:几乎没有什么提交被 Google 接受,而被拒绝的时候往往没有任何理由和解释。
3. 进化的速度. Google 对 Android 的创新的速度是移动行业内绝无仅有的,他们在 18 个月里发布了四个大版本。想在 Android 上面做文章的 OEM 厂商只得紧跟 Google 的步伐(这里想起了移动杯具的OMS),不然就跟不上新功能的发布和 bug 修复。Nexus One、Droid、G1 和其它带有 Google体验应用的手机给 Google 提供了创新的测试场。
4. 不完善的软件. 用公开的 SDK 并不能完整的建造手机。缺少的几个关键的部份包括无线通信的集成模块、国际化语言包、营运商信息包以及闭源的 Google 应用,比如 Market、Gmail 和 Gtalk。虽然 Cyanogen 可以自己定制 ROM,但里面包含的那些应用没有授权,所以不能发布在商业用途的 Android 手机上。
5. 闭门的开发者社区. Android Market 是唯一一个拥有超过四万个程序并和每个手机 OEM 厂商都签有合约的 android 程序商店。这个限制很要命,因为没有一个 OEM 厂商愿意发布没有 Market 的 Android 手机(天朝是另类)。当然,在 Market 上发布应用是个非常简单的事情,没有什么审批的步骤,这个和苹果的 AppStore 刚好相反。
6. 反分化合约. 外界几乎不清楚原来 OHA 的成员都签署了反分化的合约。但这个合约更可以被理解为不能发布没有通过 CTS 兼容测试的手机。(下面细说 CTS)(译者注:貌似中国移动已经被踢出 Android 的私有分支,是不是因为他们建立的 OMS 违反了这个协定呢?)
7. 保密的发展蓝图. Android 的发展蓝图是很杯具的,到目前为止,公开发布的发展蓝图还停留在 2009 年的第一季度。如果想要看到内部的发展蓝图,你需要 Google 的赐福.
8. Android 商标. Google 掌握着 Android 的注册商标和冠名权。任何想用 Android 品牌的厂商都需要得到Google的授权。简单的说:进 Google 的门,或者没有门。如果你要自己做 Android 分枝,你就全部靠自己了,比如你需要中国移动那么大的公司。
Android 的传奇中还有个大篇章:CTS(兼容测试组),也就是 Google 一套测试 Android 手机是不是达到 Google 的标准。根据我们的线人消息,CTS 不仅仅测试软件的 API 部份,它还包括性能测试,硬件功能,设备设计,UI 用户界面需求,和机内打包的服务。CTS 决定了你可以添加额外功能,但不能从最基础的配置中削减功能。除了 CTS 以外,OEM 厂商还要和 Google 签订授权合同,这样他们才能打包 Google 的服务,比如 Gmail、YouTube 等等。
CTS 限制了 OEM 定制弱化版 Android 手机的想法(译者注:山寨的机会啊!MTK、中微星,年底发布些低端 Android 手机吧!)。这也大大限制了 Android 开拓低端市场的能力。CTS 和向前兼容 4 万多个应用的事实,极大的挑战着 Google 想占领智能手机市场2位数的市场份额目标。这些限制,还有 Google 与 OEM 亦敌亦友的合作关系,使得 OEM 圈内掀起了建立 Android 基金的讨论。
Google 的终极目标
手握 Android,Google 的目标是为自己产生收入的服务提供一个稳定的平台。在当前,这个广告生意。但未来,Google 的目标在语音服务(几十亿没有数据服务的用户)和 Google Checkout(比如变成移动领域的 visa 卡)。但不管 Google 的终极目标是什么,我们应该意识到 Android 和 Windows Mobile、Mac OSX 或 PalmOS 相比,并没有开放多少。Android 是用开源来驱动商业议程的最聪明的案例之一。Android 骨子里并没有我们潜意识里所灌输的那么多不作恶思想。
方法1:用魅族的PC同步工具,把联系人导出来,xls的格式(Excel)
或方法2:M8备份文件夹Contact下Contact.xml文件提取联系人为xls
可以使用M8XML2EXCEL软件,下载地址:http://bbs.meizu.cn/thread-1921470-1-1.html
打开XLS文件,选择文件-存–其他格式,选择CSV文件,提示选择是即可
方法1:通过Gmail帐户同步;
或方法2:Gmail导出VCF文件,拷贝到M8中,进Android联系人导入数据。
优蛋下载:http://u.115.com/file/f9a37da84d
此版本不支持公测版。
注意:刷机有风险,请普通用户不要下载使用,仅供发烧友测试评测。
版本特性:
1. 2d加速 OK
2. 3d 加速 part OK
3. 电量显示 OK
4. 震动 OK
5. ADB 调试 OK(可以使用91手机助手)
6. Wifi OK
7. LCD & 背光 Part OK(花屏问题)
8. 电话 短信 OK
9. Gprs OK
10. 声音 Part OK(存在部分问题)
11. 视频 not work
12. 电源管理 part OK
13. 启动画面修改
14 解决中文名乱码问题
预装软件:
安卓市场
Root文件管理器
Launcher Pro
ES文件管理器
任务管理器
HiAPN
UCWEB 7.2
如果大家不喜欢其中的软件,可以在设置中进行卸载。
1. 将xip.bin复制到/Disk目录下
2. 将mdroid_sepa.img复制到/Disk目录下
3. 刷机
4. 双启动界面选择android系统即可
注意:
1.系统启动后会扫描整个磁盘,可能导致发热和系统延迟,请尽量清除磁盘中无用资料,特别是小图片
2.如果软件无法全屏,请进入Spare Parts,将软件兼容模式(Compatibility Mode)选项去掉,重启后OK
3.长按Menu键可以进行0°,90°,180°和270°旋转
4.包中的zImage可能和面大的并不兼容。
5.双启动xip中CE的版本为9.9.17
6.由于没有使用pre-dexopt,程序第一次启动可能会比较慢
本项目SEPA小组负责成员:
雪夜刀手(http://hi.baidu.com/snownight)
阿虚(http://hi.baidu.com/aokikyon)
最新发布的谷歌 Android 2.2系统带来了Flash 10.1和更快的速度,这让不少Android系统手机用户充满了期待。然而,该系统版本或许在三个月后便会成为中低端机型的配置,而谷歌正准备通过更强大的Android 3.0新版本来装备高端机型。日前,根据俄罗斯著名手机网站mobile-review.com主编Eldar Murtazin最新披露的消息显示,开发代号为“Gingerbread(姜饼)”的Android 3.0系统将有望在10月中旬推出,并且支持该版本系统手机的最低硬件配置也已经新鲜出炉。
按照Eldar Murtazin披露的说法,Android 3.0系统版本的开发代号“姜饼”,可以工作在手机或者平板电脑上,而已经问世的 Android 2.1和2.2版本则会使用在低端智能手机之上。至于即将于10月中旬推出的Android 3.0版本的最低系统需求则是需要1GHz的处理器,512M内存和3.5英寸触控屏,当然它支持更大的屏幕和更高的分辨率。比如该版本系统将支持4.0 英寸屏幕和支持1280×760像素的高分辨率等等。除此之外,如过去传闻所说的那样,新版本会开发新的操作界面,预计将拥有一个同时支持多种设备的统一的界面,并且谷歌在Android 3.0版本系统中会关闭第三方用户界面的开发接口,比如我们熟悉的摩托罗拉的Motorblur和HTC Sense等等,这意味着所有第三方界面均无法运行在该版本之上。据悉,Android 3.0版本系统大约会在10月15日或是16日左右正式发布,首批支持该版本的机型则会在11月或是12月开始销售。