我正在尝试像这样从远程蓝牙设备获取 UUIDS:
device.fetchUuidsWithSdp();
这将在所有设备上静默运行,无需用户交互,Android 6.0 除外,Android 6.0 明显要求通过配对对话框连接远程设备以获取 UUID。这是预期的行为吗?这在哪里记录?有没有一种方法可以触发 UUID 发现而无需从另一端明确允许它?
最佳答案
我找到了解决此问题的方法,方法是使用隐藏的 sdpSearch 方法而不是 fetchUuidsWithSdp。这需要一点反射(reflection)。这在 android 6.0 和 5.1.1 上对我有用,没有尝试配对的设备。 希望这会有所帮助,并随时改进相当糟糕的异常处理。
public class DeviceFinder{
public interface Callback{
void onDeviceFound(BluetoothDevice bd);
void onFinishedCallback();
void onStartCallback();
}
private ArrayList<BluetoothDevice> tempDevices = new ArrayList<>();
private Callback mCallback;
private Context mContext;
private String ACTION_SDP_RECORD;
private String EXTRA_SDP_SEARCH_RESULT;
private BroadcastReceiver mReceiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
if (BluetoothDevice.ACTION_FOUND.equals(action)){
// Aggregating found devices
BluetoothDevice bd = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
tempDevices.add(bd);
}else if (BluetoothAdapter.ACTION_DISCOVERY_STARTED.equals(action)){
// Prepare for new search
tempDevices = new ArrayList<>();
mCallback.onStartCallback();
}else if (BluetoothAdapter.ACTION_DISCOVERY_FINISHED.equals(action)){
// Do a sdpSearch for all found devices
for (BluetoothDevice bd : tempDevices){
try {
Method m = bd.getClass().getDeclaredMethod("sdpSearch", ParcelUuid.class);
m.invoke(bd, new ParcelUuid(/* your uuid here */));
} catch (Exception e) {
e.printStackTrace();
}
}
mCallback.onFinishedCallback();
}else if( ACTION_SDP_RECORD.equals(action)){
// check if the device has the specified uuid
BluetoothDevice bd = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
if (intent.getIntExtra(EXTRA_SDP_SEARCH_RESULT, 1) == 0){
mCallback.onDeviceFound(bd);
}
}
}
};
public DeviceFinder(Context context, Callback mCallback){
this.mCallback = mCallback;
this.mContext = context;
try {
Field f = BluetoothDevice.class.getDeclaredField("ACTION_SDP_RECORD");
ACTION_SDP_RECORD = ((String)f.get(null));
f = BluetoothDevice.class.getDeclaredField("EXTRA_SDP_SEARCH_STATUS");
EXTRA_SDP_SEARCH_RESULT = ((String)f.get(null));
} catch (Exception e) {
e.printStackTrace();
}
IntentFilter intentFilter = new IntentFilter();
intentFilter.addAction(BluetoothDevice.ACTION_FOUND);
intentFilter.addAction(BluetoothAdapter.ACTION_DISCOVERY_STARTED);
intentFilter.addAction(BluetoothAdapter.ACTION_DISCOVERY_FINISHED);
intentFilter.addAction(ACTION_SDP_RECORD);
context.registerReceiver(mReceiver, intentFilter);
startScan();
}
public void startScan(){
BluetoothAdapter bluetoothAdapter = BluetoothAdapter.getDefaultAdapter();
if (!bluetoothAdapter.isDiscovering()) {
bluetoothAdapter.startDiscovery();
}
}
public void unregisterReciever(){
mContext.unregisterReceiver(mReceiver);
}
}
编辑: sdpSearch 是在android 6.0 中添加的,所以它不适用于早期版本
关于Android 6.0 获取 UUIDS 时请求与远程设备配对,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33661814/
在我的Controller中,我通过以下方式在我的index方法中支持HTML和JSON:respond_todo|format|format.htmlformat.json{renderjson:@user}end在浏览器中拉起它时,它会自然地以HTML呈现。但是,当我对/user资源进行内容类型为application/json的curl调用时(因为它是索引方法),我仍然将HTML作为响应。如何获取JSON作为响应?我还需要说明什么? 最佳答案 您应该将.json附加到请求的url,提供的格式在routes.rb的路径中定义。这
有没有办法在这个简单的get方法中添加超时选项?我正在使用法拉第3.3。Faraday.get(url)四处寻找,我只能先发起连接后应用超时选项,然后应用超时选项。或者有什么简单的方法?这就是我现在正在做的:conn=Faraday.newresponse=conn.getdo|req|req.urlurlreq.options.timeout=2#2secondsend 最佳答案 试试这个:conn=Faraday.newdo|conn|conn.options.timeout=20endresponse=conn.get(url
我有一个存储主机名的Ruby数组server_names。如果我打印出来,它看起来像这样:["hostname.abc.com","hostname2.abc.com","hostname3.abc.com"]相当标准。我想要做的是获取这些服务器的IP(可能将它们存储在另一个变量中)。看起来IPSocket类可以做到这一点,但我不确定如何使用IPSocket类遍历它。如果它只是尝试像这样打印出IP:server_names.eachdo|name|IPSocket::getaddress(name)pnameend它提示我没有提供服务器名称。这是语法问题还是我没有正确使用类?输出:ge
我想获取模块中定义的所有常量的值:moduleLettersA='apple'.freezeB='boy'.freezeendconstants给了我常量的名字:Letters.constants(false)#=>[:A,:B]如何获取它们的值的数组,即["apple","boy"]? 最佳答案 为了做到这一点,请使用mapLetters.constants(false).map&Letters.method(:const_get)这将返回["a","b"]第二种方式:Letters.constants(false).map{|c
我安装了ruby版本管理器,并将RVM安装的ruby实现设置为默认值,这样'哪个ruby'显示'~/.rvm/ruby-1.8.6-p383/bin/ruby'但是当我在emacs中打开inf-ruby缓冲区时,它使用安装在/usr/bin中的ruby。有没有办法让emacs像shell一样尊重ruby的路径?谢谢! 最佳答案 我创建了一个emacs扩展来将rvm集成到emacs中。如果您有兴趣,可以在这里获取:http://github.com/senny/rvm.el
假设我有这个范围:("aaaaa".."zzzzz")如何在不事先/每次生成整个项目的情况下从范围中获取第N个项目? 最佳答案 一种快速简便的方法:("aaaaa".."zzzzz").first(42).last#==>"aaabp"如果出于某种原因你不得不一遍又一遍地这样做,或者如果你需要避免为前N个元素构建中间数组,你可以这样写:moduleEnumerabledefskip(n)returnto_enum:skip,nunlessblock_given?each_with_indexdo|item,index|yieldit
rails中是否有任何规定允许站点的所有AJAXPOST请求在没有authenticity_token的情况下通过?我有一个调用Controller方法的JqueryPOSTajax调用,但我没有在其中放置任何真实性代码,但调用成功。我的ApplicationController确实有'request_forgery_protection'并且我已经改变了config.action_controller.consider_all_requests_local在我的environments/development.rb中为false我还搜索了我的代码以确保我没有重载ajaxSend来发送
我目前正在使用以下方法获取页面的源代码:Net::HTTP.get(URI.parse(page.url))我还想获取HTTP状态,而无需发出第二个请求。有没有办法用另一种方法做到这一点?我一直在查看文档,但似乎找不到我要找的东西。 最佳答案 在我看来,除非您需要一些真正的低级访问或控制,否则最好使用Ruby的内置Open::URI模块:require'open-uri'io=open('http://www.example.org/')#=>#body=io.read[0,50]#=>"["200","OK"]io.base_ur
如何在Ruby中获取BasicObject实例的类名?例如,假设我有这个:classMyObjectSystem我怎样才能使这段代码成功?编辑:我发现Object的实例方法class被定义为returnrb_class_real(CLASS_OF(obj));。有什么方法可以从Ruby中使用它? 最佳答案 我花了一些时间研究irb并想出了这个:classBasicObjectdefclassklass=class这将为任何从BasicObject继承的对象提供一个#class您可以调用的方法。编辑评论中要求的进一步解释:假设你有对象
是否可以在应用程序中包含的gem代码中知道应用程序的Rails文件系统根目录?这是gem来源的示例:moduleMyGemdefself.included(base)putsRails.root#returnnilendendActionController::Base.send:include,MyGem谢谢,抱歉我的英语不好 最佳答案 我发现解决类似问题的解决方案是使用railtie初始化程序包含我的模块。所以,在你的/lib/mygem/railtie.rbmoduleMyGemclassRailtie使用此代码,您的模块将在