当前位置:  编程技术>移动开发
本页文章导读:
    ▪施用 symbolicatecrash 解析崩溃堆栈        使用 symbolicatecrash 解析崩溃堆栈确认Xcode的环境 /usr/bin/xcode-select -print-path结果应该是: /Applications/Xcode.app/Contents/Developer/如果结果不是上述的路径,则指定一下路径: sudo /usr/bin/xcode-select -swit.........
    ▪ 蓝牙配置文件跟协议(总则)        蓝牙配置文件和协议(总则)从本篇开始,会陆续介绍一些Bluetooth的profile和protocol,作为入门级的读物,具体详细的内容请参考: Bluetooth SIG Bluetooth Wiki Host和Controller 标记为Host的部.........
    ▪ 蓝牙通讯-打开和关闭蓝牙设备       蓝牙通信-打开和关闭蓝牙设备蓝牙(BlueTooth)要求的最低版本是android2.0,由于Android模拟器不支持蓝牙,运行蓝牙的有关应用必须在真机上测试运行。 蓝牙是一种重要的短距离无线通信协议,.........

[1]施用 symbolicatecrash 解析崩溃堆栈
    来源: 互联网  发布时间: 2014-02-18
使用 symbolicatecrash 解析崩溃堆栈
确认Xcode的环境
/usr/bin/xcode-select -print-path
结果应该是:
/Applications/Xcode.app/Contents/Developer/
如果结果不是上述的路径,则指定一下路径:
sudo /usr/bin/xcode-select -switch /Applications/Xcode.app/Contents/Developer/
准备好解析堆栈符号的工具:symbolicatecrash
以Xcode4.6版本为例,执行:
find /Applications/Xcode.app -name symbolicatecrash -type f
将会返回:
/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/PrivateFrameworks/DTDeviceKit.framework/Versions/A/Resources/symbolicatecrash
开始解析
准备好dSYM文件和app文件,可以存放在任何位置,只要mac系统的spotlight能够找到就行。
接着执行
symbolicatecrash xxx.crash
或者
symbolicatecrash xxx.plist
就可以解析符号了。
找不到符号的解决方法
Xcode找符号文件的时候,是通过mdfind来找的,所以先使用mdfind来确认你的符号文件能够被找到
mdfind 'com_apple_xcode_dsym_uuids = *'
该命令会把当前环境下的所有符号文件找出来,如果你的符号文件不在此列表中,那么就在执行symbolicatecrash的时候显式指定dSYM文件的路径:
symbolicatecrash xxx.crash xxx.dSYM

    
[2] 蓝牙配置文件跟协议(总则)
    来源: 互联网  发布时间: 2014-02-18
蓝牙配置文件和协议(总则)

从本篇开始,会陆续介绍一些Bluetooth的profile和protocol,作为入门级的读物,具体详细的内容请参考:


Bluetooth SIG

Bluetooth Wiki


如何使用蓝牙设备这样的说明就交由上述网站完成了,本站则致力于阐明各式协议(Protocol)及配置文件(Profile)的技术规范这样的内容。

首先,作为开篇的作品,将针对蓝牙协议层的结构进行概述说明。

Host和Controller

协议层的堆栈结构如上图所示。
虽然主要的结构这里都画出来了,但是也有还没表示出来的部分。

标记为Controller的部分,对应于蓝牙芯片部分。
个人电脑(PC)上用的USB适配器就属于此Controller。

标记为Host的部分,装载有可对Controller进行控制的软件。
如果对比PC上用的USB适配器的话,Host就是属于PC那一部分。

对于头戴式耳机和鼠标等有特定用途的情况,主要使用那些提供单芯片(含Host和Controller)的硬件产品。
为了实现小型化和削减成本,也销售名为HID配置文件,HSP/HFP配置文件专用的芯片。

HCI (Host Contoroller Interface)

本文仅讨论Controller以上的Host部分,所以先从HCI开始说明。

HCI是为了在Controller和Host之间进行通信用的协议。
和其他是为了与对方设备进行通信的协议不一样,仅有HCI是用作设备内部的通信的。
用在从Host到Controller进行传输的命令(Command),用在从Controller到Host进行传输的事件(Event)--二者之间的数据传送就是这样通过数据包(Packet)通信完成的。

HCI协议通过名为UART和USB的物理总线进行通信。
这些物理总线通过各种协议来进行通信,所以实际上HCI也正是在这些协议之上进行通信的。
对于包含配置文件在内的单芯片产品来说,一般认为其HCI部分是通过软件方式来进行通信的。

L2CAP (Logical Link Control and Adaptation Protocol)


L2CAP是为了对复数个链接进行管理的协议。
除了对若干个对方设备的链接进行管理之外,对同一个设备的若干个链接也进行管理。
对同一个设备的若干个链接进行管理的意思是说,比方同时打开了用作SDP通信的信道和用作RFCOMM通信的信道,为了这些信道彼此互不干扰而将其彼此区分而进行了管理。

SDP (Service Discovery Protocol)

使用蓝牙技术可以享受各种各样的服务,例如头戴式耳机,车载免提电话,拨号入网,输入设备,图像传送,音乐传送等等。
但是,这并不意味着所有的设备就可以支持所有的服务了。
SDP就是用来对对方设备究竟支持何种服务而进行检索的协议。

RFCOMM

RFCOMM是模拟RS232进行串口通信的协议。
它提供对RS232的各管脚信号的传送,以及复数端口的管理等功能。

有很多配置文件都使用了RFCOMM协议。
这些配置文件有SPP(Serial Port Profile), DNP(Dial-up Networking Profile), HSP(HeadSet Profile), HFP(Hands Free Profile), LAP(LAN Access Profile),以及包括OPP(Object Push Profile)在内的、使用OBEX协议的一些配置文件。

OBEX (Object Exchange Protocol)

OBEX是用作进行对象交换的协议,红外线通信也使用了此协议。
通过OBEX将HTTP的字符串以二进制方式进行传输,使得通信量得到了减少,所以感觉上就像是无线版的HTTP一样。
OPP(Object Push Profile), SYNC(Synchronization Profile), FTP(File Transfer Profile),BIP(Basic Imaging Profile)等配置文件使用了此协议。

配置文件(Profile)

配置文件(Profile)并不是协议(Protocol),它决定了如何提供/使用相应的服务。

尽管不能支持同样的配置文件的话肯定是无法进行通信的,但是由于在配置文件中,也划分了提供服务方和使用服务方两种不同的角色,所以也有必要加以注意。
比如在拨号上网的情况下,某一方是Dial-up Networking Profile中的网关(Gateway)侧(也即拨号上网的服务的提供方),如果另一方不支持数据终端(Data terminal)侧(也就是拨号上网服务的使用方)的话,也无法进行通信。

另外在配置文件中存在缺省功能和选项(Option)功能,配置文件也有可能不支持选项功能的实现。
比如虽然支持Object Push Profile,但是可能并不支持作为选项功能的文件推送(Push)传输。

下面列出了具有代表性的几种配置文件。

Generic Access Profile (GAP)

           提供了作为蓝牙设备基本功能的设备检索和安全性相关服务

Service Discovery Application Profile

           能检索为对方设备提供了何种服务

Serial Port Profile (SPP)

           将RS232的串口通信进行了无线化

Dial-up Networking Profile (DNP)

           进行拨号连接

LAN Access Profile (LAP)

           和对方设备进行LAN连接

FAX Profile

           通过无线方式使用FAX服务

Generic Object Exchange Profile (GOEP)

           本配置文件并非作为个体而被使用,而是定义了Object Push Profile等使用OBEX协议的对象交换类配置文件的共通内容

Object Push Profile (OPP)

           提供了类似于名片、日历、文件等对象的推送(Push)传输,以及名片的交换传输服务

File Transfer Profile (FTP)

           进行文件的收发传输

Synchronization Profile (SYNC)

           进行类似于PDA和PC内容的同期传输等文件同期处理

Headset Profile (HSP)

           利用头戴式耳机进行语音通话

Hands Free Profile (HFP)

           在Headset Profile中追加了用于电话通话的功能

Human Interface Device Profile (HID)

           将鼠标、键盘等输入设备的通信进行无线化

Basic Imaging Profile (BIP)

           进行图像的收发传输

Hardcopy Cable Replacement Profile (HCRP)

           对打印电缆提供的功能以无线方式进行置换

Basic Printing Profile (BPP)

           提供无打印机驱动的简易打印服务

Personal Area Network Profile (PAN)

           提供对若干个蓝牙设备进行构建网络的服务

Advanced Audio Distribution Profile (A2DP)

           提供音乐传输服务

Audio/Video Remote Control Profile (AVRCP)

           在传输影音内容时提供操控服务(也即远程遥控)

除了这里列举的种类以外,还有其他各式配置文件可供使用。

其他协议

上面介绍的协议,作为具有共通性的代表种类在大多数配置文件中得到了运用。
除此之外,也有为配置文件提供专用协议的情况。
比如在A2DP中有所谓AVDTP(Audio/Video Distribution Transport Protocol),在AVRCP中有所谓AVCTP(Audio/Video Control Transport Protocol)专用协议。

(其中,大内容参考:http://article.yeeyan.org/view/jianermei/49981)



    
[3] 蓝牙通讯-打开和关闭蓝牙设备
    来源: 互联网  发布时间: 2014-02-18
蓝牙通信-打开和关闭蓝牙设备

蓝牙(BlueTooth)要求的最低版本是android2.0,由于Android模拟器不支持蓝牙,运行蓝牙的有关应用必须在真机上测试运行。

蓝牙是一种重要的短距离无线通信协议,广泛应用于各种设备(手机,医疗,汽车等)。蓝牙是比较常用的无线通信设备,早研究成为手机的标配。

在Android中,与蓝牙有关的类和接口在android.bluetooth包中。其中BluetoothAdapter是蓝牙中的核心类,

代表本地的蓝牙适配器设备。BluetoothAdapter类让用户能执行基本的蓝牙任务。例如: 初始化设备的搜索,查询可匹配的设备集,使用一个已知的MAC地址来初始化一个BluetoothDevice类,创建一个 BluetoothServerSocket类以监听其它设备对本机的连接请求等。

当我们使用蓝牙时会先判断当前手机是否打开了蓝牙,然后在进行相应的处理。

下面我们看看怎样打开蓝牙设备。

1.我们调用时除了需要考虑API Level至少为5外,还需注意添加相应的权限,比如使用通讯需要在androidmanifest.xml加入<uses-permissionandroid:name="android.permission.BLUETOOTH" />,而开关蓝牙需要android.permission.BLUETOOTH_ADMIN权限。

只要是有关蓝牙的应用程序这两个不可少。

2JAVA主要代码:

package com.example.open_local_bluetooth;

import android.os.Bundle;
import android.app.Activity;
import android.bluetooth.BluetoothAdapter;
import android.content.Intent;
import android.view.Menu;
import android.widget.Toast;

public class MainActivity extends Activity {

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		BluetoothAdapter mBluetoothAdapter = BluetoothAdapter
				.getDefaultAdapter();
		if (mBluetoothAdapter == null) {
			Toast.makeText(this, "本机没有找到蓝牙硬件或驱动!", Toast.LENGTH_SHORT).show();
			finish();
		}
		// 如果本地蓝牙没有开启,则开启
		if (!mBluetoothAdapter.isEnabled()) {
			// 我们通过startActivityForResult()方法发起的Intent将会在onActivityResult()回调方法中获取用户的选择,比如用户单击了Yes开启,
			// 那么将会收到RESULT_OK的结果,
			// 如果RESULT_CANCELED则代表用户不愿意开启蓝牙
			Intent mIntent = new Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE);
			startActivityForResult(mIntent, 1);
			// 用enable()方法来开启,无需询问用户(实惠无声息的开启蓝牙设备),这时就需要用到android.permission.BLUETOOTH_ADMIN权限。
			// mBluetoothAdapter.enable();
			// mBluetoothAdapter.disable();//关闭蓝牙
		}
	}

	@Override
	protected void onActivityResult(int requestCode, int resultCode, Intent data) {
		// TODO Auto-generated method stub
		super.onActivityResult(requestCode, resultCode, data);
		if (requestCode == 1) {
			if (resultCode == RESULT_OK) {
				Toast.makeText(this, "蓝牙已经开启", Toast.LENGTH_SHORT).show();
			} else if (resultCode == RESULT_CANCELED) {
				Toast.makeText(this, "不允许蓝牙开启", Toast.LENGTH_SHORT).show();
				finish();
			}
		}

	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		// Inflate the menu; this adds items to the action bar if it is present.
		getMenuInflater().inflate(R.menu.main, menu);
		return true;
	}

}



3配置文件:AndrodManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.open_local_bluetooth"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="17" />
    <uses-permission android:name="android.permission.BLUETOOTH"/>
    <uses-permission android:name="android.permission.BLUETOOTH_ADMIN"/>

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="com.example.open_local_bluetooth.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>



运行结果:



    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app... iis7站长之家
▪Android Touch事件分发过程详解
▪Android中实现为TextView添加多个可点击的文本
▪Android程序设计之AIDL实例详解
▪Android显式启动与隐式启动Activity的区别介绍
▪Android按钮单击事件的四种常用写法总结
▪Android消息处理机制Looper和Handler详解
▪Android实现Back功能代码片段总结
▪Android实用的代码片段 常用代码总结
▪Android实现弹出键盘的方法
▪Android中通过view方式获取当前Activity的屏幕截...
▪Android提高之自定义Menu(TabMenu)实现方法
▪Android提高之多方向抽屉实现方法
▪Android提高之MediaPlayer播放网络音频的实现方法...
▪Android提高之MediaPlayer播放网络视频的实现方法...
▪Android提高之手游转电视游戏的模拟操控
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3