اشتراکها
اشتراکها
کتابخانه DataMaps
لینک مورد نظر با ارور 404 را نمایش میدهد
در برگه نمایش داده شده من Response نداره.
نظرات مطالب
OpenCVSharp #5
بازخوردهای پروژهها
نمایش جمع کل فقط در آخرین صفحه
چگونه میتوان نمایش جمع کل را فقط بر روی آخرین صفحه تنظیم کرد؟
پیشاپیش از شما دعوت میکنم اگر از سایر روشهای توسعه برنامههای موبایل چون Flutter ،React native و ... استفاده میکنید نیز این مقاله را مطالعه کنید؛ چرا که ایده کلی و نکات مهم آن میتواند برای شما نیز مفید باشد.
زمانیکه شما از طراح، کاری را میگیرید و فرضا میخواهید در صفحهای از برنامه موبایل، یک لیوان را نمایش دهید، به شما یک فایل png یا svg تحویل داده میشود. اگر چه عموما روشهایی وجود دارند تا همان فایل را به صورت مستقیم در صفحه برنامه خود استفاده کنید، ولی این کار به چند دلیل توصیه نمیشود:
۱- دستگاههای مختلف، Resolutionهای متفاوتی دارند و سختافزار بعضا ضعیف موبایل، باید عکس را برای نمایش بهینه، Scale کند که عملی است هدر دهنده پردازنده و حافظه.
۲- حتی وقتی عمل Scale انجام شد، وقتی صفحه مربوطه بسته شود و به صفحه دیگری برویم، در باز کردن دوباره صفحه مربوطه، این عمل هزینه بر مجددا رخ میدهد.
برای حل این مشکل، میتوان دو قدم برداشت:
قدم اول اینکه عکس svg و یا png آن لیوان را در Scaleهای مختلف، از پیش ذخیره کرد. این کار خود دو اشکال دارد. یک اینکه اگر این عمل به صورت دستی انجام شود، احتمال اشتباه بالا میرود و انجام این کار برای Android/iOS/Windows و برای Scaleهای مختلف، برای هر عکس، نیاز به ذخیره لااقل یک دو جین عکس دارد. دوم اینکه با ذخیرهسازی چند باره یک عکس در Scaleهای مختلف، حجم فایل نهایی پروژه بالا میرود.
برای خودکاری سازی این فرآیند دستی، در Xamarin Forms، React native و ... ابزارهایی تعبیه شده است که ResizetizerNT نمونه Xamarin Forms آن است که یک عکس svg یا png را از شما گرفته و در Scaleهای مختلف، برای Android/iOS/Windows ذخیره میکند و طبیعتا احتمال اشتباه کم میشود و کار بسیار ساده میشود.
برای حل مشکل سایز خروجی نهایی، در Android و Google Play Store فرمت جدیدی جایگزین apk شده است به نام aab یا Android App Bundle که با توجه به Resolution دستگاهی که در حال دانلود برنامه است، فایلی را برای وی ساخته و میفرستد که فقط عکسهای با Scale مناسب در آن است؛ پس میتوانیم لااقل در Android نگران حجم نباشیم.
البته تاثیر اینکار در Performance آنچنان بالاست که بهتر است برای Storeهای متفرقه که از aab پشتیبانی نمیکنند و کماکان فقط از apk پشتیبانی میکنند نیز کماکان عکس در Scaleهای مختلف ذخیره شود.
در iOS نیز ابزار pngcrunch وجود دارد که عکسهای png را بهینه و compress میکند و در کاهش حجم فایل نهایی مؤثر است. در Xamarin.iOS در قسمت تنظیمات پروژه، در قسمت iOS Build، زدن تیک Checkbox مربوطه با نام Optimize PNG images به معنای درخواست استفاده از این ابزار مفید است.
با این حال، حتی اگر عکسها در Scaleهای مختلفی ذخیره شوند، مرحلهای وجود دارد که آن png، به bitmap قابل نمایش تبدیل میشود. این عمل نیز هزینهبر بوده و زمانیکه شما صفحه ای را بسته و مجددا باز میکنید نیز این عمل تکرار میشود. همچنین اگر در یک List view پنج آیتم را داشته باشید که یک عکس را دارند، این عمل پنج بار تکرار میشود.
در Android ابزاری معرفی شدهاست که Glide نام دارد و این ابزار، مرحله تبدیل png به bitmap قابل نمایش را cache میکند و دیگر باز و بسته کردن صفحات، یا استفاده از یک عکس در List view، اشکالی را ایجاد نمیکند. در Xamarin Forms با استفاده از GlideX.Forms، میتوانید کاری کنید که در Android این بهینه سازی بسیار مؤثر صورت پذیرد و به Scroll نرم در List view و باز شدن سریع صفحات برسید. در iOS معادل همین کار را کتابخانه مطرح Nuke انجام میدهد که برای استفاده از آن در Xamarin Forms میتوانید از این Package استفاده کنید.
مزیت دیگر استفاده از GlideX.Forms و Nuke در این است که اگر جایی از برنامه، عکسهایی را از سرور دریافت و نمایش دهید (مثلا عکس مشتریها در لیست مشتریان)، این دو ابزار عکس مربوطه را پس از Scale شدن و تبدیل شدن به Bitmap برای استفادههای بعدی Cache میکنند و سری بعد که نیاز به نمایش همان عکس میشود، به جای Scale شدن مجدد و تبدیل شدن به Bitmap دوباره، فقط از Cache محتوای آماده به نمایش به کاربر نمایش داده میشود.
در نهایت شما با چند خط تنظیمات ساده و نصب کردن چند package میتوانید با داشتن یک svg یا png، آنرا به بهینهترین شکل ممکن در Android/iOS/Windows نمایش دهید.
این پروژه در Github تمامی این موارد را در کنار هم گردآوری کردهاست که میتوانید از سورس آن نیز برای درک بهتر موارد استفاده کنید.
اشتراکها
انواع Target Framework ها در NET 5.
We'll have the following TFMs:
TFM | Compatible With | Comments |
---|---|---|
net5.0 | net1..4 (with NU1701 warning) | No WinForms or WPF |
| netcoreapp1..3.1 (warning when WinForms/WPF is referenced) | |
| netstandard1..2.1 | |
net5.0-android | xamarin.android | |
| (+everything else inherited from net5.0) | |
net5.0-ios | xamarin.ios | |
| (+everything else inherited from net5.0) | |
net5.0-macos | xamarin.mac | |
| (+everything else inherited from net5.0) | |
net5.0-tvos | xamarin.tvos | |
| (+everything else inherited from net5.0) | |
net5.0-watchos | xamarin.watchos | |
| (+everything else inherited from net5.0) | |
net5.0-windows | netcoreapp1..3.1 | WinForms + WPF |
| (+everything else inherited from net5.0) | |
Tizen, Unity... | Will follow the Xamarin model | |
وین فرمز در دنیای WPF در حد فقط یکی از حالتهای طرح بندی آن به نام Canvas است (چندین سیستم طرح بندی دارد ...). Silverlight هم برادر کوچکتر WPF محسوب میشود. بنابراین اگر موردی را بتوان با winforms پیاده سازی کرد و با WPF و Silverlight خیر، بشنوید اما باور نکنید. صد البته Silverlight محدود است به sandbox مرورگر و دسترسی امنیتی آن در این حد است اما قابلیت اجرای خارج از مرورگر با سطح دسترسی بالاتر (پس از تائید کاربر را هم دارد). دسترسی کاملی به WCF دارد و همچنین نسخهی 4 آن قابلیت تعامل با اشیاء COM را هم دارد (این کنترل پنلهای مدیریتی تحت وب از همین دو مورد اخیر ناشی میشوند + قابلیتهای پاور شل جدید ویندوز سرور که دسترسی از راه دور را سادهتر کرده).
علت استفاده اصلی از سیلورلایت هم پایین آوردن زمان، هزینه و همچنین سادگی توسعه است. (به این موارد در مقالهای که آدرس دادم اشاره شده ...)
ضمنا تکلیف MVC مشخص است (حداقل بعد از سه نگارش آن). نسخهی بعدی Winforms هم تاجایی که عنوان شده قرار است چندین قابلیت MVC مانند Model binders و validation آنرا به ارث ببرد.
پ.ن.
بین ماکرو و میکرو تفاوت از زمین تا آسمان است.
علت استفاده اصلی از سیلورلایت هم پایین آوردن زمان، هزینه و همچنین سادگی توسعه است. (به این موارد در مقالهای که آدرس دادم اشاره شده ...)
ضمنا تکلیف MVC مشخص است (حداقل بعد از سه نگارش آن). نسخهی بعدی Winforms هم تاجایی که عنوان شده قرار است چندین قابلیت MVC مانند Model binders و validation آنرا به ارث ببرد.
پ.ن.
بین ماکرو و میکرو تفاوت از زمین تا آسمان است.