Последние записи
- TChromium (CEF3), сохранение изображений
- Как в Delphi XE обнулить таймер?
- Изменить цвет шрифта TextBox на форме
- Ресайз PNG без потери прозрачности
- Вывод на печать графического файла
- Взаимодействие через командную строку
- Перенести программу из Delphi в Lazarus
- Определить текущую ОС
- Автоматическая смена языка (раскладки клавиатуры)
- Сравнение языков на массивах. Часть 2
Интенсив по Python: Работа с API и фреймворками 24-26 ИЮНЯ 2022. Знаете Python, но хотите расширить свои навыки?
Slurm подготовили для вас особенный продукт! Оставить заявку по ссылке - https://slurm.club/3MeqNEk
Online-курс Java с оплатой после трудоустройства. Каждый выпускник получает предложение о работе
И зарплату на 30% выше ожидаемой, подробнее на сайте академии, ссылка - ttps://clck.ru/fCrQw
5th
Сен
WinIO для чтения/записи портов I/O и физической памяти
Есть подписанный ЭЦП драйвер WinIo 3.0 для доступа к портам и мапинга физической памяти для 32/64-разрадяных Windows. Драйвер с открытым исходным кодом и является весьма популярным.
На Delphi 7 я воспроизвёл код установки драйвера в системе и обращение к нему через DeviceIoControl. Драйвер успешно зарегистрировался в Service Control Manager, запустился через StartService, успешно возвратил хэндл через CreateFile и даже смог считать и писать порты ввода-вывода, как под Windows 11 x64, так и Windows 7 32-bit.
Однако если попытаться замапить память через MapPhysToLin, то драйвер возвращает совсем не то, что нужно. Код мапинга очень простой и ошибки здесь нет:
type
TtagPhysStruct = packed record
dwPhysMemSizeInBytes : Int64; //Number of bytes to map
pvPhysAddress : Int64; //Physical address to be mapped
PhysicalMemoryHandle : Int64; //Handle to a section returned by ZwOpenSection
pvPhysMemLin : Int64; //Pointer to a variable that receives the base address of the view
pvPhysSection : Int64;
end;
function MapPhysToLin(var PhysStruct: TtagPhysStruct) : Int64;
var
dwBytesReturned : DWORD;
begin
if not DeviceIoControl(hDriver,
IOCTL_WINIO_MAPPHYSTOLIN, //IOCTL 0x810
@PhysStruct,
SizeOf(TtagPhysStruct),
@PhysStruct,
SizeOf(TtagPhysStruct),
dwBytesReturned,nil)
then Result:=0
else Result:=PhysStruct.pvPhysMemLin;
Поэтому я решился попробовать замапить память через прилагаемую к драйверу библиотеку WinIo32.dll, которая экспортирует функцию GetPhysLong. Данная функция возвращает значение типа DWORD, записанное по определённому адресу в физической памяти.
var
dllGetPhysLong: function (pbPhysAddr: PByte; out pdwPhysVal: PDWORD): Boolean; stdcall;
dllInitializeWinIo: function : Boolean; stdcall;
procedure TForm1.Button2Click(Sender: TObject);
var
hLibrary: THandle;
hBuffer : PDWORD;
begin
hBuffer:=0;
hLibrary:=LoadLibrary('WinIo32.dll');
if hLibrary > HINSTANCE_ERROR then
begin
@dllInitializeWinIo:=GetProcAddress(hLibrary, 'InitializeWinIo');
@dllGetPhysLong:=GetProcAddress(hLibrary, 'GetPhysLong');
if @dllInitializeWinIo <> nil then
if dllInitializeWinIo then
if @dllGetPhysLong <> nil then
begin
if dllGetPhysLong(Ptr($C0000),hBuffer) then
ShowMessage(IntToHex(DWORD(hBuffer),8))
else ShowMessage('Error '+IntToHex(GetLastError,8));;
end;
FreeLibrary(hLibrary);
end;
end;
В коде выше я считываю 4 байта под адресу 0xC0000 (видеопамять). По этому адресу записано 0хE972AA55, которое успешно и возвращается при нажатии на кнопку. Но юзать DLL-ку мне не хочется. Хотелось бы воспроизвести все функции в своём коде самостоятельно.
Есть подозрение, что в С++ своя особенная упаковка структуры TtagPhysStruct:
#pragma pack(push)
#pragma pack(1)
struct tagPhysStruct
{
DWORD64 dwPhysMemSizeInBytes;
DWORD64 pvPhysAddress;
DWORD64 PhysicalMemoryHandle;
DWORD64 pvPhysMemLin;
DWORD64 pvPhysSection;
};
#pragma pack(pop)
#endif
В общем, если кому-то уже ранее удалось портировать WinIo на Delphi, то я был бы рад любой помощи!
30th
Авг
Delphi: Вывести N директорий в заданной (без рекурсии вложенных папок)
Ищу рабочие примеры с правильным использованием FindFirst, FindNext.
25th
Авг
Дополнительные кнопки мышки
На моей мышке есть дополнительные две кнопки
Вопрос: как в D7 отловить их нажатие, чтобы использовать в своей программе?
29th
Июн
Как перевернуть экран на 90 и 180 градусов?
Как перевернуть второй экран? На 90 и 180 градусов. Основной я разобрался:
procedure ChangeOrientation(NewOrientation:DWORD);
var
dm : TDeviceMode;
dwTemp : DWORD;
dmDisplayOrientation : DWORD;
begin
ZeroMemory(@dm, sizeof(dm));
dm.dmSize := sizeof(dm);
if EnumDisplaySettings(nil, DWORD(ENUM_CURRENT_SETTINGS), dm) then
begin
Move(dm.dmScale,dmDisplayOrientation,SizeOf(dmDisplayOrientation));
// swap width and height
if Odd(dmDisplayOrientation)<>Odd(NewOrientation) then
begin
dwTemp := dm.dmPelsHeight;
dm.dmPelsHeight:= dm.dmPelsWidth;
dm.dmPelsWidth := dwTemp;
end;
if dmDisplayOrientation<>NewOrientation then
begin
Move(NewOrientation,dm.dmScale,SizeOf(NewOrientation));
if (ChangeDisplaySettings(dm, 0)<>DISP_CHANGE_SUCCESSFUL) then
RaiseLastOSError;
end;
end;
end;
25th
Июн
Отрисовка текста на Canvas с перекрытием букв друг друга
Имеется задача отрисовывать текст по выбранному шрифту на Image в определенном формате. При этом текст сразу отрисовываться сразу одной строкой не может, т.к. элементы строки содержат разный цвет, поэтому отрисовка текста происходит в цикле со смещением вправо.
Проблема возникает в том, что на выходе текст обрезается, т.к. по каким-то причинам некорректно рассчитывается его ширина. Особенно это проглядывается при выборе курсива — там вообще ширина получается идентичной, что и без курсива почему-то. Но и без курсива проблема имеется.
Упрощенный пример задачи:
procedure TForm2.Button1Click(Sender: TObject);
var
i, WidthShift: Integer;
str, delim: string;
Font: TFont;
Colors: TArray<TColor>;
begin
Font := TFont.Create;
Colors := TArray<TColor>.Create(clRed, clBlack, clGreen);
WidthShift := 10;
if FontDialog1.Execute then
begin
Font.Assign(FontDialog1.Font);
end;
Image1.Canvas.Brush.Color := clWhite;
Image1.Canvas.FillRect(Image1.Canvas.ClipRect);
Image1.Canvas.Font.Assign(Font);
delim := '/';
for i := 0 to 2 do
begin
str := '0';
if i <> 0 then
str := delim + str;
Image1.Canvas.Font.Color := Colors;
Image1.Canvas.TextOut(WidthShift, 100, str);
WidthShift := WidthShift + Image1.Canvas.TextWidth(str);
end;
Font.Free;
end;
В первом случае текст обычный и все равно обрезается. А во втором курсив — там вообще все плохо.
В качестве решения можно было бы рассчитывать какой-то промежуточный запас (относительно высоты шрифта или еще по какой-то зависимости) и добавлять его на каждой итерации, однако по условиям задачи пробелов быть не должно.
Подскажите, пожалуйста, как можно побороть данную проблему?
15th
Июн
Проблемы с кодировкой в запросе через THTTPSend
Подскажите, есть скрипт на моем веб сервере. Через get запрос принимает фразу и переводит на англ.
С веб браузера скрипт отображает текст нормально, кирилица + латиница.
А с делфи (THTTPSend) ни как не могу получить ответ без кракозябр..
const
URL = 'https://.com/translate/translate.php?source=ru&target=en&text=привет';
var
HTTPs: THTTPSend;
res: TStringList;
JS:ISuperObject;
begin
HTTPs := THTTPSend.Create;
res := TStringList.Create;
HTTPs.Headers.Clear;
if not HTTPs.HTTPMethod('GET', URL) then
showmessage('internet connection: error') else
begin
res.LoadFromStream(HTTPs.Document);
JS:=SO(res.text);
Clipboard.AsText :=Utf8ToAnsi(RawByteString(res.Text));
ShowMessage(res.text);
end;
end;
Utf8ToAnsi(RawByteString( — это уже от безисходности начал варианты с интернета перебирать…
Может есть у кого совет ?
8th
Май
Динамическое создание массива TScrollBar
Как динамически создать массив TScrollBar, чтобы не возникло проблем?
30th
Апр
Как разместить форму в панель задач?
Хочу разместить форму в панель задач. Как мне это сделать, например, вместо часов?
25th
Апр
CMD скрипт, запустить из memo
Можно ли запустить CMD скрипт с самой программы, например с компонента memo? Как если бы запустили его посредством запуска файла .cmd ???
Нужно чтобы весь скрипт считывался с компоненты.
14th
Апр
Как узнать дату окончания сертификата
Есть куча *.cer файлов. Как программно узнать дату окончания сертификата?
Облако меток
css реестр ассемблер timer SaveToFile ShellExecute программы массив советы word MySQL SQL ListView pos random компоненты дата LoadFromFile form база данных сеть html php RichEdit indy строки Win Api tstringlist Image мысли макросы Edit ListBox office C/C++ memo графика StringGrid canvas поиск файл Pascal форма Файлы интернет Microsoft Office Excel excel winapi журнал ПРОграммист DelphiКупить рекламу на сайте за 1000 руб
пишите сюда - alarforum@yandex.ru
Да и по любым другим вопросам пишите на почту
пеллетные котлы
Пеллетный котел Emtas
Наши форумы по программированию:
- Форум Web программирование (веб)
- Delphi форумы
- Форумы C (Си)
- Форум .NET Frameworks (точка нет фреймворки)
- Форум Java (джава)
- Форум низкоуровневое программирование
- Форум VBA (вба)
- Форум OpenGL
- Форум DirectX
- Форум CAD проектирование
- Форум по операционным системам
- Форум Software (Софт)
- Форум Hardware (Компьютерное железо)