mirror of
https://github.com/chibicitiberiu/rainmeter-studio.git
synced 2024-02-24 04:33:31 +00:00
Committing JamesAC / spx changes to SpeedFan plugin to support conversion of default Centigrade temp values to Fahrenheit or Kelvin. Also manual update to support change.
This commit is contained in:
parent
d0fe23ec1f
commit
befa90ce8f
@ -28,8 +28,8 @@ LANGUAGE LANG_FINNISH, SUBLANG_DEFAULT
|
||||
//
|
||||
|
||||
VS_VERSION_INFO VERSIONINFO
|
||||
FILEVERSION 1,2,0,399
|
||||
PRODUCTVERSION 1,2,0,399
|
||||
FILEVERSION 1,2,0,401
|
||||
PRODUCTVERSION 1,2,0,401
|
||||
FILEFLAGSMASK 0x17L
|
||||
#ifdef _DEBUG
|
||||
FILEFLAGS 0x1L
|
||||
@ -45,12 +45,12 @@ BEGIN
|
||||
BLOCK "040b04b0"
|
||||
BEGIN
|
||||
VALUE "FileDescription", "Rainmeter - A Customizable Resource Meter"
|
||||
VALUE "FileVersion", "1, 2, 0, 399"
|
||||
VALUE "FileVersion", "1, 2, 0, 401"
|
||||
VALUE "InternalName", "Rainmeter"
|
||||
VALUE "LegalCopyright", "Copyright (C) 2010 - Rainy"
|
||||
VALUE "OriginalFilename", "Rainmeter.exe"
|
||||
VALUE "ProductName", "Rainmeter"
|
||||
VALUE "ProductVersion", "1, 2, 0, 399"
|
||||
VALUE "ProductVersion", "1, 2, 0, 401"
|
||||
END
|
||||
END
|
||||
BLOCK "VarFileInfo"
|
||||
|
@ -58,9 +58,17 @@ enum SensorType
|
||||
TYPE_VOLT
|
||||
};
|
||||
|
||||
bool ReadSharedData(SensorType type, UINT number, double* value);
|
||||
enum TempScale
|
||||
{
|
||||
SCALE_CENTIGRADE,
|
||||
SCALE_FARENHEIT,
|
||||
SCALE_KELVIN
|
||||
};
|
||||
|
||||
bool ReadSharedData(SensorType type, TempScale scale, UINT number, double* value);
|
||||
|
||||
static std::map<UINT, SensorType> g_Types;
|
||||
static std::map<UINT, TempScale> g_Scales;
|
||||
static std::map<UINT, UINT> g_Numbers;
|
||||
|
||||
/*
|
||||
@ -84,6 +92,29 @@ UINT Initialize(HMODULE instance, LPCTSTR iniFile, LPCTSTR section, UINT id)
|
||||
if (wcsicmp(L"TEMPERATURE", type) == 0)
|
||||
{
|
||||
g_Types[id] = TYPE_TEMP;
|
||||
|
||||
LPCTSTR scale = ReadConfigString(section, L"SpeedFanScale", L"C");
|
||||
if (scale)
|
||||
{
|
||||
if (wcsicmp(L"C", scale) == 0)
|
||||
{
|
||||
g_Scales[id] = SCALE_CENTIGRADE;
|
||||
}
|
||||
else if (wcsicmp(L"F", scale) == 0)
|
||||
{
|
||||
g_Scales[id] = SCALE_FARENHEIT;
|
||||
}
|
||||
else if (wcsicmp(L"K", scale) == 0)
|
||||
{
|
||||
g_Scales[id] = SCALE_KELVIN;
|
||||
}
|
||||
else
|
||||
{
|
||||
std::wstring error = L"No such SpeedFanScale: ";
|
||||
error += scale;
|
||||
MessageBox(NULL, error.c_str(), L"Rainmeter", MB_OK);
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (wcsicmp(L"FAN", type) == 0)
|
||||
{
|
||||
@ -116,22 +147,23 @@ The function returns the new value.
|
||||
*/
|
||||
double Update2(UINT id)
|
||||
{
|
||||
double value = 0;
|
||||
double value = 0.0;
|
||||
|
||||
std::map<UINT, SensorType>::iterator type = g_Types.find(id);
|
||||
std::map<UINT, UINT>::iterator number = g_Numbers.find(id);
|
||||
std::map<UINT, SensorType>::const_iterator type = g_Types.find(id);
|
||||
std::map<UINT, TempScale>::const_iterator scale = g_Scales.find(id);
|
||||
std::map<UINT, UINT>::const_iterator number = g_Numbers.find(id);
|
||||
|
||||
if(type == g_Types.end() || number == g_Numbers.end())
|
||||
if(type == g_Types.end() || number == g_Numbers.end() || ((*type).second == TYPE_TEMP && scale == g_Scales.end()))
|
||||
{
|
||||
return 0; // No id in the map. How this can be ????
|
||||
return 0.0; // No id in the map. How this can be ????
|
||||
}
|
||||
|
||||
if (ReadSharedData((*type).second, (*number).second, &value))
|
||||
if (ReadSharedData((*type).second, (*scale).second, (*number).second, &value))
|
||||
{
|
||||
return value;
|
||||
}
|
||||
|
||||
return 0;
|
||||
return 0.0;
|
||||
}
|
||||
|
||||
/*
|
||||
@ -152,12 +184,18 @@ void Finalize(HMODULE instance, UINT id)
|
||||
{
|
||||
g_Numbers.erase(i2);
|
||||
}
|
||||
|
||||
std::map<UINT, TempScale>::iterator i3 = g_Scales.find(id);
|
||||
if (i3 != g_Scales.end())
|
||||
{
|
||||
g_Scales.erase(i3);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
Get the data from shared memory.
|
||||
*/
|
||||
bool ReadSharedData(SensorType type, UINT number, double* value)
|
||||
bool ReadSharedData(SensorType type, TempScale scale, UINT number, double* value)
|
||||
{
|
||||
SpeedFanData* ptr;
|
||||
HANDLE hData;
|
||||
@ -181,6 +219,16 @@ bool ReadSharedData(SensorType type, UINT number, double* value)
|
||||
{
|
||||
*value = ptr->temps[number];
|
||||
*value /= 100.0;
|
||||
|
||||
if (scale == SCALE_FARENHEIT)
|
||||
{
|
||||
*value *= 1.8;
|
||||
*value += 32.0;
|
||||
}
|
||||
else if (scale == SCALE_KELVIN)
|
||||
{
|
||||
*value += 273.15;
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
||||
@ -213,7 +261,7 @@ bool ReadSharedData(SensorType type, UINT number, double* value)
|
||||
|
||||
UINT GetPluginVersion()
|
||||
{
|
||||
return 1001;
|
||||
return 1002;
|
||||
}
|
||||
|
||||
LPCTSTR GetPluginAuthor()
|
||||
|
@ -1,2 +1,2 @@
|
||||
#pragma once
|
||||
const int revision_number = 399;
|
||||
const int revision_number = 401;
|
Loading…
Reference in New Issue
Block a user