首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何启用I2C of Raspberry Pi3模块(使用Android作为操作系统)

如何启用I2C of Raspberry Pi3模块(使用Android作为操作系统)
EN

Stack Overflow用户
提问于 2017-12-11 14:07:34
回答 1查看 657关注 0票数 2

我正在尝试开发一个样本Android-Things应用程序使用Raspberry模块3,它从BME280传感器读取温度并显示在app上。我已经下载了示例项目,但在打开带有地址的I2cDevice时面临一个问题。

下面是代码详细信息:

私有静态最终int地址= 0x76;

代码语言:javascript
复制
private void printDeviceId() {
    List<String> deviceList = managerService.getI2cBusList();
    if (deviceList.isEmpty()) {
        Log.i(TAG, "No I2C bus available on this device.");
    } else {
        Log.i(TAG, "List of available devices: " + deviceList);
    }
    I2cDevice device = null;
    try {
        device = managerService.openI2cDevice(deviceList.get(0), ADDRESS);
        Log.d(TAG, "Device ID byte: 0x" + Integer.toHexString(device.readRegByte(0xD0)));
    } catch (IOException|RuntimeException e) {
        Log.e(TAG, e.getMessage(), e);
    } finally {
        try {
            device.close();
        } catch (Exception ex) {
            Log.d(TAG, "Error closing device");
        }
    }
}

实际上它在openI2cDevice方法上崩溃,而deviceList只有一个设备,即deviceList.get(0)是"I2C1"

这里是崩溃日志: android.os.ServiceSpecificException: I/O错误(代码5) com.google.android.things.pio.PioException: android.os.ServiceSpecificException: I/O错误(代码5)在com.google.android.things.pio.I2cDeviceImpl.readRegByte(I2cDeviceImpl.java:81) at com.example.pitepmerature.MainActivity.printDeviceId(MainActivity.java:92) atcom.example.pitepmerature.MainActivity.onCreate(MainActivity.java:34) at android.app.Activity.performCreate(Activity.java:7000) at android.app.Activity.performCreate(Activity.java:6991)在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1214) at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2731)在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2856) at android.app.ActivityThread-包装11(未知来源:0)android.app.ActivityThread$H.handleMessage(ActivityThread.java:1589) at android.os.Handler.dispatchMessage(Handler.java:106) at androidandroid.app.ActivityThread.main(ActivityThread.java:6494) at .os.Looper.loop(Looper.java:164) at java.lang.reflect.Method.invoke(原生方法)在com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)由: android.os.Parcel.readException(Parcel.java:2018)上的android.os.ServiceSpecificException: I/O错误(代码5)引起在android.os.Parcel.readException(Parcel.java:1950) at com.google.android.things.pio.IPeripheralManagerClient$Stub$Proxy.I2cReadRegByte(IPeripheralManagerClient.java:1301)在com.google.android.things.pio.I2cDeviceImpl.readRegByte(I2cDeviceImpl.java:79) at com.example.pitepmerature.MainActivity.printDeviceId(MainActivity.java:92)在com.example.pitepmerature.MainActivity.onCreate(MainActivity.java:34) at android.app.Activity.performCreate(Activity.java:7000) at android.app.Activityandroid.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1214) .performCreate(Activity.java:6991)

我也尝试将地址更改为0x77,但没有工作。也浏览了许多博客,但没有找到解决办法。

博客链接,我更喜欢编码和设置所有内容:

http://zenandroid.io/writing-a-driver-for-android-things-bme280-humidity-sensor/

请帮帮忙。

EN

回答 1

Stack Overflow用户

发布于 2017-12-22 05:29:42

谢谢大家的有益评论。我终于找到了解决方案,实际上问题在于我正在执行的示例。另外,我已经找到了正确的引脚配置。下面是示例项目git链接:

https://github.com/androidthings/drivers-samples/tree/master/bmx280

另外,检查我所遵循的引脚图。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47754702

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档