Отправка PythonJavaClass в функцию Java с помощью pyjnius - PullRequest
0 голосов
/ 12 мая 2018

Я пытаюсь отправить PythonJavaClass (NokeServiceListener) в mNokeService.registerNokeListener (), но он продолжает выдавать ошибку там, и при печати объекта NokeServiceListener я получаю nokeLock.NokeServiceListener объект в 0x97389b70, который не похож на javaобъект, а затем я получаю сообщение об ошибке JNI DETECTED ERROR IN APPLICATION: использование недопустимого задания 0x6e617278

from jnius import autoclass,PythonJavaClass,cast,java_method

Context =  autoclass('android.content.Context')
    Parcelable = autoclass('android.os.Parcelable')
    Intent = autoclass('android.content.Intent')
    Uri = autoclass('android.net.Uri')
    PythonActivity = autoclass('org.kivy.android.PythonActivity')

    NokeDeviceManagerService = autoclass('com.noke.nokemobilelibrary.NokeDeviceManagerService')
    #LocalBinder = autoclass('com.noke.nokemobilelibrary.NokeDeviceManagerService$LocalBinder')
    NokeDevice = autoclass('com.noke.nokemobilelibrary.NokeDevice')
    NokeMobileError = autoclass('com.noke.nokemobilelibrary.NokeMobileError')
    #NokeServiceListener =autoclass('com.noke.nokemobilelibrary.NokeServiceListener')

    global mNokeService

    #@run_on_ui_thread
    class NokeApi():
        def __init__(self):
            self.python_activity = PythonActivity.mActivity
            self.service_connection = ServiceConnection()

        def initiateNokeService(self):
            currentActivity = cast('android.app.Activity', self.python_activity)
            context = cast('android.content.Context', currentActivity.getApplicationContext())

            nokeIntent = Intent()
            nokeIntent.setClassName(context, 'com.noke.nokemobilelibrary.NokeDeviceManagerService')
            self.python_activity.bindService(nokeIntent,self.service_connection,Context.BIND_AUTO_CREATE)

        def onCreate(self):
            self.initiateNokeService()

    #@run_on_ui_thread
    class ServiceConnection(PythonJavaClass):
        __javainterfaces__ = ['android.content.ServiceConnection']
        __javacontext__ = 'app'

        @java_method('(Landroid/content/ComponentName;Landroid/os/IBinder;)V')
        def onServiceConnected(self,className, rawBinder):
            print 'debug1'
            #nokeDeviceManagerService = NokeDeviceManagerService()
            #localBinder = LocalBinder()
            nokeService = cast('com.noke.nokemobilelibrary.NokeDeviceManagerService$LocalBinder',rawBinder)
            global mNokeService
            mNokeService = nokeService.getService()
            print mNokeService
            #mNokeService = ((NokeDeviceManagerService.LocalBinder)rawBinder).getService()
            print 'debug2'
            mNokeServiceListener = NokeServiceListener()
            #mNokeServiceListener = cast('com.noke.nokemobilelibrary.NokeServiceListener',nokeServiceListener)
            print mNokeServiceListener
            print 'debug2.5'
            mNokeService.registerNokeListener(mNokeServiceListener)
            print 'debug3'
            noke1 = NokeDevice("NOKE3P", "F7:F3:F1:2C:66:25")
            print 'debug4'
            mNokeService.addNokeDevice(noke1)
            print 'debug5'
            mNokeService.setUploadUrl("https://coreapi-sandbox.appspot.com/upload/")
            print 'debug6'
            mNokeService.startScanningForNokeDevices()
            print "Scanning for devices"

            if not mNokeService.initialize():
                print "Unable to initialize Bluetooth"

    class NokeServiceListener(PythonJavaClass):
        __javainterfaces__ = ['com.noke.nokemobilelibrary.NokeServiceListener']
        __javacontext__ = 'app'

        def __init__(self):
            pass

        @java_method('(Lcom/noke/nokemobilelibrary/NokeDevice;)V')
        def onNokeDiscovered(self,noke):
            print "Connecting to Noke"
            mNokeService.connectToNoke(self,noke)

        @java_method('(Lcom/noke/nokemobilelibrary/NokeDevice;)V')
        def onNokeConnecting(self,noke):
            print "Connecting"

        @java_method('(Lcom/noke/nokemobilelibrary/NokeDevice;)V')
        def onNokeConnected(self,noke):
            print "Noke Connected"
            self.requestUnlock(noke)

        @java_method('(Lcom/noke/nokemobilelibrary/NokeDevice;)V')
        def onNokeSyncing(self,noke):
            print "NOKE SYNCING"

        @java_method('(Lcom/noke/nokemobilelibrary/NokeDevice;)V')
        def onNokeUnlocked(self,noke):
            print 'Noke Unlocked'

        @java_method('(Lcom/noke/nokemobilelibrary/NokeDevice;)V')
        def onNokeDisconnected(self,noke):
            print "Noke Disconnected"
            self.mNokeService.uploadData()
            self.mNokeService.startScanningForNokeDevices()

        @java_method('(I)V')
        def onBluetoothStatusChanged(self,bluetoothStatus):
            pass

        @java_method('(Lcom/noke/nokemobilelibrary/NokeDevice;ILjava/lang/String;)V')
        def onError(self,noke, error, message):
            pass

        def requestUnlock(self,noke):
            msg = '{"function":"Noke_Unlock","session":"%s","mac":"%s"}' % (noke.getSession(),noke.getMac())
            rsp = connectToServer(_host, _port, msg)
            if rsp['result'] == "success":
                commandStr = rsp["commands"]
                noke.sendCommands(commandStr)
            else:
                print "Access Denied"

Мне кажется, что ошибка заключается в том, что я передаю не Java-объект в Java-функцию, но я 'мы уже пытались преобразовать объект в com.noke.nokemobilelibrary.NokeServiceListener, и это тоже не сработало.Код всегда выдает ошибку после отладки 2.5, поэтому что-то идет не так между этими двумя шагами, но я не могу понять, что.

Ответы [ 2 ]

0 голосов
/ 14 мая 2018
class NokeServiceListener(PythonJavaClass):
    def __init__(self, callback):
        super().__init__()
        self.callback = callback

Это будет работать, потому что python не является Java / C #.базовый класс init не будет вызван, если вы не напишите его явно.

0 голосов
/ 12 мая 2018

Добавление

class NokeServiceListener(PythonJavaClass):
    def __init__(self, callback):
        super(NokeServiceListener, self).__init__()
        self.callback = callback

, казалось, решил эту проблему ... хотя понятия не имею, почему.

...