├── BluetoothScanner ├── .gitignore ├── .idea │ ├── .name │ ├── compiler.xml │ ├── copyright │ │ └── profiles_settings.xml │ ├── gradle.xml │ ├── misc.xml │ ├── modules.xml │ └── vcs.xml ├── BluetoothScanner.iml ├── app │ ├── .gitignore │ ├── app.iml │ ├── build.gradle │ ├── proguard-rules.pro │ └── src │ │ ├── androidTest │ │ └── java │ │ │ └── com │ │ │ └── tutsplus │ │ │ └── matt │ │ │ └── bluetoothscanner │ │ │ └── ApplicationTest.java │ │ └── main │ │ ├── AndroidManifest.xml │ │ ├── java │ │ └── com │ │ │ └── tutsplus │ │ │ └── matt │ │ │ └── bluetoothscanner │ │ │ ├── DeviceItem.java │ │ │ ├── DeviceListAdapter.java │ │ │ ├── DeviceListFragment.java │ │ │ └── ListActivity.java │ │ └── res │ │ ├── drawable │ │ └── corners.xml │ │ ├── layout │ │ ├── activity_list.xml │ │ ├── device_grid_item.xml │ │ ├── device_list_item.xml │ │ └── fragment_deviceitem_list.xml │ │ ├── menu │ │ └── menu_list.xml │ │ ├── mipmap-hdpi │ │ └── ic_launcher.png │ │ ├── mipmap-mdpi │ │ └── ic_launcher.png │ │ ├── mipmap-xhdpi │ │ └── ic_launcher.png │ │ ├── mipmap-xxhdpi │ │ └── ic_launcher.png │ │ ├── mipmap-xxxhdpi │ │ └── ic_launcher.png │ │ ├── values-w820dp │ │ └── dimens.xml │ │ └── values │ │ ├── dimens.xml │ │ ├── strings.xml │ │ └── styles.xml ├── build.gradle ├── gradle.properties ├── gradle │ └── wrapper │ │ ├── gradle-wrapper.jar │ │ └── gradle-wrapper.properties ├── gradlew ├── gradlew.bat └── settings.gradle └── README.md /BluetoothScanner/.gitignore: -------------------------------------------------------------------------------- 1 | .gradle 2 | /local.properties 3 | /.idea/workspace.xml 4 | /.idea/libraries 5 | .DS_Store 6 | /build 7 | /captures 8 | -------------------------------------------------------------------------------- /BluetoothScanner/.idea/.name: -------------------------------------------------------------------------------- 1 | BluetoothScanner -------------------------------------------------------------------------------- /BluetoothScanner/.idea/compiler.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | -------------------------------------------------------------------------------- /BluetoothScanner/.idea/copyright/profiles_settings.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | -------------------------------------------------------------------------------- /BluetoothScanner/.idea/gradle.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 18 | 19 | -------------------------------------------------------------------------------- /BluetoothScanner/.idea/misc.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 22 | -------------------------------------------------------------------------------- /BluetoothScanner/.idea/modules.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /BluetoothScanner/.idea/vcs.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | -------------------------------------------------------------------------------- /BluetoothScanner/BluetoothScanner.iml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | -------------------------------------------------------------------------------- /BluetoothScanner/app/.gitignore: -------------------------------------------------------------------------------- 1 | /build 2 | -------------------------------------------------------------------------------- /BluetoothScanner/app/app.iml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 8 | 9 | 10 | 11 | 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 | -------------------------------------------------------------------------------- /BluetoothScanner/app/build.gradle: -------------------------------------------------------------------------------- 1 | apply plugin: 'com.android.application' 2 | 3 | android { 4 | compileSdkVersion 22 5 | buildToolsVersion "22.0.1" 6 | 7 | defaultConfig { 8 | applicationId "com.tutsplus.matt.bluetoothscanner" 9 | minSdkVersion 15 10 | targetSdkVersion 22 11 | versionCode 1 12 | versionName "1.0" 13 | } 14 | buildTypes { 15 | release { 16 | minifyEnabled false 17 | proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' 18 | } 19 | } 20 | } 21 | 22 | dependencies { 23 | compile fileTree(dir: 'libs', include: ['*.jar']) 24 | compile 'com.android.support:appcompat-v7:22.1.1' 25 | } 26 | -------------------------------------------------------------------------------- /BluetoothScanner/app/proguard-rules.pro: -------------------------------------------------------------------------------- 1 | # Add project specific ProGuard rules here. 2 | # By default, the flags in this file are appended to flags specified 3 | # in C:\Users\User\AppData\Local\Android\sdk/tools/proguard/proguard-android.txt 4 | # You can edit the include path and order by changing the proguardFiles 5 | # directive in build.gradle. 6 | # 7 | # For more details, see 8 | # http://developer.android.com/guide/developing/tools/proguard.html 9 | 10 | # Add any project specific keep options here: 11 | 12 | # If your project uses WebView with JS, uncomment the following 13 | # and specify the fully qualified class name to the JavaScript interface 14 | # class: 15 | #-keepclassmembers class fqcn.of.javascript.interface.for.webview { 16 | # public *; 17 | #} 18 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/androidTest/java/com/tutsplus/matt/bluetoothscanner/ApplicationTest.java: -------------------------------------------------------------------------------- 1 | package com.tutsplus.matt.bluetoothscanner; 2 | 3 | import android.app.Application; 4 | import android.test.ApplicationTestCase; 5 | 6 | /** 7 | * Testing Fundamentals 8 | */ 9 | public class ApplicationTest extends ApplicationTestCase { 10 | public ApplicationTest() { 11 | super(Application.class); 12 | } 13 | } -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/AndroidManifest.xml: -------------------------------------------------------------------------------- 1 | 2 | 4 | 5 | 10 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | bas 20 | 21 | 22 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/java/com/tutsplus/matt/bluetoothscanner/DeviceItem.java: -------------------------------------------------------------------------------- 1 | package com.tutsplus.matt.bluetoothscanner; 2 | 3 | /** 4 | * Created by Matt on 5/12/2015. 5 | */ 6 | public class DeviceItem { 7 | 8 | private String deviceName; 9 | private String address; 10 | private boolean connected; 11 | 12 | public String getDeviceName() { 13 | return deviceName; 14 | } 15 | 16 | public boolean getConnected() { 17 | return connected; 18 | } 19 | 20 | public String getAddress() { 21 | return address; 22 | } 23 | 24 | public void setDeviceName(String deviceName) { 25 | this.deviceName = deviceName; 26 | } 27 | 28 | public DeviceItem(String name, String address, String connected){ 29 | this.deviceName = name; 30 | this.address = address; 31 | if (connected == "true") { 32 | this.connected = true; 33 | } 34 | else { 35 | this.connected = false; 36 | } 37 | } 38 | } 39 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/java/com/tutsplus/matt/bluetoothscanner/DeviceListAdapter.java: -------------------------------------------------------------------------------- 1 | package com.tutsplus.matt.bluetoothscanner; 2 | 3 | import android.app.Activity; 4 | import android.bluetooth.BluetoothAdapter; 5 | import android.content.Context; 6 | import android.view.LayoutInflater; 7 | import android.view.View; 8 | import android.view.ViewGroup; 9 | import android.widget.ArrayAdapter; 10 | import android.widget.Button; 11 | import android.widget.CompoundButton; 12 | import android.widget.ImageButton; 13 | import android.widget.RelativeLayout; 14 | import android.widget.TextView; 15 | import android.widget.ToggleButton; 16 | 17 | import java.util.List; 18 | 19 | /** 20 | * Created by Matt on 5/12/2015. 21 | */ 22 | public class DeviceListAdapter extends ArrayAdapter{ 23 | 24 | private Context context; 25 | private BluetoothAdapter bTAdapter; 26 | 27 | public DeviceListAdapter(Context context, List items, BluetoothAdapter bTAdapter) { 28 | super(context, android.R.layout.simple_list_item_1, items); 29 | this.bTAdapter = bTAdapter; 30 | this.context = context; 31 | } 32 | 33 | /** 34 | * Holder for the list items. 35 | */ 36 | private class ViewHolder{ 37 | TextView titleText; 38 | } 39 | 40 | /** 41 | * 42 | * @param position 43 | * @param convertView 44 | * @param parent 45 | * @return 46 | */ 47 | public View getView(int position, View convertView, ViewGroup parent) { 48 | ViewHolder holder = null; 49 | View line = null; 50 | DeviceItem item = (DeviceItem)getItem(position); 51 | final String name = item.getDeviceName(); 52 | TextView macAddress = null; 53 | View viewToUse = null; 54 | 55 | // This block exists to inflate the settings list item conditionally based on whether 56 | // we want to support a grid or list view. 57 | LayoutInflater mInflater = (LayoutInflater) context 58 | .getSystemService(Activity.LAYOUT_INFLATER_SERVICE); 59 | 60 | viewToUse = mInflater.inflate(R.layout.device_list_item, null); 61 | holder = new ViewHolder(); 62 | holder.titleText = (TextView)viewToUse.findViewById(R.id.titleTextView); 63 | viewToUse.setTag(holder); 64 | 65 | macAddress = (TextView)viewToUse.findViewById(R.id.macAddress); 66 | line = (View)viewToUse.findViewById(R.id.line); 67 | holder.titleText.setText(item.getDeviceName()); 68 | macAddress.setText(item.getAddress()); 69 | 70 | if ( item.getDeviceName().toString() == "No Devices") { 71 | macAddress.setVisibility(View.INVISIBLE); 72 | line.setVisibility(View.INVISIBLE); 73 | RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams 74 | ((int) RelativeLayout.LayoutParams.WRAP_CONTENT, (int) RelativeLayout.LayoutParams.WRAP_CONTENT); 75 | params.addRule(RelativeLayout.CENTER_VERTICAL); 76 | params.addRule(RelativeLayout.CENTER_HORIZONTAL); 77 | holder.titleText.setLayoutParams(params); 78 | } 79 | 80 | return viewToUse; 81 | } 82 | 83 | 84 | } 85 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/java/com/tutsplus/matt/bluetoothscanner/DeviceListFragment.java: -------------------------------------------------------------------------------- 1 | package com.tutsplus.matt.bluetoothscanner; 2 | 3 | import android.app.Activity; 4 | import android.bluetooth.BluetoothAdapter; 5 | import android.database.Cursor; 6 | import android.database.sqlite.SQLiteDatabase; 7 | import android.os.Bundle; 8 | import android.support.v4.app.Fragment; 9 | import android.util.Log; 10 | import android.view.LayoutInflater; 11 | import android.view.View; 12 | import android.view.ViewGroup; 13 | import android.widget.AbsListView; 14 | import android.widget.AdapterView; 15 | import android.widget.ArrayAdapter; 16 | import android.widget.ListAdapter; 17 | import android.widget.TextView; 18 | 19 | import java.util.ArrayList; 20 | 21 | /** 22 | * A fragment representing a list of Items. 23 | *

24 | * Large screen devices (such as tablets) are supported by replacing the ListView 25 | * with a GridView. 26 | *

27 | * Activities containing this fragment MUST implement the {@link OnFragmentInteractionListener} 28 | * interface. 29 | */ 30 | public class DeviceListFragment extends Fragment implements AbsListView.OnItemClickListener{ 31 | 32 | private ArrayList deviceItemList; 33 | 34 | private OnFragmentInteractionListener mListener; 35 | private static BluetoothAdapter bTAdapter; 36 | 37 | /** 38 | * The fragment's ListView/GridView. 39 | */ 40 | private AbsListView mListView; 41 | 42 | /** 43 | * The Adapter which will be used to populate the ListView/GridView with 44 | * Views. 45 | */ 46 | private ArrayAdapter mAdapter; 47 | 48 | // TODO: Rename and change types of parameters 49 | public static DeviceListFragment newInstance(BluetoothAdapter adapter) { 50 | DeviceListFragment fragment = new DeviceListFragment(); 51 | bTAdapter = adapter; 52 | return fragment; 53 | } 54 | 55 | /** 56 | * Mandatory empty constructor for the fragment manager to instantiate the 57 | * fragment (e.g. upon screen orientation changes). 58 | */ 59 | public DeviceListFragment() { 60 | } 61 | 62 | @Override 63 | public void onCreate(Bundle savedInstanceState) { 64 | super.onCreate(savedInstanceState); 65 | 66 | 67 | Log.d("DEVICELIST", "Super called for DeviceListFragment onCreate\n"); 68 | deviceItemList = new ArrayList(); 69 | 70 | // TODO Scan for devices and add them to the list 71 | 72 | // If there are no devices, add an item that states so. It will be handled in the view. 73 | if(deviceItemList.size() == 0) { 74 | deviceItemList.add(new DeviceItem("No Devices", "", "false")); 75 | } 76 | 77 | Log.d("DEVICELIST", "DeviceList populated\n"); 78 | 79 | mAdapter = new DeviceListAdapter(getActivity(), deviceItemList, bTAdapter); 80 | 81 | Log.d("DEVICELIST", "Adapter created\n"); 82 | } 83 | 84 | @Override 85 | public View onCreateView(LayoutInflater inflater, ViewGroup container, 86 | Bundle savedInstanceState) { 87 | View view = inflater.inflate(R.layout.fragment_deviceitem_list, container, false); 88 | 89 | // Set the adapter 90 | mListView = (AbsListView) view.findViewById(android.R.id.list); 91 | ((AdapterView) mListView).setAdapter(mAdapter); 92 | 93 | // Set OnItemClickListener so we can be notified on item clicks 94 | mListView.setOnItemClickListener(this); 95 | 96 | return view; 97 | } 98 | 99 | @Override 100 | public void onAttach(Activity activity) { 101 | super.onAttach(activity); 102 | try { 103 | mListener = (OnFragmentInteractionListener) activity; 104 | } catch (ClassCastException e) { 105 | throw new ClassCastException(activity.toString() 106 | + " must implement OnFragmentInteractionListener"); 107 | } 108 | } 109 | 110 | @Override 111 | public void onDetach() { 112 | super.onDetach(); 113 | mListener = null; 114 | } 115 | 116 | @Override 117 | public void onItemClick(AdapterView parent, View view, int position, long id) { 118 | 119 | Log.d("DEVICELIST", "onItemClick position: " + position + 120 | " id: " + id + " name: " + deviceItemList.get(position).getDeviceName() + "\n"); 121 | if (null != mListener) { 122 | // Notify the active callbacks interface (the activity, if the 123 | // fragment is attached to one) that an item has been selected. 124 | mListener.onFragmentInteraction(deviceItemList.get(position).getDeviceName()); 125 | } 126 | 127 | } 128 | 129 | /** 130 | * The default content for this Fragment has a TextView that is shown when 131 | * the list is empty. If you would like to change the text, call this method 132 | * to supply the text it should use. 133 | */ 134 | public void setEmptyText(CharSequence emptyText) { 135 | View emptyView = mListView.getEmptyView(); 136 | 137 | if (emptyView instanceof TextView) { 138 | ((TextView) emptyView).setText(emptyText); 139 | } 140 | } 141 | 142 | /** 143 | * This interface must be implemented by activities that contain this 144 | * fragment to allow an interaction in this fragment to be communicated 145 | * to the activity and potentially other fragments contained in that 146 | * activity. 147 | *

148 | * See the Android Training lesson Communicating with Other Fragments for more information. 151 | */ 152 | public interface OnFragmentInteractionListener { 153 | // TODO: Update argument type and name 154 | public void onFragmentInteraction(String id); 155 | } 156 | 157 | } 158 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/java/com/tutsplus/matt/bluetoothscanner/ListActivity.java: -------------------------------------------------------------------------------- 1 | package com.tutsplus.matt.bluetoothscanner; 2 | 3 | import android.bluetooth.BluetoothAdapter; 4 | import android.content.Intent; 5 | import android.support.v4.app.FragmentManager; 6 | import android.support.v7.app.ActionBarActivity; 7 | import android.os.Bundle; 8 | import android.view.Menu; 9 | import android.view.MenuItem; 10 | 11 | 12 | public class ListActivity extends ActionBarActivity implements DeviceListFragment.OnFragmentInteractionListener { 13 | 14 | 15 | private DeviceListFragment mDeviceListFragment; 16 | private BluetoothAdapter BTAdapter; 17 | 18 | 19 | public static int REQUEST_BLUETOOTH = 1; 20 | 21 | 22 | @Override 23 | protected void onCreate(Bundle savedInstanceState) { 24 | super.onCreate(savedInstanceState); 25 | setContentView(R.layout.activity_list); 26 | 27 | //TODO Check if bluetooth is enabled 28 | 29 | FragmentManager fragmentManager = getSupportFragmentManager(); 30 | 31 | mDeviceListFragment = DeviceListFragment.newInstance(BTAdapter); 32 | fragmentManager.beginTransaction().replace(R.id.container, mDeviceListFragment).commit(); 33 | 34 | } 35 | 36 | @Override 37 | public boolean onCreateOptionsMenu(Menu menu) { 38 | // Inflate the menu; this adds items to the action bar if it is present. 39 | getMenuInflater().inflate(R.menu.menu_list, menu); 40 | return true; 41 | } 42 | 43 | @Override 44 | public boolean onOptionsItemSelected(MenuItem item) { 45 | // Handle action bar item clicks here. The action bar will 46 | // automatically handle clicks on the Home/Up button, so long 47 | // as you specify a parent activity in AndroidManifest.xml. 48 | int id = item.getItemId(); 49 | 50 | //noinspection SimplifiableIfStatement 51 | if (id == R.id.action_settings) { 52 | return true; 53 | } 54 | 55 | return super.onOptionsItemSelected(item); 56 | } 57 | 58 | @Override 59 | public void onFragmentInteraction(String id) { 60 | 61 | } 62 | } 63 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/drawable/corners.xml: -------------------------------------------------------------------------------- 1 | 2 | 5 | 6 | 7 | 9 | 10 | 11 | 12 | 17 | 18 | 19 | 20 | 22 | 23 | 24 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/layout/activity_list.xml: -------------------------------------------------------------------------------- 1 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/layout/device_grid_item.xml: -------------------------------------------------------------------------------- 1 | 2 | 7 | 8 | 9 | 24 | 25 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/layout/device_list_item.xml: -------------------------------------------------------------------------------- 1 | 2 | 7 | 8 | 9 | 23 | 24 | 31 | 45 | 46 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/layout/fragment_deviceitem_list.xml: -------------------------------------------------------------------------------- 1 | 2 | 5 | 6 | 17 | 18 | 22 | 33 | 34 | 37 | 38 | 39 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/menu/menu_list.xml: -------------------------------------------------------------------------------- 1 |

4 | 6 | 7 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/mipmap-hdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tutsplus/Android-BluetoothScannerStarterProject/e6c9c165c875de20b5879c1077ebc6ab9d166ddc/BluetoothScanner/app/src/main/res/mipmap-hdpi/ic_launcher.png -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/mipmap-mdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tutsplus/Android-BluetoothScannerStarterProject/e6c9c165c875de20b5879c1077ebc6ab9d166ddc/BluetoothScanner/app/src/main/res/mipmap-mdpi/ic_launcher.png -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/mipmap-xhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tutsplus/Android-BluetoothScannerStarterProject/e6c9c165c875de20b5879c1077ebc6ab9d166ddc/BluetoothScanner/app/src/main/res/mipmap-xhdpi/ic_launcher.png -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/mipmap-xxhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tutsplus/Android-BluetoothScannerStarterProject/e6c9c165c875de20b5879c1077ebc6ab9d166ddc/BluetoothScanner/app/src/main/res/mipmap-xxhdpi/ic_launcher.png -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tutsplus/Android-BluetoothScannerStarterProject/e6c9c165c875de20b5879c1077ebc6ab9d166ddc/BluetoothScanner/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/values-w820dp/dimens.xml: -------------------------------------------------------------------------------- 1 | 2 | 5 | 64dp 6 | 7 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/values/dimens.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 16dp 4 | 16dp 5 | 6 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/values/strings.xml: -------------------------------------------------------------------------------- 1 | 2 | BluetoothScanner 3 | Connect 4 | Disconnect 5 | Devices 6 | Settings 7 | Scan 8 | 9 | -------------------------------------------------------------------------------- /BluetoothScanner/app/src/main/res/values/styles.xml: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 7 | 8 | 9 | -------------------------------------------------------------------------------- /BluetoothScanner/build.gradle: -------------------------------------------------------------------------------- 1 | // Top-level build file where you can add configuration options common to all sub-projects/modules. 2 | 3 | buildscript { 4 | repositories { 5 | jcenter() 6 | } 7 | dependencies { 8 | classpath 'com.android.tools.build:gradle:1.2.2' 9 | 10 | // NOTE: Do not place your application dependencies here; they belong 11 | // in the individual module build.gradle files 12 | } 13 | } 14 | 15 | allprojects { 16 | repositories { 17 | jcenter() 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /BluetoothScanner/gradle.properties: -------------------------------------------------------------------------------- 1 | # Project-wide Gradle settings. 2 | 3 | # IDE (e.g. Android Studio) users: 4 | # Gradle settings configured through the IDE *will override* 5 | # any settings specified in this file. 6 | 7 | # For more details on how to configure your build environment visit 8 | # http://www.gradle.org/docs/current/userguide/build_environment.html 9 | 10 | # Specifies the JVM arguments used for the daemon process. 11 | # The setting is particularly useful for tweaking memory settings. 12 | # Default value: -Xmx10248m -XX:MaxPermSize=256m 13 | # org.gradle.jvmargs=-Xmx2048m -XX:MaxPermSize=512m -XX:+HeapDumpOnOutOfMemoryError -Dfile.encoding=UTF-8 14 | 15 | # When configured, Gradle will run in incubating parallel mode. 16 | # This option should only be used with decoupled projects. More details, visit 17 | # http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects 18 | # org.gradle.parallel=true -------------------------------------------------------------------------------- /BluetoothScanner/gradle/wrapper/gradle-wrapper.jar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/tutsplus/Android-BluetoothScannerStarterProject/e6c9c165c875de20b5879c1077ebc6ab9d166ddc/BluetoothScanner/gradle/wrapper/gradle-wrapper.jar -------------------------------------------------------------------------------- /BluetoothScanner/gradle/wrapper/gradle-wrapper.properties: -------------------------------------------------------------------------------- 1 | #Wed Apr 10 15:27:10 PDT 2013 2 | distributionBase=GRADLE_USER_HOME 3 | distributionPath=wrapper/dists 4 | zipStoreBase=GRADLE_USER_HOME 5 | zipStorePath=wrapper/dists 6 | distributionUrl=https\://services.gradle.org/distributions/gradle-2.2.1-all.zip 7 | -------------------------------------------------------------------------------- /BluetoothScanner/gradlew: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env bash 2 | 3 | ############################################################################## 4 | ## 5 | ## Gradle start up script for UN*X 6 | ## 7 | ############################################################################## 8 | 9 | # Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. 10 | DEFAULT_JVM_OPTS="" 11 | 12 | APP_NAME="Gradle" 13 | APP_BASE_NAME=`basename "$0"` 14 | 15 | # Use the maximum available, or set MAX_FD != -1 to use that value. 16 | MAX_FD="maximum" 17 | 18 | warn ( ) { 19 | echo "$*" 20 | } 21 | 22 | die ( ) { 23 | echo 24 | echo "$*" 25 | echo 26 | exit 1 27 | } 28 | 29 | # OS specific support (must be 'true' or 'false'). 30 | cygwin=false 31 | msys=false 32 | darwin=false 33 | case "`uname`" in 34 | CYGWIN* ) 35 | cygwin=true 36 | ;; 37 | Darwin* ) 38 | darwin=true 39 | ;; 40 | MINGW* ) 41 | msys=true 42 | ;; 43 | esac 44 | 45 | # For Cygwin, ensure paths are in UNIX format before anything is touched. 46 | if $cygwin ; then 47 | [ -n "$JAVA_HOME" ] && JAVA_HOME=`cygpath --unix "$JAVA_HOME"` 48 | fi 49 | 50 | # Attempt to set APP_HOME 51 | # Resolve links: $0 may be a link 52 | PRG="$0" 53 | # Need this for relative symlinks. 54 | while [ -h "$PRG" ] ; do 55 | ls=`ls -ld "$PRG"` 56 | link=`expr "$ls" : '.*-> \(.*\)$'` 57 | if expr "$link" : '/.*' > /dev/null; then 58 | PRG="$link" 59 | else 60 | PRG=`dirname "$PRG"`"/$link" 61 | fi 62 | done 63 | SAVED="`pwd`" 64 | cd "`dirname \"$PRG\"`/" >&- 65 | APP_HOME="`pwd -P`" 66 | cd "$SAVED" >&- 67 | 68 | CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar 69 | 70 | # Determine the Java command to use to start the JVM. 71 | if [ -n "$JAVA_HOME" ] ; then 72 | if [ -x "$JAVA_HOME/jre/sh/java" ] ; then 73 | # IBM's JDK on AIX uses strange locations for the executables 74 | JAVACMD="$JAVA_HOME/jre/sh/java" 75 | else 76 | JAVACMD="$JAVA_HOME/bin/java" 77 | fi 78 | if [ ! -x "$JAVACMD" ] ; then 79 | die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME 80 | 81 | Please set the JAVA_HOME variable in your environment to match the 82 | location of your Java installation." 83 | fi 84 | else 85 | JAVACMD="java" 86 | which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 87 | 88 | Please set the JAVA_HOME variable in your environment to match the 89 | location of your Java installation." 90 | fi 91 | 92 | # Increase the maximum file descriptors if we can. 93 | if [ "$cygwin" = "false" -a "$darwin" = "false" ] ; then 94 | MAX_FD_LIMIT=`ulimit -H -n` 95 | if [ $? -eq 0 ] ; then 96 | if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then 97 | MAX_FD="$MAX_FD_LIMIT" 98 | fi 99 | ulimit -n $MAX_FD 100 | if [ $? -ne 0 ] ; then 101 | warn "Could not set maximum file descriptor limit: $MAX_FD" 102 | fi 103 | else 104 | warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" 105 | fi 106 | fi 107 | 108 | # For Darwin, add options to specify how the application appears in the dock 109 | if $darwin; then 110 | GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" 111 | fi 112 | 113 | # For Cygwin, switch paths to Windows format before running java 114 | if $cygwin ; then 115 | APP_HOME=`cygpath --path --mixed "$APP_HOME"` 116 | CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` 117 | 118 | # We build the pattern for arguments to be converted via cygpath 119 | ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` 120 | SEP="" 121 | for dir in $ROOTDIRSRAW ; do 122 | ROOTDIRS="$ROOTDIRS$SEP$dir" 123 | SEP="|" 124 | done 125 | OURCYGPATTERN="(^($ROOTDIRS))" 126 | # Add a user-defined pattern to the cygpath arguments 127 | if [ "$GRADLE_CYGPATTERN" != "" ] ; then 128 | OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" 129 | fi 130 | # Now convert the arguments - kludge to limit ourselves to /bin/sh 131 | i=0 132 | for arg in "$@" ; do 133 | CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` 134 | CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option 135 | 136 | if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition 137 | eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` 138 | else 139 | eval `echo args$i`="\"$arg\"" 140 | fi 141 | i=$((i+1)) 142 | done 143 | case $i in 144 | (0) set -- ;; 145 | (1) set -- "$args0" ;; 146 | (2) set -- "$args0" "$args1" ;; 147 | (3) set -- "$args0" "$args1" "$args2" ;; 148 | (4) set -- "$args0" "$args1" "$args2" "$args3" ;; 149 | (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; 150 | (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; 151 | (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; 152 | (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; 153 | (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; 154 | esac 155 | fi 156 | 157 | # Split up the JVM_OPTS And GRADLE_OPTS values into an array, following the shell quoting and substitution rules 158 | function splitJvmOpts() { 159 | JVM_OPTS=("$@") 160 | } 161 | eval splitJvmOpts $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS 162 | JVM_OPTS[${#JVM_OPTS[*]}]="-Dorg.gradle.appname=$APP_BASE_NAME" 163 | 164 | exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" 165 | -------------------------------------------------------------------------------- /BluetoothScanner/gradlew.bat: -------------------------------------------------------------------------------- 1 | @if "%DEBUG%" == "" @echo off 2 | @rem ########################################################################## 3 | @rem 4 | @rem Gradle startup script for Windows 5 | @rem 6 | @rem ########################################################################## 7 | 8 | @rem Set local scope for the variables with windows NT shell 9 | if "%OS%"=="Windows_NT" setlocal 10 | 11 | @rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. 12 | set DEFAULT_JVM_OPTS= 13 | 14 | set DIRNAME=%~dp0 15 | if "%DIRNAME%" == "" set DIRNAME=. 16 | set APP_BASE_NAME=%~n0 17 | set APP_HOME=%DIRNAME% 18 | 19 | @rem Find java.exe 20 | if defined JAVA_HOME goto findJavaFromJavaHome 21 | 22 | set JAVA_EXE=java.exe 23 | %JAVA_EXE% -version >NUL 2>&1 24 | if "%ERRORLEVEL%" == "0" goto init 25 | 26 | echo. 27 | echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 28 | echo. 29 | echo Please set the JAVA_HOME variable in your environment to match the 30 | echo location of your Java installation. 31 | 32 | goto fail 33 | 34 | :findJavaFromJavaHome 35 | set JAVA_HOME=%JAVA_HOME:"=% 36 | set JAVA_EXE=%JAVA_HOME%/bin/java.exe 37 | 38 | if exist "%JAVA_EXE%" goto init 39 | 40 | echo. 41 | echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 42 | echo. 43 | echo Please set the JAVA_HOME variable in your environment to match the 44 | echo location of your Java installation. 45 | 46 | goto fail 47 | 48 | :init 49 | @rem Get command-line arguments, handling Windowz variants 50 | 51 | if not "%OS%" == "Windows_NT" goto win9xME_args 52 | if "%@eval[2+2]" == "4" goto 4NT_args 53 | 54 | :win9xME_args 55 | @rem Slurp the command line arguments. 56 | set CMD_LINE_ARGS= 57 | set _SKIP=2 58 | 59 | :win9xME_args_slurp 60 | if "x%~1" == "x" goto execute 61 | 62 | set CMD_LINE_ARGS=%* 63 | goto execute 64 | 65 | :4NT_args 66 | @rem Get arguments from the 4NT Shell from JP Software 67 | set CMD_LINE_ARGS=%$ 68 | 69 | :execute 70 | @rem Setup the command line 71 | 72 | set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar 73 | 74 | @rem Execute Gradle 75 | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% 76 | 77 | :end 78 | @rem End local scope for the variables with windows NT shell 79 | if "%ERRORLEVEL%"=="0" goto mainEnd 80 | 81 | :fail 82 | rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of 83 | rem the _cmd.exe /c_ return code! 84 | if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 85 | exit /b 1 86 | 87 | :mainEnd 88 | if "%OS%"=="Windows_NT" endlocal 89 | 90 | :omega 91 | -------------------------------------------------------------------------------- /BluetoothScanner/settings.gradle: -------------------------------------------------------------------------------- 1 | include ':app' 2 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ### Tuts+ Tutorial: Create a Bluetooth Scanner With Android's Bluetooth API 2 | 3 | #### Instructor: Matthew Kim 4 | 5 | In this tutorial, we explore what Bluetooth is and how to use the Android Bluetooth API to create an app that scans and displays nearby Bluetooth devices. Additionally, we look over the basics of connecting with a nearby Bluetooth device. 6 | 7 | Starter project for the Tuts+ tutorial: [Create a Bluetooth Scanner With Android's Bluetooth API](http://code.tutsplus.com/tutorials/create-a-bluetooth-scanner-with-androids-bluetooth-api--cms-24084) 8 | 9 | **Read this tutorial on [Tuts+](https://code.tutsplus.com)** 10 | --------------------------------------------------------------------------------