summaryrefslogtreecommitdiff
path: root/Defogger/src/no/mork/android/defogger/ScannerActivity.java
blob: 5cc59898dbc4d8e02f6d2fa8cd973fb5aecee4c8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
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
package no.mork.android.defogger;

import android.app.Activity;
import android.bluetooth.BluetoothAdapter;
import android.bluetooth.BluetoothDevice;
import android.bluetooth.le.BluetoothLeScanner;
import android.bluetooth.le.ScanCallback;
import android.bluetooth.le.ScanResult;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;
import android.widget.ListView;
import android.widget.Toast;


// lots of nice examples: https://www.programcreek.com/java-api-examples/index.php?api=android.bluetooth.le.ScanCallback

public class ScannerActivity extends Activity {
    private static String msg = "Defogger Scanning: ";
    // Stops scanning after 10 seconds.
    private static final long SCAN_PERIOD = 10000;
    private BluetoothAdapter bluetoothAdapter;
    private boolean mScanning;
    private Handler handler;
    private ScanCallback leScanCallback;
    private BluetoothLeScanner btScanner;
    private ScanListAdapter scanlistAdapter;
    
    @Override
    protected void onCreate(Bundle savedInstanceState) {
	super.onCreate(savedInstanceState);
	setContentView(R.layout.activity_scanner);

        ListView listView = (ListView) findViewById(R.id.scanlist_view);
	scanlistAdapter = new ScanListAdapter(this, R.layout.scanitem, R.id.scanitem);
	listView.setAdapter(scanlistAdapter);
	scanlistAdapter.addDevice("foo");
	
	bluetoothAdapter = BluetoothAdapter.getDefaultAdapter();
	btScanner = bluetoothAdapter.getBluetoothLeScanner();

	if (btScanner == null) {
	    Log.d(msg, "getBluetoothLeScanner() returned NULL");
	}
	leScanCallback = new ScanCallback() {
		@Override
		public void onScanResult(int callbackType, ScanResult result) {
		    Log.d(msg, "onScanResult()");
		    super.onScanResult(callbackType, result);
		    scanlistAdapter.addDevice(result.getDevice().getAddress());
		}
	    };
	
	CharSequence text = "Hello toast!";

	Toast.makeText(getApplicationContext(), text, Toast.LENGTH_LONG).show();
	Intent intent = new Intent();
	intent.putExtra("scan_ret", "This data is returned when scan activity is finished.");
	setResult(RESULT_OK, intent);
    }

    @Override
    protected void onResume() {
	super.onResume();
	//scanForCamera(true);
	//finish();
    }

    protected void scanForCamera(final boolean enable) {
	mScanning = enable;
	Log.d(msg, "entered scanForCamera()");
	if (btScanner == null) {
	    return;
	}
 	if (enable) {
            // Stops scanning after a pre-defined scan period.
            handler.postDelayed(new Runnable() {
                @Override
                public void run() {
                    mScanning = false;
                    btScanner.stopScan(leScanCallback);
                }
		}, SCAN_PERIOD);

	    Log.d(msg, "starting scan()");
            btScanner.startScan(leScanCallback);
	    Log.d(msg, "scan started()");
        } else {
            btScanner.stopScan(leScanCallback);
        }
    }
}