(iOS) Rework BTstack handling:

No more BTDiscoveryView, just press the 'Start Bluetooth' button in the upper right corner and sync the wii remote.
   Add a per module setting to enable bluetooth as soon as a game starts.
   Stop bluetooth whenever a game is closed.
This commit is contained in:
meancoot 2013-03-06 12:15:26 -05:00
parent 14e80352e7
commit 5310067cc5
10 changed files with 65 additions and 493 deletions

View File

@ -98,7 +98,6 @@
966B9C8D16E40EFC005B61E1 /* RAInputResponder.m in Sources */ = {isa = PBXBuildFile; fileRef = 966B9C8916E40D44005B61E1 /* RAInputResponder.m */; };
966B9C8E16E40F00005B61E1 /* ios_input.m in Sources */ = {isa = PBXBuildFile; fileRef = 966B9C8616E40D44005B61E1 /* ios_input.m */; };
966B9CA216E418B7005B61E1 /* BTDevice.m in Sources */ = {isa = PBXBuildFile; fileRef = 966B9C9116E418B7005B61E1 /* BTDevice.m */; settings = {COMPILER_FLAGS = "-fno-objc-arc"; }; };
966B9CA316E418B7005B61E1 /* BTDiscoveryViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 966B9C9316E418B7005B61E1 /* BTDiscoveryViewController.m */; settings = {COMPILER_FLAGS = "-fno-objc-arc"; }; };
966B9CA416E418B7005B61E1 /* BTstackManager.m in Sources */ = {isa = PBXBuildFile; fileRef = 966B9C9C16E418B7005B61E1 /* BTstackManager.m */; settings = {COMPILER_FLAGS = "-fno-objc-arc"; }; };
966B9CA516E418B7005B61E1 /* libBTstack.dylib in Frameworks */ = {isa = PBXBuildFile; fileRef = 966B9C9D16E418B7005B61E1 /* libBTstack.dylib */; };
966B9CA616E418B7005B61E1 /* wiimote.c in Sources */ = {isa = PBXBuildFile; fileRef = 966B9C9E16E418B7005B61E1 /* wiimote.c */; };
@ -210,8 +209,6 @@
966B9C8916E40D44005B61E1 /* RAInputResponder.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = RAInputResponder.m; sourceTree = "<group>"; };
966B9C9016E418B7005B61E1 /* BTDevice.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = BTDevice.h; sourceTree = "<group>"; };
966B9C9116E418B7005B61E1 /* BTDevice.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = BTDevice.m; sourceTree = "<group>"; };
966B9C9216E418B7005B61E1 /* BTDiscoveryViewController.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = BTDiscoveryViewController.h; sourceTree = "<group>"; };
966B9C9316E418B7005B61E1 /* BTDiscoveryViewController.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = BTDiscoveryViewController.m; sourceTree = "<group>"; };
966B9C9516E418B7005B61E1 /* btstack.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = btstack.h; sourceTree = "<group>"; };
966B9C9616E418B7005B61E1 /* hci_cmds.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = hci_cmds.h; sourceTree = "<group>"; };
966B9C9716E418B7005B61E1 /* linked_list.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = linked_list.h; sourceTree = "<group>"; };
@ -422,8 +419,6 @@
children = (
966B9C9016E418B7005B61E1 /* BTDevice.h */,
966B9C9116E418B7005B61E1 /* BTDevice.m */,
966B9C9216E418B7005B61E1 /* BTDiscoveryViewController.h */,
966B9C9316E418B7005B61E1 /* BTDiscoveryViewController.m */,
966B9C9416E418B7005B61E1 /* btstack */,
966B9C9B16E418B7005B61E1 /* BTstackManager.h */,
966B9C9C16E418B7005B61E1 /* BTstackManager.m */,
@ -1001,7 +996,6 @@
966B9C8B16E40D44005B61E1 /* ios_joypad.m in Sources */,
966B9C8C16E40D44005B61E1 /* RAInputResponder.m in Sources */,
966B9CA216E418B7005B61E1 /* BTDevice.m in Sources */,
966B9CA316E418B7005B61E1 /* BTDiscoveryViewController.m in Sources */,
966B9CA416E418B7005B61E1 /* BTstackManager.m in Sources */,
966B9CA616E418B7005B61E1 /* wiimote.c in Sources */,
966B9CA716E418B7005B61E1 /* WiiMoteHelper.m in Sources */,

View File

@ -17,6 +17,7 @@
- (id)initWithPath:(NSString*)path;
- (void)writeToFile:(NSString*)path;
- (bool)getBoolNamed:(NSString*)name withDefault:(bool)def;
- (int)getIntNamed:(NSString*)name withDefault:(int)def;
- (unsigned)getUintNamed:(NSString*)name withDefault:(unsigned)def;
- (NSString*)getStringNamed:(NSString*)name withDefault:(NSString*)def;

View File

@ -40,6 +40,16 @@
config_file_write(_config, [path UTF8String]);
}
- (bool)getBoolNamed:(NSString*)name withDefault:(bool)def
{
bool result = def;
if (_config)
config_get_bool(_config, [name UTF8String], &result);
return result;
}
- (int)getIntNamed:(NSString*)name withDefault:(int)def
{
int result = def;

View File

@ -23,7 +23,6 @@
- (void)runGame:(NSString*)path;
- (IBAction)showSettings;
- (IBAction)showWiiRemoteConfig;
@property (strong, nonatomic) RAModuleInfo* moduleInfo;

View File

@ -96,14 +96,7 @@
if (_isGameTop)
[self startTimer];
#ifdef WIIMOTE
navigationController.topViewController.navigationItem.rightBarButtonItem = (![WiiMoteHelper isBluetoothRunning]) ? nil :
[[UIBarButtonItem alloc]
initWithTitle:@"Stop Bluetooth"
style:UIBarButtonItemStyleBordered
target:[RetroArch_iOS get]
action:@selector(stopBluetooth)];
#endif
self.topViewController.navigationItem.rightBarButtonItem = [self createBluetoothButton];
}
// UINavigationController: Never animate when pushing onto, or popping, an RAGameView
@ -131,6 +124,12 @@
{
rarch_init_msg_queue();
// Read load time settings
RAConfig* conf = [[RAConfig alloc] initWithPath:self.moduleInfo.configPath];
if ([conf getBoolNamed:@"ios_auto_bluetooth" withDefault:false])
[self startBluetooth];
//
[self pushViewController:RAGameView.get animated:NO];
_isRunning = true;
}
@ -151,6 +150,10 @@
rarch_deinit_msg_queue();
rarch_main_clear_state();
// Stop bluetooth (might be annoying but forgetting could eat battery of device AND wiimote)
[self stopBluetooth];
//
[self popToViewController:[RAGameView get] animated:NO];
[self popViewControllerAnimated:NO];
}
@ -233,10 +236,26 @@
[self pushViewController:[RASettingsList new] animated:YES];
}
- (IBAction)showWiiRemoteConfig
#pragma MARK Bluetooth Helpers
- (UIBarButtonItem*)createBluetoothButton
{
#ifdef WIIMOTE
[[WiiMoteHelper get] showDiscovery];
const bool isBTOn = [WiiMoteHelper isBluetoothRunning];
return [[UIBarButtonItem alloc]
initWithTitle:isBTOn ? @"Stop Bluetooth" : @"Start Bluetooth"
style:UIBarButtonItemStyleBordered
target:[RetroArch_iOS get]
action:isBTOn ? @selector(stopBluetooth) : @selector(startBluetooth)];
#else
return nil;
#endif
}
- (IBAction)startBluetooth
{
#ifdef WIIMOTE
[WiiMoteHelper startBluetooth];
[self.topViewController.navigationItem setRightBarButtonItem:[self createBluetoothButton] animated:YES];
#endif
}
@ -244,7 +263,7 @@
{
#ifdef WIIMOTE
[WiiMoteHelper stopBluetooth];
[self.topViewController.navigationItem setRightBarButtonItem:nil animated:YES];
[self.topViewController.navigationItem setRightBarButtonItem:[self createBluetoothButton] animated:YES];
#endif
}

View File

@ -1,67 +0,0 @@
/*
* Copyright (C) 2009 by Matthias Ringwald
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. Neither the name of the copyright holders nor the names of
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY MATTHIAS RINGWALD AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
* RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
* THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
*/
#import <UIKit/UIKit.h>
#import "BTstackManager.h"
@class BTstackManager;
@protocol BTDiscoveryDelegate;
typedef enum {
kInquiryInactive,
kInquiryActive,
kInquiryRemoteName
} InquiryState;
@interface BTDiscoveryViewController : UITableViewController<BTstackManagerListener>
{
BTstackManager *bt;
NSObject<BTDiscoveryDelegate> * _delegate;
UIActivityIndicatorView *deviceActivity;
UIActivityIndicatorView *bluetoothActivity;
UIFont * deviceNameFont;
UIFont * macAddressFont;
InquiryState inquiryState;
int remoteNameIndex;
BOOL showIcons;
int connectingIndex;
NSString *customActivityText;
}
-(void) markConnecting:(int)index; // use -1 for no connection active
@property (nonatomic, assign) NSObject<BTDiscoveryDelegate> * delegate;
@property (nonatomic, assign) BOOL showIcons;
@property (nonatomic, retain) NSString *customActivityText;
@end
@protocol BTDiscoveryDelegate
@optional
-(BOOL) discoveryView:(BTDiscoveryViewController*)discoveryView willSelectDeviceAtIndex:(int)deviceIndex; // returns NO to ignore selection
-(void) statusCellSelectedDiscoveryView:(BTDiscoveryViewController*)discoveryView;
@end

View File

@ -1,351 +0,0 @@
/*
* Copyright (C) 2009 by Matthias Ringwald
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. Neither the name of the copyright holders nor the names of
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY MATTHIAS RINGWALD AND CONTRIBUTORS
* ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS
* RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
* THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
*/
#import "BTDiscoveryViewController.h"
#import "BTDevice.h"
// fix compare for 3.0
#ifndef __IPHONE_3_0
#define __IPHONE_3_0 30000
#endif
#if __IPHONE_OS_VERSION_MIN_REQUIRED < __IPHONE_3_0
// SDK 30 defines missing in SDK 20
@interface UITableViewCell (NewIn30)
- (id)initWithStyle:(int)style reuseIdentifier:(NSString *)reuseIdentifier;
@end
#endif
@interface UIDevice (privateAPI)
-(BOOL) isWildcat;
@end
@implementation BTDiscoveryViewController
@synthesize showIcons;
@synthesize delegate = _delegate;
@synthesize customActivityText;
- (id) init {
self = [super initWithStyle:UITableViewStyleGrouped];
macAddressFont = [UIFont fontWithName:@"Courier New" size:[UIFont labelFontSize]];
deviceNameFont = [UIFont boldSystemFontOfSize:[UIFont labelFontSize]];
inquiryState = kInquiryInactive;
connectingIndex = -1;
deviceActivity = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleGray];
[deviceActivity startAnimating];
bluetoothActivity = [[UIActivityIndicatorView alloc] initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleGray];
[bluetoothActivity startAnimating];
bt = [BTstackManager sharedInstance];
_delegate = nil;
return self;
}
-(void) reload{
[[self tableView] reloadData];
}
/*
- (id)initWithStyle:(UITableViewStyle)style {
// Override initWithStyle: if you create the controller programmatically and want to perform customization that is not appropriate for viewDidLoad.
if (self = [super initWithStyle:style]) {
}
return self;
}
*/
/*
- (void)viewDidLoad {
[super viewDidLoad];
// Uncomment the following line to display an Edit button in the navigation bar for this view controller.
// self.navigationItem.rightBarButtonItem = self.editButtonItem;
}
*/
/*
- (void)viewWillAppear:(BOOL)animated {
[super viewWillAppear:animated];
}
*/
/*
- (void)viewDidAppear:(BOOL)animated {
[super viewDidAppear:animated];
}
*/
/*
- (void)viewWillDisappear:(BOOL)animated {
[super viewWillDisappear:animated];
}
*/
/*
- (void)viewDidDisappear:(BOOL)animated {
[super viewDidDisappear:animated];
}
*/
/*
// Override to allow orientations other than the default portrait orientation.
- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation {
// Return YES for supported orientations
return (interfaceOrientation == UIInterfaceOrientationPortrait);
}
- (void)didReceiveMemoryWarning {
// Releases the view if it doesn't have a superview.
[super didReceiveMemoryWarning];
// Release any cached data, images, etc that aren't in use.
}
*/
// BTstackManagerListenerDelegate
-(void) activatedBTstackManager:(BTstackManager*) manager{
[self reload];
}
-(void) btstackManager:(BTstackManager*)manager activationFailed:(BTstackError)error {
[self reload];
}
-(void) discoveryInquiryBTstackManager:(BTstackManager*) manager {
inquiryState = kInquiryActive;
[self reload];
}
-(void) btstackManager:(BTstackManager*)manager discoveryQueryRemoteName:(int)deviceIndex {
inquiryState = kInquiryRemoteName;
remoteNameIndex = deviceIndex;
[self reload];
}
-(void) discoveryStoppedBTstackManager:(BTstackManager*) manager {
inquiryState = kInquiryInactive;
[self reload];
}
-(void) btstackManager:(BTstackManager*)manager deviceInfo:(BTDevice*)device {
[self reload];
}
-(void) markConnecting:(int)index; {
connectingIndex = index;
[self reload];
}
-(void) setCustomActivityText:(NSString*) text{
[text retain];
[customActivityText release];
customActivityText = text;
[self reload];
}
// MARK: Table view methods
- (NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section{
return @"Devices";
}
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
return 1;
}
// Customize the number of rows in the table view.
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
return 1 + [bt numberOfDevicesFound];
}
// Customize the appearance of table view cells.
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
static NSString *CellIdentifier = @"Cell";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
if (cell == nil) {
#if __IPHONE_OS_VERSION_MIN_REQUIRED >= __IPHONE_3_0
cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier] autorelease];
#else
cell = [[[UITableViewCell alloc] initWithFrame:CGRectNull reuseIdentifier:(NSString *)CellIdentifier] autorelease];
#endif
}
// Set up the cell...
NSString *theLabel = nil;
UIImage *theImage = nil;
UIFont *theFont = nil;
int idx = [indexPath indexAtPosition:1];
if (idx >= [bt numberOfDevicesFound]) {
if (customActivityText) {
theLabel = customActivityText;
cell.accessoryView = bluetoothActivity;
} else if ([bt isActivating]){
theLabel = @"Activating BTstack...";
cell.accessoryView = bluetoothActivity;
} else if (![bt isActive]){
theLabel = @"Bluetooth not accessible!";
cell.accessoryView = nil;
} else {
#if 0
if (connectedDevice) {
theLabel = @"Disconnect";
cell.accessoryView = nil;
}
#endif
if (connectingIndex >= 0) {
theLabel = @"Connecting...";
cell.accessoryView = bluetoothActivity;
} else {
switch (inquiryState){
case kInquiryInactive:
if ([bt numberOfDevicesFound] > 0){
theLabel = @"Find more devices...";
} else {
theLabel = @"Find devices...";
}
cell.accessoryView = nil;
break;
case kInquiryActive:
theLabel = @"Searching...";
cell.accessoryView = bluetoothActivity;
break;
case kInquiryRemoteName:
theLabel = @"Query device names...";
cell.accessoryView = bluetoothActivity;
break;
}
}
}
} else {
BTDevice *dev = [bt deviceAtIndex:idx];
// pick font
theLabel = [dev nameOrAddress];
if ([dev name]){
theFont = deviceNameFont;
} else {
theFont = macAddressFont;
}
// pick an icon for the devices
if (showIcons) {
NSString *imageName = @"bluetooth.png";
// check major device class
switch (([dev classOfDevice] & 0x1f00) >> 8) {
case 0x01:
imageName = @"computer.png";
break;
case 0x02:
imageName = @"smartphone.png";
break;
case 0x05:
switch ([dev classOfDevice] & 0xff){
case 0x40:
imageName = @"keyboard.png";
break;
case 0x80:
imageName = @"mouse.png";
break;
case 0xc0:
imageName = @"keyboard.png";
break;
default:
imageName = @"HID.png";
break;
}
}
#ifdef LASER_KB
if ([dev name] && [[dev name] isEqualToString:@"CL800BT"]){
imageName = @"keyboard.png";
}
if ([dev name] && [[dev name] isEqualToString:@"CL850"]){
imageName = @"keyboard.png";
}
// Celluon CL800BT, CL850 have 00-0b-24-aa-bb-cc, COD 0x400210
uint8_t *addr = (uint8_t *) [dev address];
if (addr[0] == 0x00 && addr[1] == 0x0b && addr[2] == 0x24){
imageName = @"keyboard.png";
}
#endif
theImage = [UIImage imageNamed:imageName];
}
// set accessory view
if (idx == connectingIndex){
cell.accessoryView = deviceActivity;
} else {
cell.accessoryView = nil;
}
}
#if __IPHONE_OS_VERSION_MIN_REQUIRED >= __IPHONE_3_0
if (theLabel) cell.textLabel.text = theLabel;
if (theFont) cell.textLabel.font = theFont;
if (theImage) cell.imageView.image = theImage;
#else
if (theLabel) cell.text = theLabel;
if (theFont) cell.font = theFont;
if (theImage) cell.image = theImage;
#endif
return cell;
}
- (NSIndexPath *)tableView:(UITableView *)tableView willSelectRowAtIndexPath:(NSIndexPath *)indexPath {
if (!_delegate) return nil;
int index = [indexPath indexAtPosition:1];
if (index >= [bt numberOfDevicesFound]){
if ([_delegate respondsToSelector:@selector(statusCellSelectedDiscoveryView:)]){
[_delegate statusCellSelectedDiscoveryView:self];
return nil;
}
}
if ([_delegate respondsToSelector:@selector(discoveryView:willSelectDeviceAtIndex:)] && [_delegate discoveryView:self willSelectDeviceAtIndex:index]){
return indexPath;
}
return nil;
}
// Override to allow orientations other than the default portrait orientation.
- (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation {
UIDevice * uiDevice = [UIDevice currentDevice];
return [uiDevice respondsToSelector:@selector(isWildcat)] && [uiDevice isWildcat];
}
- (void)dealloc {
[super dealloc];
}
@end

View File

@ -31,12 +31,11 @@
#import <UIKit/UIKit.h>
#import "BTDiscoveryViewController.h"
#import "BTstackManager.h"
@interface WiiMoteHelper : NSObject<BTDiscoveryDelegate, BTstackManagerDelegate, BTstackManagerListener>
+ (WiiMoteHelper*)get;
@interface WiiMoteHelper : NSObject<BTstackManagerDelegate, BTstackManagerListener>
+ (void)startBluetooth;
+ (BOOL)isBluetoothRunning;
+ (void)stopBluetooth;
- (void)showDiscovery;
@end

View File

@ -38,27 +38,24 @@
#import "BTDevice.h"
#import "BTstackManager.h"
#import "BTDiscoveryViewController.h"
#import "btstack/btstack.h"
#import "btstack/run_loop.h"
#import "btstack/hci_cmds.h"
static BTDiscoveryViewController* discoveryView;
static WiiMoteHelper* instance;
static BTDevice *device;
static bool btOK;
@implementation WiiMoteHelper
+ (WiiMoteHelper*)get
+ (void)startBluetooth
{
if (!instance)
{
instance = [WiiMoteHelper new];
}
instance = instance ? instance : [WiiMoteHelper new];
return instance;
if (!btOK)
{
BTstackManager* bt = [BTstackManager sharedInstance];
[bt setDelegate:instance];
[bt addListener:instance];
btOK = [bt activate] == 0;
}
}
+ (BOOL)isBluetoothRunning
@ -68,46 +65,19 @@ static bool btOK;
+ (void)stopBluetooth
{
instance = nil;
myosd_num_of_joys = 0;
if (btOK)
{
BTstackManager* bt = [BTstackManager sharedInstance];
[bt removeListener:discoveryView];
discoveryView = nil;
[[BTstackManager sharedInstance] deactivate];
[bt deactivate];
[bt setDelegate:nil];
[bt removeListener:instance];
btOK = false;
}
}
- (id)init
{
if (!btOK)
{
BTstackManager* bt = [BTstackManager sharedInstance];
[bt setDelegate:self];
[bt addListener:self];
btOK = [bt activate] == 0;
}
return self;
}
- (void)showDiscovery
{
if (!discoveryView)
{
discoveryView = [BTDiscoveryViewController new];
[discoveryView setDelegate:self];
[[BTstackManager sharedInstance] addListener:discoveryView];
}
[[RetroArch_iOS get] pushViewController:discoveryView animated:YES];
instance = nil;
}
// BTStackManagerListener
@ -132,10 +102,10 @@ static bool btOK;
// BTStackManagerDelegate
-(void) btstackManager:(BTstackManager*) manager
handlePacketWithType:(uint8_t) packet_type
forChannel:(uint16_t) channel
andData:(uint8_t *)packet
withLen:(uint16_t) size
handlePacketWithType:(uint8_t)packet_type
forChannel:(uint16_t)channel
andData:(uint8_t*)packet
withLen:(uint16_t)size
{
bd_addr_t event_addr;

View File

@ -92,10 +92,10 @@ static RASettingData* custom_action(NSString* action)
NSString* shader_path = [[[NSBundle mainBundle] bundlePath] stringByAppendingString:@"/shaders/"];
NSArray* settings = [NSArray arrayWithObjects:
[NSArray arrayWithObjects:@"General",
[NSArray arrayWithObjects:@"Frontend",
custom_action(@"Module Info"),
#ifdef WIIMOTE
custom_action(@"Connect WiiMotes"),
boolean_setting(config, @"ios_auto_bluetooth", @"Auto Enable Bluetooth", @"false"),
#endif
nil],
@ -176,8 +176,6 @@ static RASettingData* custom_action(NSString* action)
{
if ([@"Module Info" isEqualToString:action])
[[RetroArch_iOS get] pushViewController:[[RAModuleInfoList alloc] initWithModuleInfo:[RetroArch_iOS get].moduleInfo] animated:YES];
else if([@"Connect WiiMotes" isEqualToString:action])
[[RetroArch_iOS get] showWiiRemoteConfig];
}
@end