O administrador de TI de um cliente me pediu para "escrever um script do PowerShell que defina a resolução manualmente na inicialização". Presumivelmente, é possível se eles estiverem me pedindo para fazer isso. Não tenho absolutamente nenhuma experiência com o PowerShell. Meus scripts/comandos e seus erros são os seguintes:
Set-DisplayResolution -Width 1024 -Height 768
Set-DisplayResolution
não é reconhecido como o nome de um cmdlet, função, arquivo de script ou programa operável.
Set-ScreenResolution -Width 1024 -Height 768
Set-ScreenResolution
não é reconhecido como o nome de um cmdlet, função, arquivo de script ou programa operável.
SetDisplayResolution -Width 1024 -Height 768
SetDisplayResolution
não é reconhecido como o nome de um cmdlet, função, arquivo de script ou programa operável.
o que estou perdendo? Obrigado.
Responder1
Não tenho certeza de onde você tirou seu exemplo, mas em um PowerShell nativo não há comando para definir a resolução.
Eu uso o AutoHotKey. Você pode construir seu próprio script lá ou usarum exemploda rede.
Ou você pode escrever sua própria função, que pode ser chamada pelo PowerShell:Veja aqui
E, claro, existem várias ferramentas de terceiros, dependendo das suas necessidades. Aqui estáum exemploque funciona com um script também ou aqui estão7 outros. O que exatamente você está tentando fazer?
Responder2
Você precisa instalar oConfigurações do visormódulo da Powershell-Gallery para obter esta função.
Instalação do Módulo
Install-Module -Name DisplaySettings
Uso
Set-DisplayResolution -Width 800 -Height 600
Responder3
Crie um arquivo setResolution.ps1 com o seguinte conteúdo (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
Então o arquivo pode ser executado a partir do PowerShell da seguinte maneira
`C:\path-to-file\setResolution.ps1`
Responder4
O script do PowerShell da postagem de Albin estava funcionando bem - mas em uma máquina só me permitiu definir 1920x1080 e não 1920x1200, o que consegui fazer manualmente. No final tive que usar o Nirsoft MultiMonitor que permite salvar e carregar perfis. Consegui editar o arquivo de configuração e apenas inserir os parâmetros de resolução e está funcionando muito bem. O arquivo de configuração fica assim:
Name=\\.\DISPLAY1
Width=1920
Height=1200
Embora eu prefira evitar ferramentas de terceiros sempre que possível, nesta ocasião ela é gratuita, leve e funciona muito bem (e não reclamei de nenhum vírus)...