- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在用Android Studio中的Java开发第一个蓝牙应用程序。它是一个国际象棋游戏,我想将当前的场地信息从一个设备发送到另一个设备。我查看了https://developer.android.com/guide/topics/connectivity/bluetooth.html处的概述和介绍,在我想连接两个设备之前,它工作正常。我可以在listView中显示另一个设备,当我单击listView中的项目时,我想连接两个设备,但是两个设备都崩溃了,并且出现了这个异常:java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare()
我已经将初始化从Service类移动到Manager类以及Activity上,原因是我认为我需要在UI-Thread中进行初始化,但没有任何效果
这是Bluetoothmanager-Class女巫启动蓝牙并启动接收器以监听设备
public class BluetoothManager extends Observable {
private BluetoothAdapter adapter;
private Context context;
private UUID uuid;
private BluetoothService service;
private BluetoothDevice connectedDevice;
public BluetoothManager(Context c){
adapter = BluetoothAdapter.getDefaultAdapter();
context = c;
uuid = UUID.fromString("1c0bbc73-ae02-4272-b528-752b6b0977c4");
}
public boolean supportBluetooth(){
if(adapter == null){
return false;
}else{
return true;
}
}
public void isEnabled(){
if(!adapter.isEnabled()){
Intent intent = new Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE);
((Activity) context).startActivityForResult(intent, 1);
//registerReceiver();
}
enableDiscoverability();
}
private BroadcastReceiver receiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
if(action.equals(BluetoothDevice.ACTION_FOUND)){
setChanged();
notifyObservers(intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE));
}
}
};
public BroadcastReceiver getReceiver() {
return receiver;
}
public void enableDiscoverability(){
Intent intent = new Intent(BluetoothAdapter.ACTION_REQUEST_DISCOVERABLE);
context.startActivity(intent);
AcceptThread acceptThread = new AcceptThread();
acceptThread.start();
}
public Set<BluetoothDevice> getPaired(){
return adapter.getBondedDevices();
}
public void manageSocket(BluetoothSocket socket){
Handler handler = new Handler(){
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
System.out.println(msg.toString());
}
};
service = new BluetoothService(socket, handler);
service.write();
}
public void connect(BluetoothDevice device){
ConnectThread thread = new ConnectThread(device);
thread.start();
}
private class AcceptThread extends Thread{
private final BluetoothServerSocket serverSocket;
private AcceptThread() {
BluetoothServerSocket tmp = null;
try{
tmp = adapter.listenUsingInsecureRfcommWithServiceRecord(context.getString(R.string.app_name), uuid);
}catch (IOException e){
System.out.println("FAILED");
}
serverSocket = tmp;
}
@Override
public void run() {
BluetoothSocket socket = null;
while (true){
try{
socket = serverSocket.accept();
if(socket != null){
manageSocket(socket);
serverSocket.close();
break;
}
}catch (IOException e){
System.out.println("FAILED");
break;
}
}
}
public void cancel(){
try {
serverSocket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
private class ConnectThread extends Thread {
private final BluetoothSocket socket;
private final BluetoothDevice device;
public ConnectThread(BluetoothDevice mdevice) {
BluetoothSocket tmp = null;
device = mdevice;
try {
tmp = device.createRfcommSocketToServiceRecord(uuid);
} catch (IOException e) {
System.out.println("FAILED");
}
socket = tmp;
}
public void run() {
adapter.cancelDiscovery();
try {
socket.connect();
} catch (IOException connectException) {
// Unable to connect; close the socket and return.
try {
socket.close();
} catch (IOException closeException) {
System.out.println("FAILED");
}
return;
}
// The connection attempt succeeded. Perform work associated with
// the connection in a separate thread.
manageSocket(socket);
}
// Closes the client socket and causes the thread to finish.
public void cancel() {
try {
socket.close();
} catch (IOException e) {
System.out.println("FAILED");
}
}
}
}
public class BluetoothService {
private static final String TAG = "MY_APP_DEBUG_TAG";
private Handler handler;
private BluetoothSocket socket;
private ConnectedThread thread;
public BluetoothService(BluetoothSocket socket, Handler handler){
this.socket = socket;
this.handler = handler;
thread = new ConnectedThread();
thread.start();
}
private interface MessageConstants {
public static final int MESSAGE_READ = 0;
public static final int MESSAGE_WRITE = 1;
public static final int MESSAGE_TOAST = 2;
}
private class ConnectedThread extends Thread {
private final BluetoothSocket mmSocket;
private final InputStream mmInStream;
private final OutputStream mmOutStream;
private byte[] mmBuffer;
public ConnectedThread() {
mmSocket = socket;
InputStream tmpIn = null;
OutputStream tmpOut = null;
try {
tmpIn = socket.getInputStream();
} catch (IOException e) {
Log.e(TAG, "Error occurred when creating input stream", e);
}
try {
tmpOut = socket.getOutputStream();
} catch (IOException e) {
Log.e(TAG, "Error occurred when creating output stream", e);
}
mmInStream = tmpIn;
mmOutStream = tmpOut;
}
public void run() {
mmBuffer = new byte[1024];
int numBytes;
while (true) {
try {
numBytes = mmInStream.read(mmBuffer);
Message readMsg = handler.obtainMessage( MessageConstants.MESSAGE_READ, numBytes, -1,mmBuffer);
readMsg.sendToTarget();
} catch (IOException e) {
Log.d(TAG, "Input stream was disconnected", e);
break;
}
}
}
public void write(byte[] bytes) {
try {
mmOutStream.write(bytes);
Message writtenMsg = handler.obtainMessage(MessageConstants.MESSAGE_WRITE, -1, -1, mmBuffer);
writtenMsg.sendToTarget();
} catch (IOException e) {
Log.e(TAG, "Error occurred when sending data", e);
// Send a failure message back to the activity.
Message writeErrorMsg = handler.obtainMessage(MessageConstants.MESSAGE_TOAST);
Bundle bundle = new Bundle();
bundle.putString("toast", "Couldn't send data to the other device");
writeErrorMsg.setData(bundle);
handler.sendMessage(writeErrorMsg);
}
}
public void cancel() {
try {
mmSocket.close();
} catch (IOException e) {
Log.e(TAG, "Could not close the connect socket", e);
}
}
}
public Handler getHandler() {
return handler;
}
public void write(){
String s = "HALLO WELT";
byte[] bytes = s.getBytes();
thread.write(bytes);
}
public void setHandler(Handler handler) {
this.handler = handler;
}
}
public class ChessActivity extends AppCompatActivity implements Observer {
private RelativeLayout layout;
private Game game;
private ChessCanvas canvas;
private BluetoothManager manager;
private List<BluetoothDevice> devices;
private ListView deviceList;
private DeviceListAdapter adapter;
private TextView status;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_chess);
Persister.init(this);
layout = findViewById(R.id.layout);
deviceList = findViewById(R.id.deviceList);
status = findViewById(R.id.status);
devices = new ArrayList<>();
adapter = new DeviceListAdapter(this, android.R.layout.simple_list_item_1, (List) devices);
deviceList.setAdapter(adapter);
canvas = new ChessCanvas(this);
layout.addView(canvas);
game = new Game(canvas);
deviceList.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
manager.connect((BluetoothDevice) parent.getItemAtPosition(position));
}
});
canvas.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View view, MotionEvent motionEvent) {
if (game.getPoints() == null || game.getPoints().isEmpty() || game.touchedOther(motionEvent)) {
game.getFigure(motionEvent);
} else {
game.turn(motionEvent);
}
Persister.persist(game.getField());
game.update();
return false;
}
});
start();
}
private void start() {
startBluetooth();
if(Persister.getGame() == null) {
game.createField();
Persister.setGame(game.getField());
Persister.persist(game.getField());
}else{
game.setField(Persister.getGame());
}
game.update();
}
private void startBluetooth() {
manager = new BluetoothManager(this);
if(manager.supportBluetooth()){
manager.isEnabled();
devices.addAll(manager.getPaired());
registerReceiver(manager.getReceiver(), new IntentFilter(BluetoothDevice.ACTION_FOUND));
}else{
System.out.println("KEIN BLUETOTH");
}
displayBluetoothList();
}
@Override
public void update(Observable o, Object arg) {
BluetoothDevice device = (BluetoothDevice) arg;
devices.add(device);
displayBluetoothList();
}
private void displayBluetoothList() {
adapter.notifyDataSetChanged();
deviceList.setVisibility(View.VISIBLE);
layout.removeView(deviceList);
AlertDialog adb = new AlertDialog.Builder(this).create();
adb.setTitle("Bluetooth Geräte");
adb.setView(deviceList);
adb.show();
}
@Override
protected void onPause() {
super.onPause();
unregisterReceiver(manager.getReceiver());
}
}
最佳答案
错误消息并不表示您必须移动代码。它说您必须在创建新处理程序之前调用Looper.prepare()
。
关于java - 我必须在哪里初始化处理程序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60655802/
我是 Spring 新手,这就是我想要做的事情: 我正在使用一个基于 Maven 的库,它有自己的 Spring 上下文和 Autowiring 字段。 它的bean配置文件是src/test/res
我在我的测试脚本中有以下列表初始化: newSequenceCore=["ls", "ns", "*", "cm", "*", "ov", "ov", "ov", "ov", "kd"] (代表要在控
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: Class construction with initial values 当我查看 http://en.
我得到了成员变量“objectCount”的限定错误。编译器还返回“ISO C++ 禁止非常量静态成员的类内初始化”。这是主类: #include #include "Tree.h" using n
我有如下所示的a.h class A { public: void doSomething()=0; }; 然后我有如下所示的b.h #include "a.h" class b: publi
我需要解析 Firebase DataSnapshot (一个 JSON 对象)转换成一个数据类,其属性包括 enum 和 list。所以我更喜欢通过传递 DataSnapshot 来手动解析它进入二
我使用 JQuery 一段时间了,我总是使用以下代码来初始化我的 javascript: $(document).ready( function() { // Initalisation logic
这里是 Objective-C 菜鸟。 为什么会这样: NSString *myString = [NSString alloc]; [myString initWithFormat:@"%f", s
我无法让核心数据支持的 NSArrayController 在我的代码中正常工作。下面是我的代码: pageArrayController = [[NSArrayController alloc] i
我对这一切都很陌生,并且无法将其安装到我的后端代码中。它去哪里?在我的页脚下面有我所有的 JS? 比如,这是什么意思: Popup initialization code should be exec
这可能是一个简单的问题,但是嘿,我是初学者。 所以我创建了一个程序来计算一些东西,它目前正在控制台中运行。我决定向其中添加一个用户界面,因此我使用 NetBeans IDE 中的内置功能创建了一个 J
我有 2 个 Controller ,TEST1Controller 和 TEST2Controller 在TEST2Controller中,我有一个initialize()函数设置属性值。 如果我尝
据我所知, dependentObservable 在声明时会进行计算。但如果某些值尚不存在怎么办? 例如: var viewModel ={}; var dependentObservable1 =
我正在阅读 POODR 这本书,它使用旧语法进行默认值初始化。我想用新语法实现相同的功能。 class Gear attr_reader :chainring, :cog, :wheel de
我按照 polymer 教程的说明进行操作: https://www.polymer-project.org/3.0/start/install-3-0 (我跳过了可选部分) 但是,在我执行命令“po
很抱歉问到一个非常新手的Kotlin问题,但是我正在努力理解与构造函数和初始化有关的一些东西。 我有这个类和构造函数: class TestCaseBuilder constructor(
假设我们有一个包含 30 列和 30 行的网格。 生命游戏规则简而言之: 一个小区有八个相邻小区 当一个细胞拥有三个存活的相邻细胞时,该细胞就会存活 如果一个细胞恰好有两个或三个活的相邻细胞,那么它就
我是 MQTT 和 Android 开放附件“AOA” 的新手。在阅读教程时,我意识到,在尝试写入 ByteArrayOutputStream 类型的变量之前,应该写入 0 或 0x00首先到该变量。
我有 2 个 Controller ,TEST1Controller 和 TEST2Controller 在TEST2Controller中,我有一个initialize()函数设置属性值。 如果我尝
我有一个inotify /内核问题。我正在使用“inotify” Python项目进行观察,但是,我的问题仍然是固有的关于inotify内核实现的核心。 Python inotify项目处理递归ino
我是一名优秀的程序员,十分优秀!