判断iPhone设备是carplay和iPod的方法
Carplay 参考代码: int UdevIsCarplay(int nVid, int nPid)//int UsbModeSwitch(pUdevStatus pStatus) { ; if (nVid != APPLE_IDVENDOR){ ; } r = libusb_init(NULL); ) { pError("failed to initialise libusb\n"); ; } struct libusb_device_handle *devh = NULL; devh = libusb_open_device_with_vid_pid(NULL, nVid, nPid); if (NULL == devh) { pError("Could not find/open device(%s)\n", strerror(errno)); r = ;goto end; } //libusb_device *dev = libusb_get_device(devh); ];// if tmp is {0x01, 0x00, 0x00, 0x00} support carplay;else close carplay. memset(tmp, , ); r = libusb_control_transfer(devh, , , tmp, , );//Page 715 //r = libusb_control_transfer(devh, 0x40, 0x51, 0x01, 0, NULL, 0, 0);//Page 716 UsbModeSwitch ) { pError("UdevIsCarplay --- get support capabilities error !!! r = %d(%s)\n", r, strerror(errno)); r = ; } ) { pError("short write (%d)\n", r); r = ; } else { //int nTmp = tmp[0] + (int)(tmp[1]<<8) + (int)(tmp[2]<<16) + (int)(tmp[3]<<24); pInfo(],tmp[],tmp[],tmp[]); ]) r = ; } libusb_close(devh); end: libusb_exit(NULL); return r ; }
邹工: 参考代码如下: void* UdevEventMonitorThread(void* pParam) { int fd; struct udev_device *dev; struct udev_monitor *mon; pUdevContainer pUdevCon = (pUdevContainer)pParam; mon = udev_monitor_new_from_netlink(pUdevCon->m_pUdev, "udev");//"kernel"或"udev"。基于"kernel"的事件通知要早于"udev",但相关的设备结点未必创建完成 if (mon == NULL) { pError("udev_monitor_new_from_netlink FAILED \n"); return; } ) { pError("UdevAddFilter FAILED \n"); return; } ) { pError("udev_monitor_enable_receiving FAILED \n"); return; } UdevStatus status[];//status[0] is OTG atatus; status[1] is HOST atatus; //pUdevStatus status = calloc(2, sizeof(UdevStatus)); memset(status, , * sizeof(UdevStatus)); status[].m_eUdevStatus = status[].m_eUdevStatus = UDEVOTHER; /* Get the file descriptor (fd) for the monitor.This fd will get passed to select() */ fd = udev_monitor_get_fd(mon); ); struct epoll_event ev; ev.events = EPOLLIN; ev.data.fd = fd; epoll_ctl(epollfd, EPOLL_CTL_ADD, fd, &ev); ]; pInfo("UdevEventMonitorThread --- start ok !!!!!!!!!!! \n"); /* This section will run continuously, calling usleep() at the end of each pass. This is to demonstrate how to use a udev_monitor in a non-blocking way. */ ) { ; //pError("epoll_wait event start!\n"); , -);//-1 is block,>=0 is noblock; //pWarn("epoll_wait event ok ret = %d!\n",ret); ; i < ret; i++) { /* Make the call to receive the device. select() ensured that this will not block. */ dev = udev_monitor_receive_device(mon); if (dev) { const char* szAction = udev_device_get_action(dev); const char* szDevNode = udev_device_get_devnode(dev); const char* szSysPath = udev_device_get_syspath(dev); int nStatus = SetUdevStatus(pUdevCon, szAction);//pStatus, if(UDEVOTHER == nStatus) { //pDebug("nStatus = 0(OTHER); goto end; } //pDebug("nActionStatus = %d\n",nStatus); int nPort = UdevPortJudge(pUdevCon, szSysPath, nStatus); if(OTHERPORT == nPort) { //pDebug("nPort = OTHERPORT(%d)\n", nPort); goto end; } pUdevStatus pStatus = &status[nPort-];//status+(nPort-1)*sizeof(UdevStatus); //pDebug(" status[%d]=(%d),pStatus->m_eUdevStatus(%d),pStatus->m_nChecked(%d)~~~~~~~~~~~~~~\n", nPort-1, nStatus,pStatus->m_eUdevStatus,pStatus->m_nChecked); if(nStatus == UDEVCHANGE) { pStatus->m_eUdevStatus = nStatus; print_all_properties(pUdevCon, pStatus, dev, "prop"); goto end; //pDebug("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n"); } else if(nStatus == UDEVREMOVE) { if(UDEVREMOVE != pStatus->m_eUdevStatus)//插入USB上电可能没有检测到设备,导致拔出状态错误 { ResetStatus(pStatus); if(NULL != szDevNode) pUdevCon->m_pUdevEvent->UdevStatusProc(pUdevCon->m_eUdevPort, pStatus->m_eUdevStatus, USBNODEV, szDevNode); else pUdevCon->m_pUdevEvent->UdevStatusProc(pUdevCon->m_eUdevPort, pStatus->m_eUdevStatus, USBNODEV, "USBNODEV"); pUdevCon->m_eUdevPort = OTHERPORT; } goto end; } //ADD event pStatus->m_eUdevStatus = nStatus; )//nStatus == ADD { print_all_attributes(pStatus, dev, "attr"); ) { pInfo("[DM-SMING] %d\n", __LINE__); if(pStatus->m_eUdevType == USBHUB) pUdevCon->m_pUdevEvent->UdevStatusProc(nPort, nStatus, USBHUB, "USBHUB"); else if(pStatus->m_eUdevType == USBOTHER) pUdevCon->m_pUdevEvent->UdevStatusProc(nPort, nStatus, USBOTHER, "USBOTHER"); } ) { pInfo("[DM-SMING] %d\n", __LINE__); int nCheck = UdevCheckContinue(pStatus, szDevNode); ) { pInfo("[DM-SMING] %d\n", __LINE__); if(pStatus->m_eUdevType == USBHID) pUdevCon->m_pUdevEvent->UdevStatusProc(nPort, nStatus, USBHID, "USBHID"); else pUdevCon->m_pUdevEvent->UdevStatusProc(nPort, nStatus, pStatus->m_eUdevType, szDevNode); } } } end: udev_device_unref(dev); } else { pDebug("No Device from receive_device().\n");// An error occured. } } //else // usleep(100*1000); //fflush(stdout); } return; } static void print_all_properties(pUdevContainer pUdevCon, pUdevStatus pStatus, struct udev_device *device, const char *key) { struct udev_list_entry *properties; udev_list_entry_foreach(properties, udev_device_get_properties_list_entry(device)) { const char *szName = udev_list_entry_get_name(properties); const char *szValue = udev_list_entry_get_value(properties); if(NULL != szValue) pDebug(" [%s]{%s}==\"%s\"\n", key, szName, szValue); ) { ) { //通过回调给上层USBNORESPOND消息,设备节点为”USBNORESPOND“ pUdevCon->m_pUdevEvent->UdevStatusProc(pUdevCon->m_eUdevPort, pStatus->m_eUdevStatus, USBNORESPOND, "USBNORESPOND"); return; } } } }
库文件在附件中。
链接: http://pan.baidu.com/s/1qXSSB84 密码: ptgu
判断iPhone设备是carplay和iPod的方法的更多相关文章
- 关于iPhone设备不同显示尺寸适配的一些方法
关于iPhone设备不同显示尺寸适配的一些方法 ------关于适配的理解------ 1.什么是适配? 适配是对不同硬件和系统软件的适应,硬件包括屏幕显示,处理器,内存等等(目前主要是屏幕适配, ...
- 判断 iPhone 是否已插入 SIM 卡的方法
判断 iPhone 是否插入了 SIM 卡,可以参考苹果官网的 systemconfigure framework 教程,将下面的代码复制到头文件 extern NSString* const kCT ...
- 判断iPhone和iPad 判断设备版本
//判断iPhone和iPad #define IS_IPHONE (!IS_IPAD) #define IS_IPAD (UI_USER_INTERFACE_IDIOM() != UIUserInt ...
- ios5和ios6横竖屏支持及ipad和iphone设备的判断
ios5和ios6横竖屏支持及ipad和iphone设备的判断 判断是ipad还是iphone设备.此定义在PayViewControllerDemo-Prefix.pch 定义如下: #define ...
- PHP判断iPhone、iPad、Android、PC设备的方法
因为工作需要我们需要知道是什么样了用户访问了我网站了,现在的移动设备种类多了,下面我们一起来看小编整理的一段php判断iPhone.iPad.Android.PC设备的例子. 注意:本代码的PC系统为 ...
- Java判断访问设备为手机、微信、PC工具类
package com.lwj.util; import javax.servlet.http.HttpServletRequest; /** * 判断访问设备为PC或者手机--工具类 * * @de ...
- 得到设备是何种iPhone设备 + 怎么获得启动页面图片
一.前言 今天做一个功能,需要动态的获得启动页,然后根据不同设备去使用不用的启动页图片. 二.正文 常规来说,我们直接判断是何种设备,然后通过name去获得图片选择性加载即可.但是实际上遇到的两个问题 ...
- JS判断访问设备、客户端操作系统类型
先给出一个实例:判断windows.linux.android 复制以下代码另存为html文件即可. <html> <head> <title>判断操作系统< ...
- PHP简单判断手机设备的方法
本文实例讲述了PHP简单判断手机设备的方法.分享给大家供大家参考,具体如下: 现在移动互联网越来越发到,很多的网站都普及了手机端浏览,为了更好的让网页在手机端显示,我们都选择了使用CSS媒体查询制作响 ...
随机推荐
- c# 数据库更新操作-文本更新和数值更新小差别
1.文本更新 string strName; sql = "update 模式表 a SET 模式名称 ='"+ strName +"'where a.模式ID =&qu ...
- 百度地图在某架构下找不到符号.a文件的问题
1.现象: 就是说找不到符号给i386的架构(就是模拟器).或者找不到符号给arm架构(真机). ld: warning: ignoring file /Users/pufang/xcode/demo ...
- Mybatis学习笔记(一) 之框架原理
原生态JDBC编程中问题总结 1.单独使用jdbc连接数据库 maven依赖包: <!-- mysql --> <dependency> <groupId>mysq ...
- HTML <dl> 标签
<html><body><h2>一个定义列表:</h2><dl> <dt>计算机</dt> <dd&g ...
- 【转】UWP 捕获全局异常
转自:http://www.cnblogs.com/youngytj/p/4749004.html 异步(async)方法中的异常无法被App的UnhandledException捕获的问题 这是一个 ...
- 七、rdd究竟是什么
RDD是个抽象类,定义了诸如map().reduce()等方法,但实际上继承RDD的派生类一般只要实现两个方法: def getPartitions: Array[Partition] def com ...
- python 数据清洗之字符串处理
在数据分析中,特别是文本分析中,字符处理需要耗费极大的精力, 因而了解字符处理对于数据分析而言,也是一项很重要的能力. 字符串处理方法 首先我们先了解下都有哪些基础方法 首先我们了解下字符串的拆分sp ...
- My Eclipse Security Alert
SECURITY ALERT: INTEGRITY CHECK ERROR This product did not pass the MyEclipse integrity check. This ...
- php 语言特点
PS:绝大多数用php的企业/ 项目 活不到雇佣得起月薪35k以上的php程序员那一天,也是php码农在10年经验的时候普遍不如java程序员的原因之一. PS2: 由于薪资提升太快,很多php码农跳 ...
- 关于Two-Pass标记连通域个数
关于Two-Pass标记连通域个数 背景 在完成图像的一系列处理后,得到二值图,一般会统计目标数量,即是获取连通域个数,这里采用TwoPass的方法. 基本思想 在Two-pass连通域标记中,第一次 ...