mirror of
https://github.com/Artemis-RGB/Artemis
synced 2025-12-13 05:48:35 +00:00
Added C++ project
This commit is contained in:
parent
c28783b461
commit
04158dce39
1
.gitignore
vendored
1
.gitignore
vendored
@ -189,3 +189,4 @@ FakesAssemblies/
|
|||||||
|
|
||||||
# Visual Studio 6 workspace options file
|
# Visual Studio 6 workspace options file
|
||||||
*.opt
|
*.opt
|
||||||
|
*.opendb
|
||||||
|
|||||||
@ -5,6 +5,8 @@ VisualStudioVersion = 14.0.24720.0
|
|||||||
MinimumVisualStudioVersion = 10.0.40219.1
|
MinimumVisualStudioVersion = 10.0.40219.1
|
||||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Artemis", "Artemis\Artemis.csproj", "{ED9997A2-E54C-4E9F-9350-62BE672C3ABE}"
|
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Artemis", "Artemis\Artemis.csproj", "{ED9997A2-E54C-4E9F-9350-62BE672C3ABE}"
|
||||||
EndProject
|
EndProject
|
||||||
|
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "LogiLed2Artemis", "LogiLed2Artemis\LogiLed2Artemis.vcxproj", "{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}"
|
||||||
|
EndProject
|
||||||
Global
|
Global
|
||||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||||
CD_ROM|Any CPU = CD_ROM|Any CPU
|
CD_ROM|Any CPU = CD_ROM|Any CPU
|
||||||
@ -54,6 +56,34 @@ Global
|
|||||||
{ED9997A2-E54C-4E9F-9350-62BE672C3ABE}.SingleImage|x64.Build.0 = Release|x64
|
{ED9997A2-E54C-4E9F-9350-62BE672C3ABE}.SingleImage|x64.Build.0 = Release|x64
|
||||||
{ED9997A2-E54C-4E9F-9350-62BE672C3ABE}.SingleImage|x86.ActiveCfg = Release|x86
|
{ED9997A2-E54C-4E9F-9350-62BE672C3ABE}.SingleImage|x86.ActiveCfg = Release|x86
|
||||||
{ED9997A2-E54C-4E9F-9350-62BE672C3ABE}.SingleImage|x86.Build.0 = Release|x86
|
{ED9997A2-E54C-4E9F-9350-62BE672C3ABE}.SingleImage|x86.Build.0 = Release|x86
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.CD_ROM|Any CPU.ActiveCfg = Release|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.CD_ROM|Any CPU.Build.0 = Release|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.CD_ROM|x64.ActiveCfg = Release|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.CD_ROM|x64.Build.0 = Release|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.CD_ROM|x86.ActiveCfg = Release|Win32
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.CD_ROM|x86.Build.0 = Release|Win32
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.Debug|Any CPU.ActiveCfg = Debug|Win32
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.Debug|x64.ActiveCfg = Debug|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.Debug|x64.Build.0 = Debug|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.Debug|x86.ActiveCfg = Debug|Win32
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.Debug|x86.Build.0 = Debug|Win32
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.DVD-5|Any CPU.ActiveCfg = Release|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.DVD-5|Any CPU.Build.0 = Release|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.DVD-5|x64.ActiveCfg = Debug|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.DVD-5|x64.Build.0 = Debug|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.DVD-5|x86.ActiveCfg = Debug|Win32
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.DVD-5|x86.Build.0 = Debug|Win32
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.Release|Any CPU.ActiveCfg = Release|Win32
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.Release|x64.ActiveCfg = Release|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.Release|x64.Build.0 = Release|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.Release|x86.ActiveCfg = Release|Win32
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.Release|x86.Build.0 = Release|Win32
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.SingleImage|Any CPU.ActiveCfg = Release|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.SingleImage|Any CPU.Build.0 = Release|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.SingleImage|x64.ActiveCfg = Release|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.SingleImage|x64.Build.0 = Release|x64
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.SingleImage|x86.ActiveCfg = Release|Win32
|
||||||
|
{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}.SingleImage|x86.Build.0 = Release|Win32
|
||||||
EndGlobalSection
|
EndGlobalSection
|
||||||
GlobalSection(SolutionProperties) = preSolution
|
GlobalSection(SolutionProperties) = preSolution
|
||||||
HideSolutionNode = FALSE
|
HideSolutionNode = FALSE
|
||||||
|
|||||||
@ -1,17 +1,24 @@
|
|||||||
using System.Collections.Generic;
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Diagnostics;
|
||||||
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using Artemis.Models;
|
using Artemis.Models;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
|
||||||
namespace Artemis.DAL
|
namespace Artemis.DAL
|
||||||
{
|
{
|
||||||
internal class ProfileProvider
|
internal class ProfileProvider
|
||||||
{
|
{
|
||||||
|
private List<ProfileModel> _profiles;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Get all profiles
|
/// Get all profiles
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <returns>All profiles</returns>
|
/// <returns>All profiles</returns>
|
||||||
public List<ProfileModel> GetAll()
|
public List<ProfileModel> GetAll()
|
||||||
{
|
{
|
||||||
|
ReadProfiles();
|
||||||
return new List<ProfileModel>();
|
return new List<ProfileModel>();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -33,5 +40,34 @@ namespace Artemis.DAL
|
|||||||
public void AddOrUpdate(ProfileModel profile)
|
public void AddOrUpdate(ProfileModel profile)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void ReadProfiles()
|
||||||
|
{
|
||||||
|
CheckProfiles();
|
||||||
|
_profiles = new List<ProfileModel>();
|
||||||
|
|
||||||
|
// Create the directory structure
|
||||||
|
var profileFolder = Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments) + @"\Artemis\profiles";
|
||||||
|
var profileFiles = Directory.GetFiles(profileFolder, "*.json", SearchOption.AllDirectories);
|
||||||
|
|
||||||
|
// Parse the JSON files into objects and add them if they are valid
|
||||||
|
foreach (var file in profileFiles)
|
||||||
|
{
|
||||||
|
var prof = JsonConvert.DeserializeObject<ProfileModel>(File.ReadAllText(file));
|
||||||
|
if (prof.GameName?.Length > 1 && prof.KeyboardName?.Length > 1 && prof.Name?.Length > 1)
|
||||||
|
_profiles.Add(prof);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void CheckProfiles()
|
||||||
|
{
|
||||||
|
// Create the directory structure
|
||||||
|
var profileFolder = Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments) + @"\Artemis\profiles";
|
||||||
|
if (Directory.Exists(profileFolder))
|
||||||
|
return;
|
||||||
|
|
||||||
|
Directory.CreateDirectory(profileFolder);
|
||||||
|
Debug.WriteLine("Place presets");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -18,7 +18,7 @@ namespace Artemis.KeyboardProviders.Logitech
|
|||||||
Name = "Logitech G910 RGB";
|
Name = "Logitech G910 RGB";
|
||||||
CantEnableText = "Couldn't connect to your Logitech G910.\n" +
|
CantEnableText = "Couldn't connect to your Logitech G910.\n" +
|
||||||
"Please check your cables and updating the Logitech Gaming Software\n" +
|
"Please check your cables and updating the Logitech Gaming Software\n" +
|
||||||
$"A minimum version of 8.81.15 is required. (Detected {_versionString})\n\n" +
|
"A minimum version of 8.81.15 is required.\n\n" +
|
||||||
"If needed, you can select a different keyboard in Artemis under settings.";
|
"If needed, you can select a different keyboard in Artemis under settings.";
|
||||||
Height = 6;
|
Height = 6;
|
||||||
Width = 21;
|
Width = 21;
|
||||||
@ -42,7 +42,12 @@ namespace Artemis.KeyboardProviders.Logitech
|
|||||||
|
|
||||||
// Turn it into one long number...
|
// Turn it into one long number...
|
||||||
var version = int.Parse($"{majorNum}{minorNum}{buildNum}");
|
var version = int.Parse($"{majorNum}{minorNum}{buildNum}");
|
||||||
_versionString = $"{majorNum}.{minorNum}.{buildNum}";
|
CantEnableText = "Couldn't connect to your Logitech G910.\n" +
|
||||||
|
"Please check your cables and updating the Logitech Gaming Software\n" +
|
||||||
|
$"A minimum version of 8.81.15 is required (detected {majorNum}.{minorNum}.{buildNum}).\n\n" +
|
||||||
|
"If the detected version differs from the version LGS is reporting, reinstall LGS or see the FAQ.\n\n" +
|
||||||
|
"If needed, you can select a different keyboard in Artemis under settings.";
|
||||||
|
|
||||||
return version >= 88115;
|
return version >= 88115;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -118,7 +118,7 @@ namespace Artemis.Modules.Games.TheDivision
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Parses Division key data to game data
|
// Parses Division key data to game data
|
||||||
private void InterpertrateDivisionKey(int[] parts)
|
private void InterpertrateDivisionKey(IReadOnlyList<int> parts)
|
||||||
{
|
{
|
||||||
var keyCode = parts[1];
|
var keyCode = parts[1];
|
||||||
var rPer = parts[2];
|
var rPer = parts[2];
|
||||||
|
|||||||
Binary file not shown.
104
Artemis/LogiLed2Artemis/Logger.cpp
Normal file
104
Artemis/LogiLed2Artemis/Logger.cpp
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
// Original work by VRocker https://github.com/VRocker/LogiLed2Corsair
|
||||||
|
// I'm mainly a C# developer, and these modification aren't a piece of art, but it suits our needs.
|
||||||
|
|
||||||
|
// The MIT License (MIT)
|
||||||
|
//
|
||||||
|
// Copyright (c) 2015 VRocker
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
// of this software and associated documentation files (the "Software"), to deal
|
||||||
|
// in the Software without restriction, including without limitation the rights
|
||||||
|
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
// copies of the Software, and to permit persons to whom the Software is
|
||||||
|
// furnished to do so, subject to the following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
|
// copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
// SOFTWARE.
|
||||||
|
|
||||||
|
#include "Logger.h"
|
||||||
|
|
||||||
|
#include <time.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdarg.h>
|
||||||
|
|
||||||
|
|
||||||
|
// Ok this looks butt-ugleh but its just to force the default log level to debug if we compile in debug
|
||||||
|
#ifdef _DEBUG
|
||||||
|
LogLevel CLogger::m_eLogLevel = LogLevel::Debug;
|
||||||
|
#else
|
||||||
|
LogLevel CLogger::m_eLogLevel = LogLevel::All;
|
||||||
|
#endif
|
||||||
|
FILE* CLogger::m_pFile = 0;
|
||||||
|
|
||||||
|
void CLogger::InitLogging(const char* szFile)
|
||||||
|
{
|
||||||
|
if (!m_pFile)
|
||||||
|
{
|
||||||
|
m_pFile = fopen(szFile, "a+");
|
||||||
|
if (!m_pFile)
|
||||||
|
{
|
||||||
|
// Hum, we couldn't open the file for writing
|
||||||
|
printf("ERROR: Unable to open log file %s.\n", szFile);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void CLogger::EndLogging(void)
|
||||||
|
{
|
||||||
|
if (m_pFile)
|
||||||
|
{
|
||||||
|
fclose(m_pFile);
|
||||||
|
m_pFile = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void CLogger::OutputLog_s(const char* sz, const LogLevel eLevel)
|
||||||
|
{
|
||||||
|
// If the level of this log entry is less important than what we are told to log, just return
|
||||||
|
if (eLevel < m_eLogLevel)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// If we don't have a file to write to, bail.
|
||||||
|
if (!m_pFile)
|
||||||
|
return;
|
||||||
|
|
||||||
|
char szOutput[512] = {0};
|
||||||
|
|
||||||
|
time_t rawtime;
|
||||||
|
struct tm* timeinfo;
|
||||||
|
|
||||||
|
time(&rawtime);
|
||||||
|
timeinfo = localtime(&rawtime);
|
||||||
|
|
||||||
|
// Timestamp the log entry
|
||||||
|
size_t uiLen = sprintf(szOutput, "<%.2d/%.2d/%.2d - %.2d:%.2d:%.2d> %s\n", timeinfo->tm_mday, timeinfo->tm_mon + 1, timeinfo->tm_year + 1900, timeinfo->tm_hour, timeinfo->tm_min, timeinfo->tm_sec, sz);
|
||||||
|
|
||||||
|
// Write the text to the file
|
||||||
|
fwrite(szOutput, 1, uiLen, m_pFile);
|
||||||
|
// Flush the log file to the disk. May move this to a seperate function
|
||||||
|
fflush(m_pFile);
|
||||||
|
|
||||||
|
// Output the text to any console that may be attached
|
||||||
|
printf("%s", szOutput);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CLogger::OutputLog(const char* sz, const LogLevel eLevel, ...)
|
||||||
|
{
|
||||||
|
char szText[1024] = {0};
|
||||||
|
va_list marker;
|
||||||
|
va_start(marker, eLevel);
|
||||||
|
vsprintf(szText, sz, marker);
|
||||||
|
va_end(marker);
|
||||||
|
|
||||||
|
// Since this function is pretty much the same as the safer function, we'll just redirect it there
|
||||||
|
OutputLog_s(szText, eLevel);
|
||||||
|
}
|
||||||
|
|
||||||
82
Artemis/LogiLed2Artemis/Logger.h
Normal file
82
Artemis/LogiLed2Artemis/Logger.h
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
// Original work by VRocker https://github.com/VRocker/LogiLed2Corsair
|
||||||
|
// I'm mainly a C# developer, and these modification aren't a piece of art, but it suits our needs.
|
||||||
|
|
||||||
|
// The MIT License (MIT)
|
||||||
|
//
|
||||||
|
// Copyright (c) 2015 VRocker
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
// of this software and associated documentation files (the "Software"), to deal
|
||||||
|
// in the Software without restriction, including without limitation the rights
|
||||||
|
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
// copies of the Software, and to permit persons to whom the Software is
|
||||||
|
// furnished to do so, subject to the following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
|
// copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
// SOFTWARE.
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#ifndef _LOGGER_H
|
||||||
|
#define _LOGGER_H
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
enum class LogLevel
|
||||||
|
{
|
||||||
|
Debug,
|
||||||
|
All,
|
||||||
|
Critical,
|
||||||
|
Warning,
|
||||||
|
Information,
|
||||||
|
User,
|
||||||
|
Internal,
|
||||||
|
None,
|
||||||
|
|
||||||
|
// Just to force the compiler to treat the enum options as an int
|
||||||
|
FORCE_32BIT = 0x7fffffff
|
||||||
|
};
|
||||||
|
|
||||||
|
class CLogger
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
static LogLevel GetLogLevel(void)
|
||||||
|
{
|
||||||
|
return m_eLogLevel;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void SetLogLevel(const LogLevel e)
|
||||||
|
{
|
||||||
|
#ifndef _DEBUG
|
||||||
|
if ( e == LogLevel::Debug ) return;
|
||||||
|
#endif
|
||||||
|
m_eLogLevel = e;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void InitLogging(const char* szFile);
|
||||||
|
// Always remember to end logging when you are finished otherwise you will have file handles floating around
|
||||||
|
static void EndLogging(void);
|
||||||
|
|
||||||
|
// Output the text to a log file.
|
||||||
|
static void OutputLog_s(const char* sz, const LogLevel eLevel);
|
||||||
|
static void OutputLog(const char* sz, const LogLevel eLevel, ...);
|
||||||
|
|
||||||
|
static FILE* GetFile()
|
||||||
|
{
|
||||||
|
return m_pFile;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
static LogLevel m_eLogLevel;
|
||||||
|
static FILE* m_pFile;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
49
Artemis/LogiLed2Artemis/LogiLed2Artemis.def
Normal file
49
Artemis/LogiLed2Artemis/LogiLed2Artemis.def
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
// Original work by VRocker https://github.com/VRocker/LogiLed2Corsair
|
||||||
|
// I'm mainly a C# developer, and these modification aren't a piece of art, but it suits our needs.
|
||||||
|
|
||||||
|
// The MIT License (MIT)
|
||||||
|
//
|
||||||
|
// Copyright (c) 2015 VRocker
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
// of this software and associated documentation files (the "Software"), to deal
|
||||||
|
// in the Software without restriction, including without limitation the rights
|
||||||
|
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
// copies of the Software, and to permit persons to whom the Software is
|
||||||
|
// furnished to do so, subject to the following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
|
// copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
// SOFTWARE.
|
||||||
|
|
||||||
|
LIBRARY LogiLed2Artemis.dll
|
||||||
|
|
||||||
|
EXPORTS
|
||||||
|
|
||||||
|
LogiLedInit
|
||||||
|
LogiLedGetSdkVersion
|
||||||
|
LogiLedSetTargetDevice
|
||||||
|
LogiLedSaveCurrentLighting
|
||||||
|
LogiLedSetLighting
|
||||||
|
LogiLedRestoreLighting
|
||||||
|
LogiLedFlashLighting
|
||||||
|
LogiLedPulseLighting
|
||||||
|
LogiLedStopEffects
|
||||||
|
LogiLedSetLightingFromBitmap
|
||||||
|
LogiLedSetLightingForKeyWithScanCode
|
||||||
|
LogiLedSetLightingForKeyWithHidCode
|
||||||
|
LogiLedSetLightingForKeyWithQuartzCode
|
||||||
|
LogiLedSetLightingForKeyWithKeyName
|
||||||
|
LogiLedSaveLightingForKey
|
||||||
|
LogiLedRestoreLightingForKey
|
||||||
|
LogiLedFlashSingleKey
|
||||||
|
LogiLedPulseSingleKey
|
||||||
|
LogiLedStopEffectsOnKey
|
||||||
|
LogiLedShutdown
|
||||||
168
Artemis/LogiLed2Artemis/LogiLed2Artemis.vcxproj
Normal file
168
Artemis/LogiLed2Artemis/LogiLed2Artemis.vcxproj
Normal file
@ -0,0 +1,168 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<Project DefaultTargets="Build" ToolsVersion="14.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
|
<ItemGroup Label="ProjectConfigurations">
|
||||||
|
<ProjectConfiguration Include="Debug|Win32">
|
||||||
|
<Configuration>Debug</Configuration>
|
||||||
|
<Platform>Win32</Platform>
|
||||||
|
</ProjectConfiguration>
|
||||||
|
<ProjectConfiguration Include="Debug|x64">
|
||||||
|
<Configuration>Debug</Configuration>
|
||||||
|
<Platform>x64</Platform>
|
||||||
|
</ProjectConfiguration>
|
||||||
|
<ProjectConfiguration Include="Release|Win32">
|
||||||
|
<Configuration>Release</Configuration>
|
||||||
|
<Platform>Win32</Platform>
|
||||||
|
</ProjectConfiguration>
|
||||||
|
<ProjectConfiguration Include="Release|x64">
|
||||||
|
<Configuration>Release</Configuration>
|
||||||
|
<Platform>x64</Platform>
|
||||||
|
</ProjectConfiguration>
|
||||||
|
</ItemGroup>
|
||||||
|
<PropertyGroup Label="Globals">
|
||||||
|
<ProjectGuid>{D2EDB8F3-F0CB-4670-B472-0B46D5800D2C}</ProjectGuid>
|
||||||
|
<Keyword>Win32Proj</Keyword>
|
||||||
|
<RootNamespace>LogiLed2Artemis</RootNamespace>
|
||||||
|
<ProjectName>LogiLed2Artemis</ProjectName>
|
||||||
|
</PropertyGroup>
|
||||||
|
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">
|
||||||
|
<ConfigurationType>DynamicLibrary</ConfigurationType>
|
||||||
|
<UseDebugLibraries>true</UseDebugLibraries>
|
||||||
|
<PlatformToolset>v140</PlatformToolset>
|
||||||
|
<CharacterSet>Unicode</CharacterSet>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="Configuration">
|
||||||
|
<ConfigurationType>DynamicLibrary</ConfigurationType>
|
||||||
|
<UseDebugLibraries>true</UseDebugLibraries>
|
||||||
|
<PlatformToolset>v140</PlatformToolset>
|
||||||
|
<CharacterSet>Unicode</CharacterSet>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
|
||||||
|
<ConfigurationType>DynamicLibrary</ConfigurationType>
|
||||||
|
<UseDebugLibraries>false</UseDebugLibraries>
|
||||||
|
<PlatformToolset>v140</PlatformToolset>
|
||||||
|
<WholeProgramOptimization>true</WholeProgramOptimization>
|
||||||
|
<CharacterSet>Unicode</CharacterSet>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
|
||||||
|
<ConfigurationType>DynamicLibrary</ConfigurationType>
|
||||||
|
<UseDebugLibraries>false</UseDebugLibraries>
|
||||||
|
<PlatformToolset>v140</PlatformToolset>
|
||||||
|
<WholeProgramOptimization>true</WholeProgramOptimization>
|
||||||
|
<CharacterSet>Unicode</CharacterSet>
|
||||||
|
</PropertyGroup>
|
||||||
|
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
|
||||||
|
<ImportGroup Label="ExtensionSettings">
|
||||||
|
</ImportGroup>
|
||||||
|
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
|
||||||
|
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
|
||||||
|
</ImportGroup>
|
||||||
|
<ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="PropertySheets">
|
||||||
|
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
|
||||||
|
</ImportGroup>
|
||||||
|
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
|
||||||
|
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
|
||||||
|
</ImportGroup>
|
||||||
|
<ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets">
|
||||||
|
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
|
||||||
|
</ImportGroup>
|
||||||
|
<PropertyGroup Label="UserMacros" />
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
|
||||||
|
<LinkIncremental>true</LinkIncremental>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
|
||||||
|
<LinkIncremental>true</LinkIncremental>
|
||||||
|
<LibraryPath>$(LibraryPath)</LibraryPath>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
|
||||||
|
<LinkIncremental>false</LinkIncremental>
|
||||||
|
</PropertyGroup>
|
||||||
|
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
|
||||||
|
<LinkIncremental>false</LinkIncremental>
|
||||||
|
<TargetName>$(ProjectName)</TargetName>
|
||||||
|
</PropertyGroup>
|
||||||
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
|
||||||
|
<ClCompile>
|
||||||
|
<PrecompiledHeader>
|
||||||
|
</PrecompiledHeader>
|
||||||
|
<WarningLevel>Level3</WarningLevel>
|
||||||
|
<Optimization>Disabled</Optimization>
|
||||||
|
<PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;_USRDLL;LOGILEDCORSAIR_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
|
</ClCompile>
|
||||||
|
<Link>
|
||||||
|
<SubSystem>Windows</SubSystem>
|
||||||
|
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||||
|
<ModuleDefinitionFile>LogiLed2Artemis.def</ModuleDefinitionFile>
|
||||||
|
<AdditionalDependencies>../CUESDK/lib/i386/CUESDK_2013.lib;%(AdditionalDependencies)</AdditionalDependencies>
|
||||||
|
</Link>
|
||||||
|
</ItemDefinitionGroup>
|
||||||
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
|
||||||
|
<ClCompile>
|
||||||
|
<PrecompiledHeader>
|
||||||
|
</PrecompiledHeader>
|
||||||
|
<WarningLevel>Level3</WarningLevel>
|
||||||
|
<Optimization>Disabled</Optimization>
|
||||||
|
<PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;_USRDLL;LOGILEDCORSAIR_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
|
<AdditionalIncludeDirectories>%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
||||||
|
</ClCompile>
|
||||||
|
<Link>
|
||||||
|
<SubSystem>Windows</SubSystem>
|
||||||
|
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||||
|
<ModuleDefinitionFile>LogiLed2Artemis.def</ModuleDefinitionFile>
|
||||||
|
<AdditionalDependencies>%(AdditionalDependencies)</AdditionalDependencies>
|
||||||
|
</Link>
|
||||||
|
</ItemDefinitionGroup>
|
||||||
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
|
||||||
|
<ClCompile>
|
||||||
|
<WarningLevel>Level3</WarningLevel>
|
||||||
|
<PrecompiledHeader>
|
||||||
|
</PrecompiledHeader>
|
||||||
|
<Optimization>MaxSpeed</Optimization>
|
||||||
|
<FunctionLevelLinking>true</FunctionLevelLinking>
|
||||||
|
<IntrinsicFunctions>true</IntrinsicFunctions>
|
||||||
|
<PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;LOGILEDCORSAIR_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
|
</ClCompile>
|
||||||
|
<Link>
|
||||||
|
<SubSystem>Windows</SubSystem>
|
||||||
|
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||||
|
<EnableCOMDATFolding>true</EnableCOMDATFolding>
|
||||||
|
<OptimizeReferences>true</OptimizeReferences>
|
||||||
|
<ModuleDefinitionFile>LogiLed2Artemis.def</ModuleDefinitionFile>
|
||||||
|
<AdditionalDependencies>../CUESDK/lib/i386/CUESDK_2013.lib;%(AdditionalDependencies)</AdditionalDependencies>
|
||||||
|
</Link>
|
||||||
|
</ItemDefinitionGroup>
|
||||||
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
|
||||||
|
<ClCompile>
|
||||||
|
<WarningLevel>Level3</WarningLevel>
|
||||||
|
<PrecompiledHeader>
|
||||||
|
</PrecompiledHeader>
|
||||||
|
<Optimization>MaxSpeed</Optimization>
|
||||||
|
<FunctionLevelLinking>true</FunctionLevelLinking>
|
||||||
|
<IntrinsicFunctions>true</IntrinsicFunctions>
|
||||||
|
<PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;LOGILEDCORSAIR_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions>
|
||||||
|
</ClCompile>
|
||||||
|
<Link>
|
||||||
|
<SubSystem>Windows</SubSystem>
|
||||||
|
<GenerateDebugInformation>true</GenerateDebugInformation>
|
||||||
|
<EnableCOMDATFolding>true</EnableCOMDATFolding>
|
||||||
|
<OptimizeReferences>true</OptimizeReferences>
|
||||||
|
<ModuleDefinitionFile>LogiLed2Artemis.def</ModuleDefinitionFile>
|
||||||
|
<AdditionalDependencies>%(AdditionalDependencies)</AdditionalDependencies>
|
||||||
|
</Link>
|
||||||
|
</ItemDefinitionGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<ClInclude Include="Logger.h" />
|
||||||
|
<ClInclude Include="LogiLedDefs.h" />
|
||||||
|
<ClInclude Include="main.h" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<ClCompile Include="Logger.cpp" />
|
||||||
|
<ClCompile Include="main.cpp" />
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<None Include="LogiLed2Artemis.def" />
|
||||||
|
</ItemGroup>
|
||||||
|
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
||||||
|
<ImportGroup Label="ExtensionTargets">
|
||||||
|
</ImportGroup>
|
||||||
|
</Project>
|
||||||
41
Artemis/LogiLed2Artemis/LogiLed2Artemis.vcxproj.filters
Normal file
41
Artemis/LogiLed2Artemis/LogiLed2Artemis.vcxproj.filters
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
|
<ItemGroup>
|
||||||
|
<Filter Include="Source Files">
|
||||||
|
<UniqueIdentifier>{4FC737F1-C7A5-4376-A066-2A32D752A2FF}</UniqueIdentifier>
|
||||||
|
<Extensions>cpp;c;cc;cxx;def;odl;idl;hpj;bat;asm;asmx</Extensions>
|
||||||
|
</Filter>
|
||||||
|
<Filter Include="Header Files">
|
||||||
|
<UniqueIdentifier>{93995380-89BD-4b04-88EB-625FBE52EBFB}</UniqueIdentifier>
|
||||||
|
<Extensions>h;hh;hpp;hxx;hm;inl;inc;xsd</Extensions>
|
||||||
|
</Filter>
|
||||||
|
<Filter Include="Resource Files">
|
||||||
|
<UniqueIdentifier>{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}</UniqueIdentifier>
|
||||||
|
<Extensions>rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx;tiff;tif;png;wav;mfcribbon-ms</Extensions>
|
||||||
|
</Filter>
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<ClInclude Include="main.h">
|
||||||
|
<Filter>Header Files</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="LogiLedDefs.h">
|
||||||
|
<Filter>Header Files</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="Logger.h">
|
||||||
|
<Filter>Header Files</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<ClCompile Include="main.cpp">
|
||||||
|
<Filter>Source Files</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="Logger.cpp">
|
||||||
|
<Filter>Source Files</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<None Include="LogiLed2Artemis.def">
|
||||||
|
<Filter>Source Files</Filter>
|
||||||
|
</None>
|
||||||
|
</ItemGroup>
|
||||||
|
</Project>
|
||||||
135
Artemis/LogiLed2Artemis/LogiLedDefs.h
Normal file
135
Artemis/LogiLed2Artemis/LogiLedDefs.h
Normal file
@ -0,0 +1,135 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
const int LOGITECH_LED_MOUSE = 0x0001;
|
||||||
|
const int LOGITECH_LED_KEYBOARD = 0x0002;
|
||||||
|
const int LOGITECH_LED_ALL = LOGITECH_LED_MOUSE | LOGITECH_LED_KEYBOARD;
|
||||||
|
|
||||||
|
#define LOGI_LED_BITMAP_WIDTH 21
|
||||||
|
#define LOGI_LED_BITMAP_HEIGHT 6
|
||||||
|
#define LOGI_LED_BITMAP_BYTES_PER_KEY 4
|
||||||
|
|
||||||
|
#define LOGI_LED_BITMAP_SIZE LOGI_LED_BITMAP_WIDTH*LOGI_LED_BITMAP_HEIGHT*LOGI_LED_BITMAP_BYTES_PER_KEY
|
||||||
|
|
||||||
|
#define LOGI_LED_DURATION_INFINITE 0
|
||||||
|
|
||||||
|
#define LOGI_DEVICETYPE_MONOCHROME_ORD 0
|
||||||
|
#define LOGI_DEVICETYPE_RGB_ORD 1
|
||||||
|
#define LOGI_DEVICETYPE_PERKEY_RGB_ORD 2
|
||||||
|
|
||||||
|
#define LOGI_DEVICETYPE_MONOCHROME (1 << LOGI_DEVICETYPE_MONOCHROME_ORD)
|
||||||
|
#define LOGI_DEVICETYPE_RGB (1 << LOGI_DEVICETYPE_RGB_ORD)
|
||||||
|
#define LOGI_DEVICETYPE_PERKEY_RGB (1 << LOGI_DEVICETYPE_PERKEY_RGB_ORD)
|
||||||
|
|
||||||
|
#define LOGI_DEVICETYPE_ALL (LOGI_DEVICETYPE_MONOCHROME | LOGI_DEVICETYPE_RGB | LOGI_DEVICETYPE_PERKEY_RGB)
|
||||||
|
|
||||||
|
namespace LogiLed
|
||||||
|
{
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
ESC = 0x01,
|
||||||
|
F1 = 0x3b,
|
||||||
|
F2 = 0x3c,
|
||||||
|
F3 = 0x3d,
|
||||||
|
F4 = 0x3e,
|
||||||
|
F5 = 0x3f,
|
||||||
|
F6 = 0x40,
|
||||||
|
F7 = 0x41,
|
||||||
|
F8 = 0x42,
|
||||||
|
F9 = 0x43,
|
||||||
|
F10 = 0x44,
|
||||||
|
F11 = 0x57,
|
||||||
|
F12 = 0x58,
|
||||||
|
PRINT_SCREEN = 0x137,
|
||||||
|
SCROLL_LOCK = 0x46,
|
||||||
|
PAUSE_BREAK = 0x145,
|
||||||
|
TILDE = 0x29,
|
||||||
|
ONE = 0x02,
|
||||||
|
TWO = 0x03,
|
||||||
|
THREE = 0x04,
|
||||||
|
FOUR = 0x05,
|
||||||
|
FIVE = 0x06,
|
||||||
|
SIX = 0x07,
|
||||||
|
SEVEN = 0x08,
|
||||||
|
EIGHT = 0x09,
|
||||||
|
NINE = 0x0A,
|
||||||
|
ZERO = 0x0B,
|
||||||
|
MINUS = 0x0C,
|
||||||
|
EQUALS = 0x0D,
|
||||||
|
BACKSPACE = 0x0E,
|
||||||
|
INSERT = 0x152,
|
||||||
|
HOME = 0x147,
|
||||||
|
PAGE_UP = 0x149,
|
||||||
|
NUM_LOCK = 0x45,
|
||||||
|
NUM_SLASH = 0x135,
|
||||||
|
NUM_ASTERISK = 0x37,
|
||||||
|
NUM_MINUS = 0x4A,
|
||||||
|
TAB = 0x0F,
|
||||||
|
Q = 0x10,
|
||||||
|
W = 0x11,
|
||||||
|
E = 0x12,
|
||||||
|
R = 0x13,
|
||||||
|
T = 0x14,
|
||||||
|
Y = 0x15,
|
||||||
|
U = 0x16,
|
||||||
|
I = 0x17,
|
||||||
|
O = 0x18,
|
||||||
|
P = 0x19,
|
||||||
|
OPEN_BRACKET = 0x1A,
|
||||||
|
CLOSE_BRACKET = 0x1B,
|
||||||
|
BACKSLASH = 0x2B,
|
||||||
|
KEYBOARD_DELETE = 0x153,
|
||||||
|
END = 0x14F,
|
||||||
|
PAGE_DOWN = 0x151,
|
||||||
|
NUM_SEVEN = 0x47,
|
||||||
|
NUM_EIGHT = 0x48,
|
||||||
|
NUM_NINE = 0x49,
|
||||||
|
NUM_PLUS = 0x4E,
|
||||||
|
CAPS_LOCK = 0x3A,
|
||||||
|
A = 0x1E,
|
||||||
|
S = 0x1F,
|
||||||
|
D = 0x20,
|
||||||
|
F = 0x21,
|
||||||
|
G = 0x22,
|
||||||
|
H = 0x23,
|
||||||
|
J = 0x24,
|
||||||
|
K = 0x25,
|
||||||
|
L = 0x26,
|
||||||
|
SEMICOLON = 0x27,
|
||||||
|
APOSTROPHE = 0x28,
|
||||||
|
ENTER = 0x1C,
|
||||||
|
NUM_FOUR = 0x4B,
|
||||||
|
NUM_FIVE = 0x4C,
|
||||||
|
NUM_SIX = 0x4D,
|
||||||
|
LEFT_SHIFT = 0x2A,
|
||||||
|
Z = 0x2C,
|
||||||
|
X = 0x2D,
|
||||||
|
C = 0x2E,
|
||||||
|
V = 0x2F,
|
||||||
|
B = 0x30,
|
||||||
|
N = 0x31,
|
||||||
|
M = 0x32,
|
||||||
|
COMMA = 0x33,
|
||||||
|
PERIOD = 0x34,
|
||||||
|
FORWARD_SLASH = 0x35,
|
||||||
|
RIGHT_SHIFT = 0x36,
|
||||||
|
ARROW_UP = 0x148,
|
||||||
|
NUM_ONE = 0x4F,
|
||||||
|
NUM_TWO = 0x50,
|
||||||
|
NUM_THREE = 0x51,
|
||||||
|
NUM_ENTER = 0x11C,
|
||||||
|
LEFT_CONTROL = 0x1D,
|
||||||
|
LEFT_WINDOWS = 0x15B,
|
||||||
|
LEFT_ALT = 0x38,
|
||||||
|
SPACE = 0x39,
|
||||||
|
RIGHT_ALT = 0x138,
|
||||||
|
RIGHT_WINDOWS = 0x15C,
|
||||||
|
APPLICATION_SELECT = 0x15D,
|
||||||
|
RIGHT_CONTROL = 0x11D,
|
||||||
|
ARROW_LEFT = 0x14B,
|
||||||
|
ARROW_DOWN = 0x150,
|
||||||
|
ARROW_RIGHT = 0x14D,
|
||||||
|
NUM_ZERO = 0x52,
|
||||||
|
NUM_PERIOD = 0x53,
|
||||||
|
} KeyName;
|
||||||
|
}
|
||||||
|
|
||||||
254
Artemis/LogiLed2Artemis/main.cpp
Normal file
254
Artemis/LogiLed2Artemis/main.cpp
Normal file
@ -0,0 +1,254 @@
|
|||||||
|
// Original work by VRocker https://github.com/VRocker/LogiLed2Corsair
|
||||||
|
// I'm mainly a C# developer, and these modification aren't a piece of art, but it suits our needs.
|
||||||
|
|
||||||
|
// The MIT License (MIT)
|
||||||
|
//
|
||||||
|
// Copyright (c) 2015 VRocker
|
||||||
|
//
|
||||||
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
// of this software and associated documentation files (the "Software"), to deal
|
||||||
|
// in the Software without restriction, including without limitation the rights
|
||||||
|
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
// copies of the Software, and to permit persons to whom the Software is
|
||||||
|
// furnished to do so, subject to the following conditions:
|
||||||
|
//
|
||||||
|
// The above copyright notice and this permission notice shall be included in all
|
||||||
|
// copies or substantial portions of the Software.
|
||||||
|
//
|
||||||
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
// SOFTWARE.
|
||||||
|
|
||||||
|
#include "main.h"
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <tchar.h>
|
||||||
|
#include <thread>
|
||||||
|
#include "LogiLedDefs.h"
|
||||||
|
#define WIN32_LEAN_AND_MEAN
|
||||||
|
#include <Windows.h>
|
||||||
|
#include "Logger.h"
|
||||||
|
|
||||||
|
#include <complex>
|
||||||
|
#include <filesystem>
|
||||||
|
|
||||||
|
|
||||||
|
static bool g_hasInitialised = false;
|
||||||
|
const char* game = "";
|
||||||
|
|
||||||
|
void cleanup()
|
||||||
|
{
|
||||||
|
CLogger::EndLogging();
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOL WINAPI DllMain(HINSTANCE hInst, DWORD fdwReason, LPVOID)
|
||||||
|
{
|
||||||
|
switch (fdwReason)
|
||||||
|
{
|
||||||
|
case DLL_PROCESS_ATTACH:
|
||||||
|
{
|
||||||
|
atexit(cleanup);
|
||||||
|
|
||||||
|
CLogger::InitLogging("Log.txt");
|
||||||
|
CLogger::SetLogLevel(LogLevel::None);
|
||||||
|
|
||||||
|
// Get the process that loaded the DLL
|
||||||
|
TCHAR divisionFind[] = _T("Division");
|
||||||
|
TCHAR gtaFind[] = _T("GTA");
|
||||||
|
TCHAR szPath[MAX_PATH];
|
||||||
|
GetModuleFileName(NULL, szPath, MAX_PATH);
|
||||||
|
|
||||||
|
if (_tcscmp(szPath, divisionFind) != 0)
|
||||||
|
game = "division";
|
||||||
|
else if (_tcscmp(szPath, gtaFind) != 0)
|
||||||
|
game = "gta";
|
||||||
|
|
||||||
|
CLogger::OutputLog("Attached to process.", LogLevel::Debug);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case DLL_PROCESS_DETACH:
|
||||||
|
{
|
||||||
|
cleanup();
|
||||||
|
|
||||||
|
CLogger::OutputLog_s("Detached from process.", LogLevel::Debug);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedInit()
|
||||||
|
{
|
||||||
|
CLogger::OutputLog_s("Logitech LED init called.", LogLevel::Debug);
|
||||||
|
g_hasInitialised = true;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedGetSdkVersion(int* majorNum, int* minorNum, int* buildNum)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedGetSdkVersion called.", LogLevel::Debug);
|
||||||
|
|
||||||
|
// Mimic the SDK version
|
||||||
|
*majorNum = 8;
|
||||||
|
*minorNum = 81;
|
||||||
|
*buildNum = 15;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedSetTargetDevice(int targetDevice)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedSetTargetDevice called (%i)", LogLevel::Debug, targetDevice);
|
||||||
|
|
||||||
|
// Logitech SDK says this function returns false if LogiLedInit hasn't been called
|
||||||
|
return g_hasInitialised;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedSaveCurrentLighting()
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedSaveCurrentLighting called (%i)", LogLevel::Debug);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Transmit(const char* msg)
|
||||||
|
{
|
||||||
|
//Pipe Init Data
|
||||||
|
HANDLE hPipe1;
|
||||||
|
char buf[100];
|
||||||
|
LPTSTR lpszPipename1 = TEXT("\\\\.\\pipe\\artemis");
|
||||||
|
|
||||||
|
hPipe1 = CreateFile(lpszPipename1, GENERIC_WRITE, 0, NULL, OPEN_EXISTING, FILE_FLAG_OVERLAPPED, NULL);
|
||||||
|
if (hPipe1 == NULL || hPipe1 == INVALID_HANDLE_VALUE)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("Could not open the pipe - (error %i)", LogLevel::Debug, GetLastError());
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
DWORD cbWritten;
|
||||||
|
WriteFile(hPipe1, msg, strlen(msg), &cbWritten, NULL);
|
||||||
|
CLogger::OutputLog_s("Transmitted to pipe", LogLevel::Debug);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedSetLighting(int redPercentage, int greenPercentage, int bluePercentage)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedSetLighting called (%i %i %i)", LogLevel::Debug, redPercentage, greenPercentage, bluePercentage);
|
||||||
|
|
||||||
|
std::ostringstream os;
|
||||||
|
os << "0 0 " << redPercentage << " " << greenPercentage << " " << bluePercentage;
|
||||||
|
Transmit(os.str().c_str());
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedRestoreLighting()
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedRestoreLighting called", LogLevel::Debug);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedFlashLighting(int redPercentage, int greenPercentage, int bluePercentage, int milliSecondsDuration, int milliSecondsInterval)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedFlashLighting called (%i %i %i %i %i)", LogLevel::Debug, redPercentage, greenPercentage, bluePercentage, milliSecondsDuration, milliSecondsInterval);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedPulseLighting(int redPercentage, int greenPercentage, int bluePercentage, int milliSecondsDuration, int milliSecondsInterval)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedPulseLighting called (%i %i %i %i %i)", LogLevel::Debug, redPercentage, greenPercentage, bluePercentage, milliSecondsDuration, milliSecondsInterval);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedStopEffects()
|
||||||
|
{
|
||||||
|
CLogger::OutputLog_s("LogiLedStopEffects called", LogLevel::Debug);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedSetLightingFromBitmap(unsigned char bitmap[])
|
||||||
|
{
|
||||||
|
CLogger::OutputLog_s("LogiLedSetLightingFromBitmap called", LogLevel::Debug);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedSetLightingForKeyWithScanCode(int keyCode, int redPercentage, int greenPercentage, int bluePercentage)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedSetLightingForKeyWithScanCode called [Key: %i] (%i %i %i)", LogLevel::Debug, keyCode, redPercentage, greenPercentage, bluePercentage);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedSetLightingForKeyWithHidCode(int keyCode, int redPercentage, int greenPercentage, int bluePercentage)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedSetLightingForKeyWithHidCode called [Key: %i] (%i %i %i)", LogLevel::Debug, keyCode, redPercentage, greenPercentage, bluePercentage);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedSetLightingForKeyWithQuartzCode(int keyCode, int redPercentage, int greenPercentage, int bluePercentage)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedSetLightingForKeyWithQuartzCode called [Key: %i] (%i %i %i)", LogLevel::Debug, keyCode, redPercentage, greenPercentage, bluePercentage);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedSetLightingForKeyWithKeyName(LogiLed::KeyName keyName, int redPercentage, int greenPercentage, int bluePercentage)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedSetLightingForKeyWithKeyName called [Key: %i] (%i %i %i)", LogLevel::Debug, keyName, redPercentage, greenPercentage, bluePercentage);
|
||||||
|
|
||||||
|
// Only transmit interesting keys. This can most likely be done prettier, but I'm no C++ dev.
|
||||||
|
if (game == "division" &&
|
||||||
|
(keyName == LogiLed::F1 ||
|
||||||
|
keyName == LogiLed::F2 ||
|
||||||
|
keyName == LogiLed::F3 ||
|
||||||
|
keyName == LogiLed::F4 ||
|
||||||
|
keyName == LogiLed::R ||
|
||||||
|
keyName == LogiLed::G ||
|
||||||
|
keyName == LogiLed::V)
|
||||||
|
)
|
||||||
|
{
|
||||||
|
std::ostringstream os;
|
||||||
|
os << "1 " << keyName << " " << redPercentage << " " << greenPercentage << " " << bluePercentage;
|
||||||
|
std::string s = os.str();
|
||||||
|
Transmit(os.str().c_str());
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedSaveLightingForKey(LogiLed::KeyName keyName)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedSaveLightingForKey called [Key: %i]", LogLevel::Debug, keyName);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedRestoreLightingForKey(LogiLed::KeyName keyName)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedRestoreLightingForKey called [Key: %i]", LogLevel::Debug, keyName);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedFlashSingleKey(LogiLed::KeyName keyName, int redPercentage, int greenPercentage, int bluePercentage, int msDuration, int msInterval)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedFlashSingleKey called [Key: %i] (%i %i %i %i %i)", LogLevel::Debug, keyName, redPercentage, greenPercentage, bluePercentage, msDuration, msInterval);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedPulseSingleKey(LogiLed::KeyName keyName, int startRedPercentage, int startGreenPercentage, int startBluePercentage, int finishRedPercentage, int finishGreenPercentage, int finishBluePercentage, int msDuration, bool isInfinite)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedPulseSingleKey called [Key: %i] (%i %i %i %i %i %i %i %i)", LogLevel::Debug, keyName, startRedPercentage, startGreenPercentage, startBluePercentage, finishRedPercentage, finishGreenPercentage, finishBluePercentage, msDuration, isInfinite);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool LogiLedStopEffectsOnKey(LogiLed::KeyName keyName)
|
||||||
|
{
|
||||||
|
CLogger::OutputLog("LogiLedStopEffectsOnKey called [Key: %i]", LogLevel::Debug, keyName);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void LogiLedShutdown()
|
||||||
|
{
|
||||||
|
CLogger::OutputLog_s("LogiLedShutdown called.", LogLevel::Debug);
|
||||||
|
g_hasInitialised = false;
|
||||||
|
}
|
||||||
|
|
||||||
2
Artemis/LogiLed2Artemis/main.h
Normal file
2
Artemis/LogiLed2Artemis/main.h
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
Loading…
x
Reference in New Issue
Block a user