判断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媒体查询制作响 ...
随机推荐
- python cookbook学习1
python cookbook学习笔记 第一章 文本(1) 1.1每次处理一个字符(即每次处理一个字符的方式处理字符串) print list('theString') #方法一,转列表 结果:['t ...
- 大数据应用之Windows平台Hbase客户端Eclipse开发环境搭建
大数据应用之Windows平台Hbase客户端Eclipse开发环境搭建 大数据应用之Windows平台Hbase客户端Eclipse环境搭建-Java版 作者:张子良 版权所有,转载请注明出处 引子 ...
- 在C中判断变量存储类型(字符常量/数组/动态变量)
在C中判断变量存储类型(字符常量/数组/动态变量) 在chinaunix论坛上有人问到关于变量存府类型的问题,我觉得可以写个测试代码加深大家对内存使用和布局的理解.下面我把原问题及处理办法贴出来,限供 ...
- Java远程调用邮件服务器,实现邮件发送
写这篇文章的背景是公司Android客户端需要实现一个功能,实现类似于密码找回或者用户注册完发送一个邮件给用户的功能,当然这些逻辑客户端只负责请求自己的服务端,自己的服务端再去请求邮件服务器. 邮件服 ...
- C++ 全局构造函数调用的顺序
C++的全局类和静态类的构造函数是在main函数之前调用的.但是,不同的类的构造函数以什么顺序调用呢? 对于g++编译器来说,这个顺序是由链接时,文件顺序决定的. 我们用一个例子来说明这一点. 我们有 ...
- ASP.NET Core + Angular 2 Template for Visual Studio
多个月以来,我和多个Github上的社区贡献者一起建立支持库.包,我们最终的目的是希望完成这样一个作为起点的模板,也就是基于把Typescript代码和Angular2宿主在ASP.NET Core项 ...
- css ie6最小高度问题
最小高度问题: 这个最小高度 min-height:的问题,因为min-height:只在IE7\FF中起作用.至于这个IE6死活就是不认.而我这个页面又必需得用这个最小高度来定. 但头痛的是I ...
- C#的FTP上传下载的实验
前段时间做了一个FTP操作服务器文件的实验,现在把一些经验写下来,免得忘记. 1.上传的处理:目标文件夹A上传到服务器指定目录.先检索服务器目录中有无同名文件夹,若有,则先改名,上传成功后再删除,上传 ...
- MVC实现省级联动
前言 省级联动的效果,网上现成的都有很多,各种JS实现,Jquery实现等等,今天我们要讲的是在MVC里面,如何更方便.更轻量的实现省级联动呢? 实现效果如下: 具体实现 如图所示,在HTML页非常简 ...
- C#中的文件操作1
1. 文件操作常用相关类 a)File //操作文件,静态类,对文件整体操作.拷贝.删除.剪切等. b)Directory //操作目录(文件夹),静态类 c)Di ...