1:修改库文件为(C:\Users\administrator\AppData\Local\Arduino15\packages\digistump\hardware\avr\1.6.7\libraries\DigisparkKeyboard\DigiKeyboard.h)
/*
* Based on Obdev's AVRUSB code and under the same license.
*
* TODO: Make a proper file header. :-)
* Modified for Digispark by Digistump
*/
#ifndef __DigiKeyboard_h__
#define __DigiKeyboard_h__
#include <Arduino.h>
#include <avr/pgmspace.h>
#include <avr/interrupt.h>
#include <avr/delay.h>
#include <string.h>
#include "usbdrv.h"
#include "scancode-ascii-table.h"
// TODO: Work around Arduino 12 issues better.
//#include <WConstants.h>
//#undef int()
typedef uint8_t byte;
#define BUFFER_SIZE 2 // Minimum of 2: 1 for modifiers + 1 for keystroke
static uchar idleRate; // in 4 ms units
/* We use a simplifed keyboard report descriptor which does not support the
* boot protocol. We don't allow setting status LEDs and but we do allow
* simultaneous key presses.
* The report descriptor has been created with usb.org's "HID Descriptor Tool"
* which can be downloaded from http://www.usb.org/developers/hidpage/.
* Redundant entries (such as LOGICAL_MINIMUM and USAGE_PAGE) have been omitted
* for the second INPUT item.
*/
const PROGMEM char usbHidReportDescriptor[USB_CFG_HID_REPORT_DESCRIPTOR_LENGTH] = {
// /* USB report descriptor */
0x05, 0x01, // USAGE_PAGE (Generic Desktop)
0x09, 0x06, // USAGE (Keyboard)
0xa1, 0x01, // COLLECTION (Application)
0x85, 0x01, // Report ID (1)
0x05, 0x07, // USAGE_PAGE (Keyboard)
0x19, 0xe0, // USAGE_MINIMUM (Keyboard LeftControl)
0x29, 0xe7, // USAGE_MAXIMUM (Keyboard Right GUI)
0x15, 0x00, // LOGICAL_MINIMUM (0)
0x25, 0x01, // LOGICAL_MAXIMUM (1)
0x75, 0x01, // REPORT_SIZE (1)
0x95, 0x08, // REPORT_COUNT (8)
0x81, 0x02, // INPUT (Data,Var,Abs)
0x95, 0x01, // REPORT_COUNT (simultaneous keystrokes)
0x75, 0x08, // REPORT_SIZE (8)
0x25, 0x65, // LOGICAL_MAXIMUM (101)
0x19, 0x00, // USAGE_MINIMUM (Reserved (no event indicated))
0x29, 0x65, // USAGE_MAXIMUM (Keyboard Application)
0x81, 0x00, // INPUT (Data,Ary,Abs)
0xc0 , // END_COLLECTION
0x05, 0x0c, // USAGE_PAGE (Consumer Devices)
0x09, 0x01, // USAGE (Consumer Control)
0xa1, 0x01, // COLLECTION (Application)
0x85, 0x02, // Report ID2
0x15, 0x00, // LOGICAL_MINIMUM (0)
0x25, 0x01, // LOGICAL_MAXIMUM (1)
0x09, 0xb6, // USAGE (Scan Previous Track)
0x09, 0xb5, // USAGE (Scan Next Track)
0x09, 0xe9, // USAGE (Volume Up)
0x09, 0xea, // USAGE (Volume Down)
0x09, 0xe2, // USAGE (Mute)
0x09, 0xCD, // USAGE (Play/Pause)
0x09, 0xb3, // USAGE (Fast Forward)
0x09, 0xb7, // USAGE (Stop)
0x75, 0x01, // REPORT_SIZE (1)
0x95, 0x08, // REPORT_COUNT (8)
0x81, 0x42, // INPUT (Data,Var,Abs,Null)
0xc0, // END_COLLECTION
};
/* Keyboard usage values, see usb.org's HID-usage-tables document, chapter
* 10 Keyboard/Keypad Page for more codes.
*/
#define MOD_CONTROL_LEFT (1 << 0)
#define MOD_SHIFT_LEFT (1 << 1)
#define MOD_ALT_LEFT (1 << 2)
#define MOD_GUI_LEFT (1 << 3)
#define MOD_CONTROL_RIGHT (1 << 4)
#define MOD_SHIFT_RIGHT (1 << 5)
#define MOD_ALT_RIGHT (1 << 6)
#define MOD_GUI_RIGHT (1 << 7)
#define KEY_A 4
#define KEY_B 5
#define KEY_C 6
#define KEY_D 7
#define KEY_E 8
#define KEY_F 9
#define KEY_G 10
#define KEY_H 11
#define KEY_I 12
#define KEY_J 13
#define KEY_K 14
#define KEY_L 15
#define KEY_M 16
#define KEY_N 17
#define KEY_O 18
#define KEY_P 19
#define KEY_Q 20
#define KEY_R 21
#define KEY_S 22
#define KEY_T 23
#define KEY_U 24
#define KEY_V 25
#define KEY_W 26
#define KEY_X 27
#define KEY_Y 28
#define KEY_Z 29
#define KEY_1 30
#define KEY_2 31
#define KEY_3 32
#define KEY_4 33
#define KEY_5 34
#define KEY_6 35
#define KEY_7 36
#define KEY_8 37
#define KEY_9 38
#define KEY_0 39
#define KEY_ENTER 40
#define KEY_SPACE 44
#define KEY_F1 58
#define KEY_F2 59
#define KEY_F3 60
#define KEY_F4 61
#define KEY_F5 62
#define KEY_F6 63
#define KEY_F7 64
#define KEY_F8 65
#define KEY_F9 66
#define KEY_F10 67
#define KEY_F11 68
#define KEY_F12 69
#define KEY_ARROW_LEFT 0x50
class DigiKeyboardDevice : public Print
{
public:
DigiKeyboardDevice()
{
cli();
usbDeviceDisconnect();
_delay_ms(250);
usbDeviceConnect();
usbInit();
sei();
// TODO: Remove the next two lines once we fix
// missing first keystroke bug properly.
memset(reportBuffer, 0, sizeof(reportBuffer));
usbSetInterrupt(reportBuffer, sizeof(reportBuffer));
}
void update()
{
usbPoll();
}
// delay while updating until we are finished delaying
void delay(long milli)
{
unsigned long last = millis();
while (milli > 0)
{
unsigned long now = millis();
milli -= now - last;
last = now;
update();
}
}
//sendKeyStroke: sends a key press AND release
void sendKeyStroke( byte keyStroke)
{
sendKeyStroke(keyStroke, 0);
}
//sendKeyStroke: sends a key press AND release with modifiers
void sendKeyStroke( byte keyStroke, byte modifiers)
{
sendKeyPress(0x01,keyStroke, modifiers);
// This stops endlessly repeating keystrokes:
sendKeyPress(0, 0, 0);
}
//sendKey Press : sends a key press only - no release
//to release the key, send again with keyPress=0
void sendKeyPress( byte keyPress)
{
sendKeyPress(keyPress, 0);
}
//sendKey Press : sends a key press only, with modifiers - no release
//to release the key, send again with keyPress=0
void sendKeyPress( byte keyPress, byte modifiers)
{
while (!usbInterruptIsReady())
{
// Note: We wait until we can send keyPress
// so we know the previous keyPress was
// sent.
usbPoll();
_delay_ms(5);
}
memset(reportBuffer, 0, sizeof(reportBuffer));
reportBuffer[0] = modifiers;
reportBuffer[1] = keyPress;
reportBuffer[2] = 0;
usbSetInterrupt(reportBuffer, sizeof(reportBuffer));
}
void sendKeyPress(byte report_id, byte keyPress, byte modifiers)
{
while (!usbInterruptIsReady())
{
// Note: We wait until we can send keyPress
// so we know the previous keyPress was
// sent.
usbPoll();
_delay_ms(5);
}
memset(reportBuffer, 0, sizeof(reportBuffer));
reportBuffer[0] = report_id;
reportBuffer[1] = modifiers;
reportBuffer[2] = keyPress;
usbSetInterrupt(reportBuffer, sizeof(reportBuffer));
}
size_t write(uint8_t chr)
{
uint8_t data = pgm_read_byte_near(ascii_to_scan_code_table + (chr - 8));
sendKeyStroke(data & 0b01111111, data >> 7 ? MOD_SHIFT_RIGHT : 0);
return 1;
}
//private: TODO: Make friend?
uchar reportBuffer[3]; // buffer for HID reports [ 1 modifier byte + (len-1) key strokes]
using Print::write;
};
DigiKeyboardDevice DigiKeyboard = DigiKeyboardDevice();
#ifdef __cplusplus
extern "C"
{
#endif
// USB_PUBLIC uchar usbFunctionSetup
uchar usbFunctionSetup(uchar data[8])
{
usbRequest_t *rq = (usbRequest_t *)((void *)data);
usbMsgPtr = DigiKeyboard.reportBuffer; //
if ((rq->bmRequestType & USBRQ_TYPE_MASK) == USBRQ_TYPE_CLASS)
{
/* class request type */
if (rq->bRequest == USBRQ_HID_GET_REPORT)
{
/* wValue: ReportType (highbyte), ReportID (lowbyte) */
/* we only have one report type, so don't look at wValue */
// TODO: Ensure it's okay not to return anything here?
return 0;
}
else if (rq->bRequest == USBRQ_HID_GET_IDLE)
{
//usbMsgPtr = &idleRate;
//return 1;
return 0;
}
else if (rq->bRequest == USBRQ_HID_SET_IDLE)
{
idleRate = rq->wValue.bytes[1];
}
}
else
{
/* no vendor specific requests implemented */
}
return 0;
}
#ifdef __cplusplus
} // extern "C"
#endif
#endif // __DigiKeyboard_h__
2:代码文件
#include "DigiKeyboard.h"
#include <Adafruit_NeoPixel.h>
int i = 0;
int i2 = 0;
int c = 0;
int rote = 0;
int wheel = 0;
const int ledPin = 1; // RGB LED 引脚
const int keyPin = 0; // 按键引脚
const int keyPin2 = 2; // 按键引脚
int R[5] = {0x00,0xFF,0x00,0xFF,0x00};
int G[5] = {0x00,0xFF,0xFF,0x00,0x00};
int B[5] = {0x00,0xFF,0xFF,0xFF,0x00};
int k21[5]={0x02,0x02,0x02,0x02,0x01}; //reprot_id
int k22[5]={0x00,0x00,0x00,0x00,0x1e};//key
int k23[5]={0x01,0x04,0x10,0x40,0x00}; //modifiers
int k11[5]={0x02,0x02,0x02,0x01,0x01};//reprot_id
int k12[5]={0x00,0x00,0x00,0x0f,0x27};//key
int k13[5]={0x02,0x08,0x20,0x05,0x00};//modifiers
int Brightness = 64; // 亮度值(0-255)
Adafruit_NeoPixel led = Adafruit_NeoPixel(2, ledPin, NEO_GRB + NEO_KHZ800);
uint32_t Wheel(byte WheelPos){
WheelPos = 255 - WheelPos;
if (WheelPos < 85){
return led.Color(255 - WheelPos * 3, 0, WheelPos * 3);
}
if (WheelPos < 170){
WheelPos -= 85;
return led.Color(0, WheelPos * 3, 255 - WheelPos * 3);
}
WheelPos -= 170;
return led.Color(WheelPos * 3, 255 - WheelPos * 3, 0);
}
void setup(){
pinMode(keyPin, INPUT_PULLUP);
pinMode(keyPin2, INPUT_PULLUP);
led.begin();
led.setBrightness(Brightness);
led.show();
}
void loop(){
if (digitalRead(keyPin) == LOW and digitalRead(keyPin2) != LOW){
if(i == 0 or i > 10){
DigiKeyboard.sendKeyPress(k21[c],k22[c],k23[c]);
DigiKeyboard.sendKeyPress(k21[c],0x00,0x00);
}
i++;
}else{
i = 0;
}
if (digitalRead(keyPin2) == LOW){
if(i2 == 0 or i2 > 10){
if(digitalRead(keyPin) == LOW){
c++;
if(c > 4){
c = 0;
}
led.setPixelColor(0, R[c], G[c], B[c]);
led.setPixelColor(1, R[c], G[c], B[c]);
led.show();
}else{
DigiKeyboard.sendKeyPress(k11[c],k12[c],k13[c]);
DigiKeyboard.sendKeyPress(k11[c],0x00,0x00);
}
}
DigiKeyboard.delay(25);
i2 ++;
}else{
i2 = 0;
}
DigiKeyboard.delay(25); // 防抖延时
if(c == 0){
led.setPixelColor(0, Wheel((rote) & 255));
led.setPixelColor(1, Wheel((32+rote) & 255));
led.show();
rote++;
if (rote == 255){
rote = 0;
}
}
}

