2 bugs fixed

This commit is contained in:
Frank Skare
2020-05-11 03:51:52 +02:00
parent f61eef8961
commit 2e59d49ad1
5 changed files with 154 additions and 135 deletions

View File

@@ -2,7 +2,8 @@
5.4.7.5 Beta (not yet released)
============
- fix in the learn window of input editor, whole day spent :-(
- fix black one pixel bar on right side by truncating instead of rounding
5.4.7.4 Beta (not yet released)

View File

@@ -1,4 +1,5 @@
using System;

using System;
namespace mpvnet
{
@@ -35,4 +36,4 @@ namespace mpvnet
WinAPI.AdjustWindowRect(ref rc, (uint)WinAPI.GetWindowLong(hwnd, -16 /* GWL_STYLE */), false);
}
}
}
}

View File

@@ -16,8 +16,7 @@
Background="{x:Static mpvnet:Theme.Background}"
MouseWheel="Window_MouseWheel"
MouseUp="Window_MouseUp"
MouseDoubleClick="Window_MouseDoubleClick"
TextInput="Window_TextInput">
MouseDoubleClick="Window_MouseDoubleClick" PreviewKeyDown="Window_PreviewKeyDown">
<Grid>
<Grid.RowDefinitions>

View File

@@ -2,11 +2,11 @@
using System;
using System.Diagnostics;
using System.Runtime.InteropServices;
using System.Text;
using System.Windows;
using System.Windows.Input;
using System.Windows.Interop;
using WinForms = System.Windows.Forms;
using System.Windows.Forms;
namespace mpvnet
{
@@ -14,13 +14,68 @@ namespace mpvnet
{
public CommandItem InputItem { get; set; }
string NewKey = "";
string KeyChar = "";
uint MAPVK_VK_TO_VSC = 0;
int VK_MENU = 0x12;
int VK_LMENU = 0xA4;
int VK_RMENU = 0xA5;
int VK_CONTROL = 0x11;
int VK_LCONTROL = 0xA2;
int VK_RCONTROL = 0xA3;
public LearnWindow() => InitializeComponent();
[DllImport("user32.dll", CharSet = CharSet.Auto)]
static extern short GetKeyState(int keyCode);
[DllImport("user32.dll")]
static extern uint MapVirtualKey(uint uCode, uint uMapType);
[DllImport("user32.dll", CharSet = CharSet.Unicode)]
static extern int ToUnicode(uint wVirtKey, uint wScanCode, byte[] lpKeyState,
StringBuilder pwszBuff, int cchBuff, uint wFlags);
[DllImport("user32.dll")]
static extern bool GetKeyboardState(byte[] lpKeyState);
string ToUnicode(uint vk)
{
byte[] keys = new byte[256];
if (!GetKeyboardState(keys))
return "";
if ((keys[VK_CONTROL] & 0x80) != 0 && (keys[VK_MENU] & 0x80) == 0)
keys[VK_LCONTROL] = keys[VK_RCONTROL] = keys[VK_CONTROL] = 0;
uint scanCode = MapVirtualKey(vk, MAPVK_VK_TO_VSC);
string ret = ToUnicode(vk, scanCode, keys);
if (ret.Length == 1 && (int)ret[0] < 32)
return "";
if (ret == "" && (keys[VK_MENU] & 0x80) != 0)
{
keys[VK_LMENU] = keys[VK_RMENU] = keys[VK_MENU] = 0;
ret = ToUnicode(vk, scanCode, keys);
}
return ret;
}
public string ToUnicode(uint vk, uint scanCode, byte[] keys)
{
StringBuilder sb = new StringBuilder(10);
ToUnicode(vk, scanCode, keys, sb, sb.Capacity, 0);
return sb.ToString();
}
IntPtr WndProc(IntPtr hwnd, int msg, IntPtr wParam, IntPtr lParam, ref bool handled)
{
WinForms.Message m = new WinForms.Message();
Message m = new Message();
m.HWnd = hwnd;
m.Msg = msg;
m.WParam = wParam;
@@ -29,116 +84,86 @@ namespace mpvnet
return m.Result;
}
void OnKeyUp(WinForms.KeyEventArgs e)
void OnKeyDown(uint vk)
{
if (e.KeyCode == WinForms.Keys.ControlKey || e.KeyCode == WinForms.Keys.ShiftKey ||
e.KeyCode == WinForms.Keys.Menu || e.KeyCode == WinForms.Keys.None)
Keys key = (Keys)vk;
if (key == Keys.ControlKey || key == Keys.ShiftKey ||
key == Keys.Menu || key == Keys.None)
return;
string text = "";
uint charValue = MapVirtualKey((uint)e.KeyCode, 2);
string text = ToUnicode(vk);
if (charValue == 0 || (charValue & 1 << 31) == 1 << 31)
text = e.KeyCode.ToString().Trim();
else
try {
text = Convert.ToChar(charValue).ToString().ToLower().Trim();
} catch {}
if ((int)key > 111 && (int)key < 136)
text = "F" + ((int)key - 111);
for (int i = 0; i < 13; i++)
if ("D" + i == text)
text = text.Substring(1);
if ((int)key > 95 && (int)key < 106)
text = "KP" + ((int)key - 96);
switch (e.KeyCode)
switch (text)
{
case WinForms.Keys.NumPad0:
case WinForms.Keys.NumPad1:
case WinForms.Keys.NumPad2:
case WinForms.Keys.NumPad3:
case WinForms.Keys.NumPad4:
case WinForms.Keys.NumPad5:
case WinForms.Keys.NumPad6:
case WinForms.Keys.NumPad7:
case WinForms.Keys.NumPad8:
case WinForms.Keys.NumPad9:
text = "KP" + e.KeyCode.ToString()[6]; break;
case WinForms.Keys.Space:
text = "SPACE"; break;
case WinForms.Keys.Enter:
text = "ENTER"; break;
case WinForms.Keys.Tab:
text = "TAB"; break;
case WinForms.Keys.Back:
text = "BS"; break;
case WinForms.Keys.Delete:
text = "DEL"; break;
case WinForms.Keys.Insert:
text = "INS"; break;
case WinForms.Keys.Home:
text = "HOME"; break;
case WinForms.Keys.End:
text = "END"; break;
case WinForms.Keys.PageUp:
text = "PGUP"; break;
case WinForms.Keys.PageDown:
text = "PGDWN"; break;
case WinForms.Keys.Escape:
text = "ESC"; break;
case WinForms.Keys.PrintScreen:
text = "PRINT"; break;
case WinForms.Keys.Play:
text = "PLAY"; break;
case WinForms.Keys.Pause:
text = "PAUSE"; break;
case WinForms.Keys.MediaPlayPause:
text = "PLAYPAUSE"; break;
case WinForms.Keys.MediaStop:
text = "STOP"; break;
case WinForms.Keys.MediaNextTrack:
text = "NEXT"; break;
case WinForms.Keys.MediaPreviousTrack:
text = "PREV"; break;
case WinForms.Keys.BrowserHome:
text = "HOMEPAGE"; break;
case WinForms.Keys.LaunchMail:
text = "MAIL"; break;
case WinForms.Keys.BrowserFavorites:
text = "FAVORITES"; break;
case WinForms.Keys.BrowserSearch:
text = "SEARCH"; break;
case WinForms.Keys.Sleep:
text = "SLEEP"; break;
case WinForms.Keys.Cancel:
text = "CANCEL"; break;
case WinForms.Keys.VolumeUp:
case WinForms.Keys.VolumeDown:
case WinForms.Keys.VolumeMute:
case "#": text = "SHARP"; break;
case "´´": text = "´"; break;
case "``": text = "`"; break;
case "^^": text = "^"; break;
}
switch (key)
{
case Keys.Left: text = "LEFT"; break;
case Keys.Up: text = "UP"; break;
case Keys.Right: text = "RIGHT"; break;
case Keys.Down: text = "DOWN"; break;
case Keys.Space: text = "SPACE"; break;
case Keys.Enter: text = "ENTER"; break;
case Keys.Tab: text = "TAB"; break;
case Keys.Back: text = "BS"; break;
case Keys.Delete: text = "DEL"; break;
case Keys.Insert: text = "INS"; break;
case Keys.Home: text = "HOME"; break;
case Keys.End: text = "END"; break;
case Keys.PageUp: text = "PGUP"; break;
case Keys.PageDown: text = "PGDWN"; break;
case Keys.Escape: text = "ESC"; break;
case Keys.Sleep: text = "SLEEP"; break;
case Keys.Cancel: text = "CANCEL"; break;
case Keys.PrintScreen: text = "PRINT"; break;
case Keys.BrowserFavorites: text = "FAVORITES"; break;
case Keys.BrowserSearch: text = "SEARCH"; break;
case Keys.BrowserHome: text = "HOMEPAGE"; break;
case Keys.LaunchMail: text = "MAIL"; break;
case Keys.Play: text = "PLAY"; break;
case Keys.Pause: text = "PAUSE"; break;
case Keys.MediaPlayPause: text = "PLAYPAUSE"; break;
case Keys.MediaStop: text = "STOP"; break;
case Keys.MediaNextTrack: text = "NEXT"; break;
case Keys.MediaPreviousTrack: text = "PREV"; break;
case Keys.VolumeUp:
case Keys.VolumeDown:
case Keys.VolumeMute:
text = ""; break;
}
bool wasModified = false;
bool isAlt = GetKeyState(18) < 0;
bool isShift = GetKeyState(16) < 0;
bool isCtrl = GetKeyState(17) < 0;
bool isAlt = GetKeyState(18) < (short)0;
bool isShift = GetKeyState(16) < (short)0;
bool isCtrl = GetKeyState(17) < (short)0;
bool isLetter = (int)key > 64 && (int)key < 91;
if (text.Length == 1 && KeyChar != text)
{
text = KeyChar;
wasModified = true;
}
if (isLetter && isShift)
text = text.ToUpper();
if (text == "#")
text = "SHARP";
string keyString = ToUnicode(vk);
if (isAlt && !wasModified)
if (isAlt && !isCtrl)
text = "ALT+" + text;
if (isShift && !wasModified)
if (isShift && keyString == "")
text = "SHIFT+" + text;
if (isCtrl && !wasModified)
if (isCtrl && !(keyString != "" && isCtrl && isAlt))
text = "CTRL+" + text;
if (!string.IsNullOrEmpty(text))
@@ -152,32 +177,14 @@ namespace mpvnet
KeyTextBlock.Text = key;
}
[DllImport("user32.dll")]
static extern uint MapVirtualKey(uint uCode, uint uMapType);
public static WinForms.Keys ModifierKeys {
get {
WinForms.Keys keys = WinForms.Keys.None;
if (GetKeyState(17) < (short)0)
keys |= WinForms.Keys.Control;
if (GetKeyState(16) < (short)0)
keys |= WinForms.Keys.Shift;
if (GetKeyState(18) < (short)0)
keys |= WinForms.Keys.Alt;
return keys;
}
}
void ProcessKeyEventArgs(ref WinForms.Message m)
void ProcessKeyEventArgs(ref Message m)
{
int WM_KEYUP = 0x0101, WM_SYSKEYUP = 0x0105, WM_APPCOMMAND = 0x0319;
int WM_KEYDOWN = 0x100;
int WM_SYSKEYDOWN = 0x104;
int WM_APPCOMMAND = 0x319;
if (m.Msg == WM_KEYUP || m.Msg == WM_SYSKEYUP)
OnKeyUp(new WinForms.KeyEventArgs((WinForms.Keys)(unchecked((int)(long)m.WParam)) | ModifierKeys));
if (m.Msg == WM_KEYDOWN || m.Msg == WM_SYSKEYDOWN)
OnKeyDown((uint)m.WParam.ToInt64());
else if (m.Msg == WM_APPCOMMAND)
{
string value = mpvHelp.WM_APPCOMMAND_to_mpv_key((int)(m.LParam.ToInt64() >> 16 & ~0xf000));
@@ -187,9 +194,6 @@ namespace mpvnet
}
}
[DllImport("user32.dll", CharSet = CharSet.Auto)]
public static extern short GetKeyState(int keyCode);
void Window_Loaded(object sender, RoutedEventArgs e)
{
HwndSource source = HwndSource.FromHwnd(new WindowInteropHelper(this).Handle);
@@ -250,9 +254,13 @@ namespace mpvnet
}
}
void Window_TextInput(object sender, TextCompositionEventArgs e)
void Window_PreviewKeyDown(object sender, System.Windows.Input.KeyEventArgs e)
{
KeyChar = e.Text;
if (e.Key == Key.Tab)
{
OnKeyDown((uint)Keys.Tab);
e.Handled = true;
}
}
}
}

View File

@@ -321,26 +321,26 @@ namespace mpvnet
}
height = Convert.ToInt32(height * scale);
int width = Convert.ToInt32(height * videoSize.Width / (double)videoSize.Height);
int width = height * videoSize.Width / videoSize.Height;
int maxHeight = screen.WorkingArea.Height - (Height - ClientSize.Height);
int maxWidth = screen.WorkingArea.Width - (Width - ClientSize.Width);
if (height < maxHeight * core.AutofitSmaller)
{
height = Convert.ToInt32(maxHeight * core.AutofitSmaller);
width = Convert.ToInt32(height * videoSize.Width / (double)videoSize.Height);
width = Convert.ToInt32(height * videoSize.Width / videoSize.Height);
}
if (height > maxHeight * core.AutofitLarger)
{
height = Convert.ToInt32(maxHeight * core.AutofitLarger);
width = Convert.ToInt32(height * videoSize.Width / (double)videoSize.Height);
width = Convert.ToInt32(height * videoSize.Width / videoSize.Height);
}
if (width > maxWidth)
{
width = maxWidth;
height = Convert.ToInt32(width * videoSize.Height / (double)videoSize.Width);
height = (int)Math.Ceiling(width * videoSize.Height / (double)videoSize.Width);
}
Point middlePos = new Point(Left + Width / 2, Top + Height / 2);
@@ -579,8 +579,18 @@ namespace mpvnet
s = new Size(16, 9);
float aspect = s.Width / (float)s.Height;
int d_w = Convert.ToInt32(c_h * aspect - c_w);
int d_h = Convert.ToInt32(c_w / aspect - c_h);
int d_w = (int)(c_h * aspect - c_w);
int d_h = (int)(c_w / aspect - c_h);
Debug.WriteLine(d_w);
Debug.WriteLine(d_h);
int d_w2 = (int)(c_h * aspect - c_w);
int d_h2 = (int)(c_w / aspect - c_h);
Debug.WriteLine(d_w2);
Debug.WriteLine(d_h2);
int[] d_corners = { d_w, d_h, -d_w, -d_h };
int[] corners = { rc.Left, rc.Top, rc.Right, rc.Bottom };
int corner = NativeHelp.GetResizeBorder(m.WParam.ToInt32());