ИТ-администратор клиента попросил меня "написать скрипт powershell, который вручную устанавливает разрешение при загрузке". Предположительно, это возможно, если они просят меня сделать это. У меня нет абсолютно никакого опыта работы с powershell. Мои скрипты/команды и их ошибки следующие:
Set-DisplayResolution -Width 1024 -Height 768
Set-DisplayResolution
не распознается как имя командлета, функции, файла сценария или исполняемой программы.
Set-ScreenResolution -Width 1024 -Height 768
Set-ScreenResolution
не распознается как имя командлета, функции, файла сценария или исполняемой программы.
SetDisplayResolution -Width 1024 -Height 768
SetDisplayResolution
не распознается как имя командлета, функции, файла сценария или исполняемой программы.
Что я упускаю? Спасибо.
решение1
Не уверен, откуда вы взяли свой пример, но в родной оболочке PowerShell нет команды для установки разрешения.
Я использую AutoHotKey. Вы можете написать свой скрипт там или использоватьпримериз сети.
Или вы можете написать свою собственную функцию, которую можно будет вызывать из PowerShell:глянь сюда
И, конечно, есть несколько сторонних инструментов в зависимости от ваших требований. Вотодин примеркоторый также работает со скриптом или вот7 других. Что именно ты пытаешься сделать?
решение2
Вам необходимо установитьНастройки отображениямодуль из Powershell-Gallery для получения этой функции.
Установка модуля
Install-Module -Name DisplaySettings
Применение
Set-DisplayResolution -Width 800 -Height 600
решение3
Создайте файл setResolution.ps1 со следующим содержимым (src):
Function Set-ScreenResolution {
<#
.Synopsis
Sets the Screen Resolution of the primary monitor
.Description
Uses Pinvoke and ChangeDisplaySettings Win32API to make the change
.Example
Set-ScreenResolution -Width 1024 -Height 768
#>
param (
[Parameter(Mandatory=$true,
Position = 0)]
[int]
$Width,
[Parameter(Mandatory=$true,
Position = 1)]
[int]
$Height
)
$pinvokeCode = @"
using System;
using System.Runtime.InteropServices;
namespace Resolution
{
[StructLayout(LayoutKind.Sequential)]
public struct DEVMODE1
{
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
public string dmDeviceName;
public short dmSpecVersion;
public short dmDriverVersion;
public short dmSize;
public short dmDriverExtra;
public int dmFields;
public short dmOrientation;
public short dmPaperSize;
public short dmPaperLength;
public short dmPaperWidth;
public short dmScale;
public short dmCopies;
public short dmDefaultSource;
public short dmPrintQuality;
public short dmColor;
public short dmDuplex;
public short dmYResolution;
public short dmTTOption;
public short dmCollate;
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
public string dmFormName;
public short dmLogPixels;
public short dmBitsPerPel;
public int dmPelsWidth;
public int dmPelsHeight;
public int dmDisplayFlags;
public int dmDisplayFrequency;
public int dmICMMethod;
public int dmICMIntent;
public int dmMediaType;
public int dmDitherType;
public int dmReserved1;
public int dmReserved2;
public int dmPanningWidth;
public int dmPanningHeight;
};
class User_32
{
[DllImport("user32.dll")]
public static extern int EnumDisplaySettings(string deviceName, int modeNum, ref DEVMODE1 devMode);
[DllImport("user32.dll")]
public static extern int ChangeDisplaySettings(ref DEVMODE1 devMode, int flags);
public const int ENUM_CURRENT_SETTINGS = -1;
public const int CDS_UPDATEREGISTRY = 0x01;
public const int CDS_TEST = 0x02;
public const int DISP_CHANGE_SUCCESSFUL = 0;
public const int DISP_CHANGE_RESTART = 1;
public const int DISP_CHANGE_FAILED = -1;
}
public class PrmaryScreenResolution
{
static public string ChangeResolution(int width, int height)
{
DEVMODE1 dm = GetDevMode1();
if (0 != User_32.EnumDisplaySettings(null, User_32.ENUM_CURRENT_SETTINGS, ref dm))
{
dm.dmPelsWidth = width;
dm.dmPelsHeight = height;
int iRet = User_32.ChangeDisplaySettings(ref dm, User_32.CDS_TEST);
if (iRet == User_32.DISP_CHANGE_FAILED)
{
return "Unable To Process Your Request. Sorry For This Inconvenience.";
}
else
{
iRet = User_32.ChangeDisplaySettings(ref dm, User_32.CDS_UPDATEREGISTRY);
switch (iRet)
{
case User_32.DISP_CHANGE_SUCCESSFUL:
{
return "Success";
}
case User_32.DISP_CHANGE_RESTART:
{
return "You Need To Reboot For The Change To Happen.\n If You Feel Any Problem After Rebooting Your Machine\nThen Try To Change Resolution In Safe Mode.";
}
default:
{
return "Failed To Change The Resolution";
}
}
}
}
else
{
return "Failed To Change The Resolution.";
}
}
private static DEVMODE1 GetDevMode1()
{
DEVMODE1 dm = new DEVMODE1();
dm.dmDeviceName = new String(new char[32]);
dm.dmFormName = new String(new char[32]);
dm.dmSize = (short)Marshal.SizeOf(dm);
return dm;
}
}
}
"@
Add-Type $pinvokeCode -ErrorAction SilentlyContinue
[Resolution.PrmaryScreenResolution]::ChangeResolution($width,$height)
}
Set-ScreenResolution -Width 1024 -Height 768
Затем файл можно запустить из PowerShell следующим образом:
`C:\path-to-file\setResolution.ps1`
решение4
Скрипт powershell из поста Альбина работал нормально, но на одной машине он позволил мне установить только 1920x1080, а не 1920x1200, что я мог сделать вручную. В конце концов мне пришлось использовать Nirsoft MultiMonitor, который позволяет сохранять и загружать профили. Мне удалось отредактировать файл конфигурации и просто указать параметры разрешения, и он работает довольно хорошо. Файл конфигурации выглядит так:
Name=\\.\DISPLAY1
Width=1920
Height=1200
Хотя я предпочитаю избегать сторонних инструментов, где это возможно, в данном случае он бесплатный, легкий и работает очень хорошо (и не жаловался ни на один вирус)...