Форум программистов, компьютерный форум, киберфорум
Delphi
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.85/20: Рейтинг темы: голосов - 20, средняя оценка - 4.85
157 / 300 / 47
Регистрация: 14.08.2012
Сообщений: 2,578

Иницилизация расширения файла

25.10.2012, 20:16. Показов 4667. Ответов 41
Метки нет (Все метки)

Привет. У меня возникла такая проблема: Дело в том, если создаешь файлы со своим расширением, то эти файлы откроются только тем приложением, которым созданы(имеено тем). Можете подсказать как иницилизировать моё расширение и какими примерно путями(через ресстр или модуль, или dll)? Буду очень благодарен. P.S. Иницилизация идет на одно название приложения.

Добавлено через 5 минут
Понимаю это довольно трудно, но мне это просто необходимо.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.10.2012, 20:16
Ответы с готовыми решениями:

Добавление расширения файла в конец каждой строки этого файла
Добрый вечер, Нужно решить следующую задачу: Ежедневно в папку c:/req скидывается файл. Расширение файла постоянно меняется. Нужно...

Иницилизация массива
Есть: typedef unsigned ptrel; typedef struct element {basetype data; ptrel next; }; ...

Иницилизация динамического массива в конструкторе
#include <iostream> #include <string> using namespace std; class A { int *p; int n; public: A(){};

41
251 / 156 / 31
Регистрация: 07.10.2012
Сообщений: 401
06.11.2012, 23:29
Во всём модуле замени Pchar на PWideChar .
Не волнуйся, тебе ещё долго мучиться.
Цитата Сообщение от Alex_pac Посмотреть сообщение
саша40, где строка 119 ?
35
0
157 / 300 / 47
Регистрация: 14.08.2012
Сообщений: 2,578
07.11.2012, 12:34  [ТС]
Цитата Сообщение от Alex_pac Посмотреть сообщение
саша40, где строка 119 ?
Я её коментом указал. Думаю там одного входного параметра нет.

Добавлено через 1 час 36 минут
Ура. Наконец сделали. Вот код:
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
unit AssocUnit;
 
interface
 
uses Windows, Forms, Registry, ComObj, SysUtils, ActiveX, ShlObj;
 
type
  ASSOCIATIONTYPE = (AT_FILEEXTENSION, AT_URLPROTOCOL,
     AT_STARTMENUCLIENT, AT_MIMETYPE);
 
  ASSOCIATIONLEVEL = (AL_MACHINE, AL_EFFECTIVE, AL_USER);
 
  IApplicationAssociationRegistration = interface(IUnknown)
  ['{4e530b0a-e611-4c77-a3ac-9031d022281b}']
  function ClearUserAssociations: HRESULT; stdcall;
   function QueryAppIsDefault(pszQuery: PWideChar; atQueryType:
     ASSOCIATIONTYPE; alQueryLevel: ASSOCIATIONLEVEL; pszAppRegistryName:
     PWideChar; var pfDefault: BOOL): HRESULT; stdcall;
   function QueryAppIsDefaultAll(alQueryLevel: ASSOCIATIONLEVEL;
     pszAppRegistryName: PWideChar; var pfDefault: BOOL): HRESULT; stdcall;
   function QueryCurrentDefault(pszQuery: PWideChar; atQueryType:
     ASSOCIATIONTYPE; alQueryLevel: ASSOCIATIONLEVEL; var ppszAssociation:
     PWideChar): HRESULT; stdcall;
   function SetAppAsDefault(pszAppRegistryName: PWideChar; pszSet:
     PWideChar; atSetType: ASSOCIATIONTYPE): HRESULT; stdcall;
   function SetAppAsDefaultAll(pszAppRegistryName: PWideChar):
     HRESULT; stdcall;
  end;
  TAssoc = class(TObject)
  private
  public
  constructor Create;
  destructor Destroy; override;
  procedure Initilization(Name: string);
  procedure RegisterApp;
  function Register(pExt: PChar): Boolean;
  function UnRegister(pExt: PChar): Boolean;
  function IsRegister(pExt: PChar): Boolean;
end;
 
const
  CLSID_ApplicationAssociationRegistration: TGUID     = '{591209c7-767b-42b2-9fba-44ee4615f2c7}';
 
var
 
FReg: TRegistry;
FAppAssocReg: IApplicationAssociationRegistration;
MY_NAME: string;
 
implementation
 
constructor TAssoc.Create;
begin
FReg := TRegistry.Create;
FAppAssocReg := IApplicationAssociationRegistration
(CreateComObject(CLSID_ApplicationAssociationRegistration));
end;
 
destructor TAssoc.Destroy;
begin
  FReg.Free;
end;
 
procedure TAssoc.RegisterApp;
var
  sKey: string;
begin
  if Assigned(FAppAssocReg) then
  begin
    sKey := 'Software\Clients\Media\' + MY_NAME + '\Capabilities';
    FReg.RootKey := HKEY_LOCAL_MACHINE;
    if FReg.OpenKey('SOFTWARE\RegisteredApplications', True) then
    begin
      FReg.WriteString(MY_NAME, sKey);
      FReg.CloseKey;
    end;
    if FReg.OpenKey(sKey, True) then
    begin
      FReg.WriteExpandString('ApplicationDescription', MY_NAME);
      FReg.WriteExpandString('ApplicationIcon', '"' + Application.ExeName +
        '"' + ',0');
      FReg.WriteExpandString('ApplicationName', MY_NAME);
      FReg.CloseKey;
    end;
  end;
end;
 
function TAssoc.Register(pExt: PChar): Boolean;
var
  pCurrentAssociation: PChar;
  sID, sCurrentAssociation: string;
begin
  Result := False;
  FReg.RootKey := HKEY_CLASSES_ROOT;
  if not FReg.OpenKey(pExt, True) then
    Exit;
  sID := MY_NAME + pExt;
  if not FReg.OpenKey(sID + '\shell\open', True) then
    Exit;
  FReg.WriteString('', 'Открить в ' + MY_NAME);
  FReg.CloseKey;
  if not FReg.OpenKey(sID + '\shell\open\command', True) then
    Exit;
  FReg.WriteString('', '"' + Application.ExeName + '"' + ' "%1"');
  FReg.CloseKey;
  if not FReg.OpenKey(sID + '\DefaultIcon', True) then
    Exit;
  FReg.WriteString('', '"' + Application.ExeName + '"' + ',0');
  FReg.CloseKey;
  FReg.RootKey := HKEY_LOCAL_MACHINE;
  if not FReg.OpenKey('Software\Clients\Media\' + MY_NAME +
    '\Capabilities\FileAssociations', True) then
    Exit;
  FReg.WriteString(pExt, sID);
  FReg.CloseKey;
  FReg.RootKey := HKEY_CLASSES_ROOT;
  if FAppAssocReg <> nil then
  begin
    if FAppAssocReg.QueryCurrentDefault(PWideChar(pExt), AT_FILEEXTENSION, AL_EFFECTIVE, PWideChar(pCurrentAssociation))= 0 then
    begin
      sCurrentAssociation := pCurrentAssociation;
    Result:=FAppAssocReg.SetAppAsDefault(PWideChar(MY_NAME),PWideChar(pExt), AT_FILEEXTENSION)=0;
      end;
  end
  else
  begin
    if FReg.OpenKey(pExt, False) then
    begin
      sCurrentAssociation := FReg.ReadString('');
      FReg.WriteString('', sID);
      FReg.CloseKey;
      Result := True;
    end;
  end;
  if FReg.OpenKey(sID, True) then
  begin
    FReg.WriteString('Backup', pCurrentAssociation);
    FReg.CloseKey;
  end;
end;
procedure TAssoc.Initilization(Name: string);
begin
if Name='' then exit;
MY_Name:=Name;
end;
 
function TAssoc.UnRegister(pExt: PChar): Boolean;
var
  sID, sBackup: string;
begin
  Result := False;
  sID := MY_NAME + pExt;
  FReg.RootKey := HKEY_CLASSES_ROOT;
  if not FReg.OpenKey(sID, False) then
    Exit;
  sBackup := FReg.ReadString('Backup');
  FReg.CloseKey;
  if not FReg.OpenKey(pExt, False) then
    Exit;
  FReg.WriteString('', sBackup);
  FReg.CloseKey;
  Result := FReg.DeleteKey(sID);
end;
 
function TAssoc.IsRegister(pExt: PChar): Boolean;
var
  b: BOOL;
  sID: string;
begin
  b := False;
  FReg.RootKey := HKEY_CLASSES_ROOT;
  sID := MY_NAME + pExt;
  if FAppAssocReg <> nil then
    FAppAssocReg.QueryAppIsDefault(PWideChar(pExt), AT_FILEEXTENSION, AL_EFFECTIVE, PWideChar(MY_NAME), b)
  else
  begin
    if FReg.OpenKey(pExt, False) then
    begin
      b := FReg.ReadString('') = sID;
      FReg.CloseKey;
    end;
  end;
  if b then
  begin
    b := False;
    if FReg.OpenKey(sID + '\shell\open\command', False) then
    begin
      b := Pos(Application.ExeName, FReg.ReadString('')) > 0;
      FReg.CloseKey;
    end;
  end;
  Result := b;
end;
Применение:
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
procedure TForm1.ApplyAssoc;
var
  Assoc: TAssoc;
begin
  Assoc := TAssoc.Create;
  try
    Assoc.Initilization('Music Player');
    Assoc.RegisterApp;
    Assoc.Register('.saved');
  finally
    Assoc.Free;
  end;
end;
Наконец сделали. 14 дней работы, и наконец сделали. Ура!!! Всем огромное спасибо за помощь.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.11.2012, 12:34

Иницилизация плагина при условии существования класса
Добрый день. В тег html добавляется класс touch если это мобильное устройство или no-touch если это десктоп. Мне нужно что бы плагин...

Иницилизация двух одномерных динамических массивов в классе
Unit1.h(43): E2451 Undefined symbol 'W' выдает такую ошибку, вопрос почему на точно так же объявленный массив P не выдает ошибку, а на...

Дана строка содержащая полное имя файла.Выделить из этой строки только имя файла без расширения
1.Дан символ С.Вывести его код (то есть номер в кодовой таблице) 2. Дан символ С.Вывести два символа, первый из которых предшествует...

Проверка расширения файла
Доброго времени суток! Ребят помогите с созданием рег. выражения для проверки расширения файла. Должно проверить, если расширение НЕ как в...

Добавление расширения файла
Подскажите, пожалуйста, как сделать так, чтобы в программе при запуске пользователь вводиил только имя файла а расширение к нему добавляла...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
42
Ответ Создать тему
Новые блоги и статьи
Программа для com-порта
Uhbif79 05.06.2026
Всем привет, давно хотел изучить Qt, начинал, бросал, потом снова начинал. И сейчас вот смог написать свою первую программу. До этого имел опыт программирования микроконтроллеров, писал прошивки на. . .
Транскрипция 55-минутного видео через Whisper: WhisperDesktop облажался, спас Google Colab[
anaschu 01.06.2026
Понадобилось получить текст из свежезагруженного видео на YouTube. Казалось бы, задача на пять минут. Заняла полтора часа. Делюсь опытом — может кому пригодится последовательность решений. . . .
21 мат мед. Планы на развитие модели здравоСохранения
anaschu 01.06.2026
AnyLogic: план развития симуляционной модели рабочего коллектива — динамический абсентеизм, реальные данные, три сценария сравнения Продолжаю серию постов о дискретно-событийной модели рабочего. . .
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
"Прокси" для последовательного порта
Eddy_Em 28.05.2026
Эту штуку написал я достаточно давно. Но сейчас вот понадобилось настроить датчик грозы, но при этом не отключать его от "метеодемона". Соответственно, надо запустить этот "прокси": метеодемон будет. . .
Рефакторинг программы уравнивания.
Massaraksh7 26.05.2026
Пример по предыдущей записи в блоге. Но, надо заметить, что, во-первых, там оптимизация не только математики, но и работы с базой данных, и с графами, а во-вторых, это ещё не всё.
Использование TThread в Lazarus для математических вычислений.
Massaraksh7 25.05.2026
Производя рефакторинг своих программ на предмет ускорения их работы, обратил внимание на такой аспект, как сокращение времени матвычислений. Дело в том, что приходится работать с большими матрицами. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru