Перейти к содержанию
Fire Monkey от А до Я

Slym

Пользователи
  • Постов

    141
  • Зарегистрирован

  • Посещение

  • Победитель дней

    31

Весь контент Slym

  1. К счетчику Гейгера...? Что за девайс? Nokia ww3 edition?
  2. Slym

    Serial port

    ищи по тексту --min-sdk-version или делай дешугаринг либе
  3. Для лайков и хейтов. Все у кого получилось отписывайтесь что прилинковали и выкладывайте хедеры
  4. Линковка Kotlin (Котлин) библиотек в Delphi, как делаю: Хедеры линкуемых библиотек обычно громадны описанием всех типов... Я обычно делаю свой jar на java в нем линкую зависимости и наружу для дельфи оставляю один объект с простыми функциями. Хедер дельфи получается компактным и понятным: package com.MyCompany.evotor; public interface J2DCallback { void Log(String str); String Trans(String str); String GetValue(String name); void SetValue(String name, String value); Activity GetActivity(); Context GetContext(); } public class FiscalCoreConnection { final private Global Instance; public FiscalCoreConnection(J2DCallback aj2d) throws NullPointerException { Instance = new Global(aj2d); } public String SendJSON(String JSON){ try{ return Instance.SendJson(JSON); } catch (Exception e) { return FiscalCoreException.MakeJson(e); } } } type J2DCallbackClass = interface(IJavaClass) ['{856654D5-7939-44DF-ACD5-E2EF8C6D3AA4}'] end; [JavaSignature('com/MyCompany/evotor/J2DCallback')] J2DCallbackIntf = interface(IJavaInstance) ['{025B14E9-C041-4105-9E85-83CC127CC340}'] procedure Log(str:JString); cdecl; function Trans(str:JString):JString; cdecl; function GetValue(name:JString):JString; cdecl; procedure SetValue(name:JString; value:JString); cdecl; function GetActivity():JActivity; cdecl; function GetContext():JContext; cdecl; end; TJ2DCallbackImp = class(TJavaGenericImport<J2DCallbackClass, J2DCallbackIntf>) end; [JavaSignature('com/MyCompany/evotor/FiscalCoreConnection')] JFiscalCoreConnection = interface(JObject) ['{5797747D-D61D-4EF6-94F7-5E8994545CC2}'] function SendJSON(JSON:JString):JString; cdecl; end; JFiscalCoreConnectionClass = interface(JObjectClass) ['{81782882-DFCF-4FA9-BD37-02CCCF2409EA}'] function init(j2d : J2DCallbackIntf) : JFiscalCoreConnection; cdecl; end; TJFiscalCoreConnection = class(TJavaGenericImport<JFiscalCoreConnectionClass, JFiscalCoreConnection>) end; TJ2DCallback = class(TJavaLocal, J2DCallbackIntf) public procedure Log(str:JString); cdecl; function Trans(str:JString):JString; cdecl; function GetValue(name:JString):JString; cdecl; procedure SetValue(name:JString; value:JString); cdecl; function GetActivity():JActivity; cdecl; function GetContext():JContext; cdecl; end; Все зависимости в build.gradle: dependencies { implementation 'com.github.evotor:integration-library:v0.4.50' implementation 'com.google.zxing:core:3.4.0' } В Дереве External Libraries забираем jarы зависимостей ПКМ Show in Explorer. Копируем в папку своего проекта и даем осознанное имя. Там же забираем kotlin-stdlib ПКМ Show in Explorer. Копируем в папку своего проекта и даем осознанное имя. Но в kotlin-stdlib.jar есть "лишний" файл kotlin-stdlib-1.5.10.jar\META-INF\versions\9\module-info.class Открываем архиватором и удаляем файл или всю папку versions Почти все готово... Но котлин еще и посыпан сахаром и не хочет Дельфей dexится, хочет -min-sdk-version=26 Поможем Delphi: Ищем CodeGear.Common.Targets, у меня он в "C:\Program Files (x86)\Embarcadero\Studio\21.0\bin"\ Ищем в нем --output, и перед ним вставим все про sdk. У меня получилось так: <DxCmd>PATH $(JDKPath)\bin;$(PATH); %26 set JAVA_HOME=$(JDKPath)%26 "$(JavaDxPath)" --dex --min-sdk-version=26 --output=</DxCmd> Далее цепляем все jar в проект Либа производителя, Либа своя обертка, и котлин Иии собираем! Если есть еще зависимости делаем аналогично: находим jar, выпиливаем META-INF\versions\9\module-info.class, линкуем в проект и собираем... Не все зависимости используются и нужны, поэтому добавляем поштучно до тех пор пока не заведется.
  5. DLIB_JNI_METHOD(jniBitmapExtractFaceGazes)(JNIEnv* env, jobject thiz, jobject bitmap, jobject gazesList)?
  6. Вангую: потом будет вопрос как понять что весь stream прилетел а не его некоторая часть...
  7. Не пробовал... может так? вместо form1.close пишем TAndroidHelper.Activity.setResult(RESULT_OK, Intent); TAndroidHelper.Activity.Finish;
  8. билять гоню... это защита от onClick MouseUp/Down имхо никак
  9. билять гоню... это защита от onClick MouseUp/Down имхо никак
  10. тогда сначала так, без проверки парента //if TOpenCustomScrollBox(Sender).ContainsObject(ICtrl.GetObject) then закоментируй иф... так понятней?: procedure TScrollBoxService.OnViewportPositionChange(Sender: TObject; const OldViewportPosition, NewViewportPosition: TPointF; const ContentSizeChanged: Boolean); var ICtrl:IControl; begin ICtrl:=TControl(Sender).Root.Captured; if not assigned(ICtrl) then begin ICtrl:=TControl(Sender).Root.Focused; if not assigned(ICtrl) then exit; end; ICtrl.MouseUp(TMouseButton.mbLeft,[],0,0); ICtrl.DoMouseLeave; end;
  11. атак? if TOpenCustomScrollBox(Sender).ContainsObject(ICtrl.GetObject) then
  12. procedure SyncProc(Proc:TProc<TLightweightEvent>); var Event:TLightweightEvent; begin Event:=TLightweightEvent.Create; try Proc(Event); Event.WaitFor(); finally Event.Free; end; end; function MessageDialogSync(const AMessage: string; const ADialogType: TMsgDlgType; const AButtons: TMsgDlgButtons; const ADefaultButton: TMsgDlgBtn; const AHelpCtx: THelpContext): TModalResult; var LocalResult: TModalResult; begin SyncProc( procedure(Event:TLightweightEvent) begin TThread.Synchronize(nil, procedure begin TDialogServiceAsync.MessageDialog(AMessage, ADialogType, AButtons, ADefaultButton, AHelpCtx, procedure(const AResult: TModalResult) begin LocalResult:=AResult; Event.SetEvent; end); end); end); result:=LocalResult; end; procedure TForm3.Button1Click(Sender: TObject); begin TThread.CreateAnonymousThread( procedure begin while not TThread.CheckTerminated do begin TThread.Sleep(1000); if MessageDialogSync('Продолжать?', TMsgDlgType.mtInformation,[TMsgDlgBtn.mbYes, TMsgDlgBtn.mbNo],TMsgDlgBtn.mbYes,0)<>idYes then TThread.CurrentThread.Terminate; end; end).Start; end; поток тормозится до исполнения диалога... диалог показывается в главном потоке
  13. type TOpenCustomScrollBox=class(TCustomScrollBox); procedure TScrollBoxService.OnViewportPositionChange(Sender: TObject; const OldViewportPosition, NewViewportPosition: TPointF; const ContentSizeChanged: Boolean); var ICtrl:IControl; begin ICtrl:=TControl(Sender).Root.Captured; if not assigned(ICtrl) then begin ICtrl:=TControl(Sender).Root.Focused; if not assigned(ICtrl) then exit; end; if TOpenCustomScrollBox(Sender).Content.ContainsObject(ICtrl.GetObject) then begin ICtrl.MouseUp(TMouseButton.mbLeft,[],0,0); ICtrl.DoMouseLeave; end; end;
  14. Собственно - это только IOS Все там есть. см iOSapi.CoreLocation.pas
  15. тогда везде тыкай {$ZEROBASEDSTRINGS OFF} глобально никак
  16. var i:integer; begin s:='hello world'; for i:=low(s) to high(s) do print(s[i]); end; s.Chars[0] и все остальное из TStringHelper всегда с нуля... но даже так огреб при расчете суммы ean13
  17. ImageToStream.Free; убери может оно гасится раньше отправки var ImageToStream : TMemoryStream; begin ImageToStream := TMemoryStream.Create; ImageToStream.LoadFromFile('Здесь находится путь к файлу'); ImageToStream.Position := 0; TetheringAppProfile1.Resources.FindByName('ImageTransfer').Value := ImageToStream; end; А вот который принимает: procedure TForm1.TetheringAppProfile1Resources3ResourceReceived(const Sender: TObject; const AResource: TRemoteResource); begin ImageViewer1.Bitmap.LoadFromStream(AResource.Value.AsStream); end;
  18. 1 рабочий поток. но диалоги через Synchronize посылаются в главный поток при этом рабочий засыпает на Event.WaitFor; диалог закрывается и дергает Event.SetEvent; у меня это тоже не как скелет, все кишки с евентами и синхронизами спрятаны, 1-3 скроки показать диалог... остальное бизнес логика
  19. Так себе, отключать кеш... можно разово при запуске {$IFDEF ANDROID} var NativeBrowser:JWebBrowser; if Supports(WebBrowser,JWebBrowser,NativeBrowser) then NativeBrowser.clearCache(true); {$ENDIF ANDROID}
  20. Я пробовал полезную нагрузку сунуть в поток а гуй через sync и с ожиданием Event как то так (псевдокод) : TThread.CreateAnonThread( begin Event:=TEvent.Create; try DoStep1; Event.Reset; TThread.Sync( begin ShowMessageAsync('Ахтунг!' begin Event.SetEvent; end) end); Event.WaitFor; DoStep2;.... fin Event.Free; end; end)
  21. Да весь FMX на интерфейсах и QueryInterface... FireDAC так вообще страшный сон все на QueryInterface, на фабриках фабрик. а Модель COM - построена на одном интерфейсе - IDispatch, все!
  22. VCLComObject все таки завязан только названием! Остальное завязано только на QueryInterface, а оно нативно и мультиплатформенно
  23. Пример в атаче, там же патченый FMX.Controls.Presentation VCLComObject.zip
×
×
  • Создать...