• This repository has been archived on 31/Aug/2018
  • Stars
    star
    210
  • Rank 187,585 (Top 4 %)
  • Language
    Objective-C
  • Created over 10 years ago
  • Updated almost 9 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

An application that enables the Xbox One Controller to be used on a Mac

Xbox One Controller Enabler

alt tag

Project deprecated

Use 360Controller instead (it supports Xbox One controllers).

What is it?

Microsoft released in 2013 their new console Xbox One along with its new Controller. Just like the Xbox 360's controller, it is expected that it will be compatible with computers as well. A Windows driver is expected to be released in 2014, but nothing was announced with respect to Mac.

This application communicates with the Xbox One Controller and uses a Virtual Joystick to simulate the controller.

Where can I get it?

Get your compiled copy here. Source code is available on GitHub.

For OS X 10.10 Yosemite users

For extended compatibility, you will need to enable kext dev mode. To do so, run the following command on your terminal:
sudo nvram boot-args=kext-dev-mode=1

What's under the hood?

The USB communication is done using Apple's IOKit framework. The controller is polled every 5 ms looking for changes in the controller.

This application is built on top of Alexandr Serkov's great VHID and WirtualJoy frameworks, from his WJoy project. These are responsible for the Virtual HID that the system will see as a controller.

This application doesn't work with this or that game!

This is an ongoing project that will eventually be promoted from its current beta stage to a final version. Feel free to report issues. Bugs will be tracked as soon as possible.

As long as I have time to learn more on how to implement the stuff it requires, improvements will be done. Usability and compatibility are the main goals for now. Additional controllers, automatic connection, bells and whistles will come later.

How to build?

Update: a libusb installation is no longer needed as the library has been included in the project.

Just open the project in Xcode and run it!

I'd like to contribute!

Well... This is on GitHub, isn't it? Fork this project, write some code and open a pull request. You know what to do!

Thanks to:

  • Kyle Lemons for figuring out how to power the controller (check his xbox project).
  • Brandon Jones for nicely laying out the button mapping of the controller.
  • Lucas Assis for his work on Windows drivers for the controller.
  • Alexandr Serkov for providing nice Virtual HID drivers (WJoy).