বৈশিষ্ট্য এবং APIs ওভারভিউ

অ্যান্ড্রয়েড 15 ডেভেলপারদের জন্য দুর্দান্ত বৈশিষ্ট্য এবং এপিআই প্রবর্তন করে। নিম্নলিখিত বিভাগগুলি আপনাকে সম্পর্কিত APIগুলির সাথে শুরু করতে সহায়তা করার জন্য এই বৈশিষ্ট্যগুলিকে সংক্ষিপ্ত করে৷

যোগ করা, পরিবর্তিত এবং সরানো API-এর বিস্তারিত তালিকার জন্য, API ডিফ রিপোর্ট পড়ুন। যোগ করা এপিআই সম্পর্কে বিশদ বিবরণের জন্য অ্যান্ড্রয়েড এপিআই রেফারেন্সে যান — অ্যান্ড্রয়েড 15-এর জন্য, এপিআই লেভেল 35-এ যুক্ত করা হয়েছে এমন APIগুলি দেখুন। প্ল্যাটফর্মের পরিবর্তনগুলি আপনার অ্যাপগুলিকে প্রভাবিত করতে পারে এমন অঞ্চলগুলি সম্পর্কে জানতে, অ্যাপগুলির জন্য Android 15 আচরণের পরিবর্তনগুলি পরীক্ষা করতে ভুলবেন না। লক্ষ্য Android 15 এবং সমস্ত অ্যাপের জন্য

ক্যামেরা এবং মিডিয়া

Android 15-এ বিভিন্ন ধরনের বৈশিষ্ট্য রয়েছে যা ক্যামেরা এবং মিডিয়ার অভিজ্ঞতাকে উন্নত করে এবং যেগুলি আপনাকে Android-এ তাদের দৃষ্টিভঙ্গি বাস্তবায়িত করতে নির্মাতাদের সহায়তা করার জন্য টুল এবং হার্ডওয়্যার অ্যাক্সেস দেয়।

অ্যান্ড্রয়েড মিডিয়া এবং ক্যামেরার জন্য সর্বশেষ বৈশিষ্ট্য এবং বিকাশকারী সমাধান সম্পর্কে আরও জানতে, Google I/O থেকে বিল্ডিং আধুনিক অ্যান্ড্রয়েড মিডিয়া এবং ক্যামেরা অভিজ্ঞতা টক দেখুন৷

কম আলো বুস্ট

অ্যান্ড্রয়েড 15 লো লাইট বুস্ট প্রবর্তন করেছে, একটি অটো-এক্সপোজার মোড ক্যামেরা 2 এবং নাইট মোড ক্যামেরা এক্সটেনশন উভয়ের জন্য উপলব্ধ। লো লাইট বুস্ট কম আলোর অবস্থায় প্রিভিউ স্ট্রিমের এক্সপোজার সামঞ্জস্য করে। নাইট মোড ক্যামেরা এক্সটেনশন যেভাবে স্থির চিত্র তৈরি করে তার থেকে এটি আলাদা, কারণ নাইট মোড একটি একক, উন্নত চিত্র তৈরি করতে ফটোগুলির একটি বিস্ফোরণকে একত্রিত করে। যদিও নাইট মোড একটি স্থির চিত্র তৈরি করার জন্য খুব ভাল কাজ করে, এটি একটি ক্রমাগত ফ্রেম তৈরি করতে পারে না, তবে লো লাইট বুস্ট করতে পারে। সুতরাং, লো লাইট বুস্ট ক্যামেরার ক্ষমতা সক্ষম করে, যেমন:

  • একটি উন্নত ইমেজ প্রিভিউ প্রদান করা, যাতে ব্যবহারকারীরা তাদের কম-আলোতে ছবি ফ্রেম করতে পারে
  • কম আলোতে QR কোড স্ক্যান করা হচ্ছে

আপনি যদি লো লাইট বুস্ট সক্ষম করেন, কম আলোর স্তর থাকলে এটি স্বয়ংক্রিয়ভাবে চালু হয় এবং যখন বেশি আলো থাকে তখন বন্ধ হয়ে যায়।

অ্যাপ্লিকেশানগুলি একটি উজ্জ্বল ভিডিও সংরক্ষণ করতে কম আলোতে প্রিভিউ স্ট্রিম রেকর্ড করতে পারে৷

আরও তথ্যের জন্য, লো লাইট বুস্ট দেখুন।

ইন-অ্যাপ ক্যামেরা নিয়ন্ত্রণ

অ্যান্ড্রয়েড 15 সমর্থিত ডিভাইসগুলিতে ক্যামেরা হার্ডওয়্যার এবং এর অ্যালগরিদমগুলির উপর আরও নিয়ন্ত্রণের জন্য একটি এক্সটেনশন যুক্ত করে:

  • উন্নত ফ্ল্যাশ শক্তি সমন্বয় ইমেজ ক্যাপচার করার সময় SINGLE এবং TORCH উভয় মোডে ফ্ল্যাশ তীব্রতার সুনির্দিষ্ট নিয়ন্ত্রণ সক্ষম করে।

এইচডিআর হেডরুম নিয়ন্ত্রণ

Android 15 HDR হেডরুম বেছে নেয় যা অন্তর্নিহিত ডিভাইসের ক্ষমতা এবং প্যানেলের বিট-গভীরতার জন্য উপযুক্ত। যে পৃষ্ঠাগুলিতে প্রচুর SDR সামগ্রী রয়েছে, যেমন একটি মেসেজিং অ্যাপ একটি একক HDR থাম্বনেল প্রদর্শন করে, এই আচরণটি SDR সামগ্রীর অনুভূত উজ্জ্বলতাকে বিরূপভাবে প্রভাবিত করতে পারে৷ Android 15 আপনাকে SDR এবং HDR সামগ্রীর মধ্যে ভারসাম্য বজায় রাখতে setDesiredHdrHeadroom সহ HDR হেডরুম নিয়ন্ত্রণ করতে দেয়।

বাম স্ক্রিনে SDR UI উপাদানগুলির উজ্জ্বলতা ডান স্ক্রিনের উজ্জ্বলতার চেয়ে বেশি অভিন্ন বলে মনে হচ্ছে, যা HDR এবং SDR বিষয়বস্তু মিশ্রিত হলে সম্ভাব্য হেডরুম সমস্যাগুলিকে অনুকরণ করে৷ HDR হেডরুম সামঞ্জস্য করে, আপনি SDR এবং HDR সামগ্রীর মধ্যে একটি ভাল ভারসাম্য অর্জন করতে পারেন।

উচ্চস্বরে নিয়ন্ত্রণ

অ্যান্ড্রয়েড 15 CTA-2075 লাউডনেস স্ট্যান্ডার্ডের জন্য সমর্থন প্রবর্তন করে যাতে আপনি অডিও লাউডনেস অসঙ্গতিগুলি এড়াতে এবং কনটেন্টের মধ্যে পরিবর্তন করার সময় ব্যবহারকারীদের ক্রমাগত ভলিউম সামঞ্জস্য করতে না হয় তা নিশ্চিত করতে সহায়তা করে। সিস্টেমটি আউটপুট ডিভাইসের (হেডফোন এবং স্পিকার) পরিচিত বৈশিষ্ট্যগুলির সাথে AAC অডিও সামগ্রীতে উপলব্ধ লাউডনেস মেটাডেটা সহ অডিও লাউডনেস এবং ডাইনামিক রেঞ্জ কম্প্রেশন স্তরগুলিকে বুদ্ধিমত্তার সাথে সামঞ্জস্য করে।

এই বৈশিষ্ট্যটি সক্ষম করতে, আপনাকে আপনার AAC সামগ্রীতে লাউডনেস মেটাডেটা উপলব্ধ রয়েছে তা নিশ্চিত করতে হবে এবং আপনার অ্যাপে প্ল্যাটফর্ম বৈশিষ্ট্যটি সক্ষম করতে হবে। এর জন্য, আপনি একটি LoudnessCodecController অবজেক্টের সাথে যুক্ত AudioTrack থেকে অডিও সেশন আইডি সহ এটির তৈরি ফ্যাক্টরি পদ্ধতিতে কল করে ইনস্ট্যান্টিশিয়েট করেন; এটি স্বয়ংক্রিয়ভাবে অডিও আপডেট প্রয়োগ করা শুরু করে। আপনি একটি OnLoudnessCodecUpdateListener পাস করতে পারেন MediaCodec এ প্রয়োগ করার আগে লাউডনেস প্যারামিটারগুলি সংশোধন বা ফিল্টার করতে।

// Media contains metadata of type MPEG_4 OR MPEG_D
val mediaCodec = 
val audioTrack = AudioTrack.Builder()
                                .setSessionId(sessionId)
                                .build()
...
// Create new loudness controller that applies the parameters to the MediaCodec
try {
   val lcController = LoudnessCodecController.create(mSessionId)
   // Starts applying audio updates for each added MediaCodec
}

একটি নির্বিঘ্ন অ্যাপ ইন্টিগ্রেশনের জন্য LoudnessCodecController API ব্যবহার করার জন্য AndroidX media3 ExoPlayerও আপডেট করা হবে।

ভার্চুয়াল MIDI 2.0 ডিভাইস

Android 13 ইউএসবি ব্যবহার করে MIDI 2.0 ডিভাইসে সংযোগ করার জন্য সমর্থন যোগ করেছে, যা ইউনিভার্সাল MIDI প্যাকেট (UMP) ব্যবহার করে যোগাযোগ করে। Android 15 ভার্চুয়াল MIDI অ্যাপগুলিতে UMP সমর্থন প্রসারিত করে, কম্পোজিশন অ্যাপগুলিকে একটি ভার্চুয়াল MIDI 2.0 ডিভাইস হিসাবে সিন্থেসাইজার অ্যাপগুলিকে নিয়ন্ত্রণ করতে সক্ষম করে ঠিক যেমন তারা একটি USB MIDI 2.0 ডিভাইসের সাথে করে।

আরও দক্ষ AV1 সফ্টওয়্যার ডিকোডিং

dav1d লোগো

dav1d , VideoLAN-এর জনপ্রিয় AV1 সফ্টওয়্যার ডিকোডার Android ডিভাইসগুলির জন্য উপলব্ধ যা হার্ডওয়্যারে AV1 ডিকোড সমর্থন করে না। dav1d লিগ্যাসি AV1 সফ্টওয়্যার ডিকোডারের চেয়ে 3 গুণ বেশি পারফরম্যান্ট, কিছু নিম্ন এবং মধ্য স্তরের ডিভাইস সহ আরও ব্যবহারকারীদের জন্য HD AV1 প্লেব্যাক সক্ষম করে৷

আপনার অ্যাপটিকে "c2.android.av1-dav1d.decoder" নামে ডাকার মাধ্যমে dav1d ব্যবহার করতে অপ্ট-ইন করতে হবে। পরবর্তী আপডেটে dav1d কে ডিফল্ট AV1 সফ্টওয়্যার ডিকোডার করা হবে। এই সমর্থনটি প্রমিত এবং Android 11 ডিভাইসগুলিতে ব্যাকপোর্ট করা হয়েছে যা Google Play সিস্টেম আপডেটগুলি গ্রহণ করে।

বিকাশকারীর উত্পাদনশীলতা এবং সরঞ্জাম

অ্যান্ড্রয়েড স্টুডিও , জেটপ্যাক কম্পোজ এবং অ্যান্ড্রয়েড জেটপ্যাক লাইব্রেরির মতো টুলগুলির আশেপাশে আপনার উত্পাদনশীলতা কেন্দ্রগুলিকে উন্নত করার জন্য আমাদের বেশিরভাগ কাজ করার সময়, আমরা সর্বদা প্ল্যাটফর্মে উপায়গুলি সন্ধান করি যাতে আপনাকে আরও সহজে আপনার দৃষ্টিভঙ্গি উপলব্ধি করতে সহায়তা করে৷

OpenJDK 17 আপডেট

Android 15 সর্বশেষ OpenJDK LTS রিলিজের বৈশিষ্ট্যগুলির সাথে সারিবদ্ধ করার জন্য Android এর মূল লাইব্রেরিগুলিকে রিফ্রেশ করার কাজ চালিয়ে যাচ্ছে।

নিম্নলিখিত মূল বৈশিষ্ট্য এবং উন্নতি অন্তর্ভুক্ত করা হয়েছে:

এই APIগুলি Google Play সিস্টেম আপডেটের মাধ্যমে Android 12 (API স্তর 31) এবং উচ্চতর চলমান এক বিলিয়নেরও বেশি ডিভাইসে আপডেট করা হয়, যাতে আপনি সর্বশেষ প্রোগ্রামিং বৈশিষ্ট্যগুলি লক্ষ্য করতে পারেন৷

PDF উন্নতি

Android 15-এ PdfRenderer API-এর উল্লেখযোগ্য উন্নতি রয়েছে। অ্যাপগুলি পাসওয়ার্ড-সুরক্ষিত ফাইল রেন্ডারিং, টীকা, ফর্ম সম্পাদনা , অনুসন্ধান এবং অনুলিপি সহ নির্বাচনের মতো উন্নত বৈশিষ্ট্যগুলিকে অন্তর্ভুক্ত করতে পারে৷ লিনিয়ারাইজড পিডিএফ অপ্টিমাইজেশানগুলি স্থানীয় পিডিএফ দেখার গতি এবং সম্পদের ব্যবহার কমাতে সমর্থিত। জেটপ্যাক পিডিএফ লাইব্রেরি আপনার অ্যাপে পিডিএফ দেখার ক্ষমতা যোগ করা সহজ করতে এই APIগুলি ব্যবহার করে।

পিডিএফ রেন্ডারিংয়ের সর্বশেষ আপডেটগুলির মধ্যে একটি এমবেডেড পিডিএফ ফাইল অনুসন্ধান করার মতো বৈশিষ্ট্যগুলি অন্তর্ভুক্ত রয়েছে।

PdfRenderer একটি মডিউলে সরানো হয়েছে যা প্ল্যাটফর্ম রিলিজ ছাড়া Google Play সিস্টেম আপডেটগুলি ব্যবহার করে আপডেট করা যেতে পারে, এবং আমরা এই পরিবর্তনগুলিকে Android 11 (API স্তর 30)-এ একটি সামঞ্জস্যপূর্ণ প্রি-Android 15 সংস্করণ তৈরি করে সমর্থন করছি। API পৃষ্ঠ, PdfRendererPreV নামে পরিচিত।

,

Android 15-এ PdfRenderer API-এর উল্লেখযোগ্য উন্নতি রয়েছে। অ্যাপগুলি পাসওয়ার্ড-সুরক্ষিত ফাইল রেন্ডারিং, টীকা, ফর্ম সম্পাদনা , অনুসন্ধান এবং অনুলিপি সহ নির্বাচনের মতো উন্নত বৈশিষ্ট্যগুলিকে অন্তর্ভুক্ত করতে পারে৷ লিনিয়ারাইজড পিডিএফ অপ্টিমাইজেশানগুলি স্থানীয় পিডিএফ দেখার গতি এবং সম্পদের ব্যবহার কমাতে সমর্থিত। জেটপ্যাক পিডিএফ লাইব্রেরি আপনার অ্যাপে পিডিএফ দেখার ক্ষমতা যোগ করা সহজ করতে এই APIগুলি ব্যবহার করে।

পিডিএফ রেন্ডারিংয়ের সর্বশেষ আপডেটগুলির মধ্যে একটি এমবেডেড পিডিএফ ফাইল অনুসন্ধান করার মতো বৈশিষ্ট্যগুলি অন্তর্ভুক্ত রয়েছে।

PdfRenderer একটি মডিউলে সরানো হয়েছে যা প্ল্যাটফর্ম রিলিজ ছাড়া Google Play সিস্টেম আপডেটগুলি ব্যবহার করে আপডেট করা যেতে পারে, এবং আমরা এই পরিবর্তনগুলিকে Android 11 (API স্তর 30)-এ একটি সামঞ্জস্যপূর্ণ প্রি-Android 15 সংস্করণ তৈরি করে সমর্থন করছি। API পৃষ্ঠ, PdfRendererPreV নামে পরিচিত।

,

Android 15-এ PdfRenderer API-এর উল্লেখযোগ্য উন্নতি রয়েছে। অ্যাপগুলি পাসওয়ার্ড-সুরক্ষিত ফাইল রেন্ডারিং, টীকা, ফর্ম সম্পাদনা , অনুসন্ধান এবং অনুলিপি সহ নির্বাচনের মতো উন্নত বৈশিষ্ট্যগুলিকে অন্তর্ভুক্ত করতে পারে৷ লিনিয়ারাইজড পিডিএফ অপ্টিমাইজেশানগুলি স্থানীয় পিডিএফ দেখার গতি এবং সম্পদের ব্যবহার কমাতে সমর্থিত। জেটপ্যাক পিডিএফ লাইব্রেরি আপনার অ্যাপে পিডিএফ দেখার ক্ষমতা যোগ করা সহজ করতে এই APIগুলি ব্যবহার করে।

পিডিএফ রেন্ডারিংয়ের সর্বশেষ আপডেটগুলির মধ্যে একটি এমবেডেড পিডিএফ ফাইল অনুসন্ধান করার মতো বৈশিষ্ট্যগুলি অন্তর্ভুক্ত রয়েছে।

PdfRenderer একটি মডিউলে সরানো হয়েছে যা প্ল্যাটফর্ম রিলিজ ছাড়া Google Play সিস্টেম আপডেটগুলি ব্যবহার করে আপডেট করা যেতে পারে, এবং আমরা এই পরিবর্তনগুলিকে Android 11 (API স্তর 30)-এ একটি সামঞ্জস্যপূর্ণ প্রি-Android 15 সংস্করণ তৈরি করে সমর্থন করছি। API পৃষ্ঠ, PdfRendererPreV নামে পরিচিত।

স্বয়ংক্রিয় ভাষা পরিবর্তন পরিমার্জন

Android 14 added on-device, multi-language recognition in audio with automatic switching between languages, but this can cause words to get dropped, especially when languages switch with less of a pause between the two utterances. Android 15 adds additional controls to help apps tune this switching to their use case. EXTRA_LANGUAGE_SWITCH_INITIAL_ACTIVE_DURATION_TIME_MILLIS confines the automatic switching to the beginning of the audio session, while EXTRA_LANGUAGE_SWITCH_MATCH_SWITCHES deactivates the language switching after a defined number of switches. These options are particularly useful if you expect that there will be a single language spoken during the session that should be autodetected.

উন্নত OpenType ভেরিয়েবল ফন্ট API

Android 15 OpenType ভেরিয়েবল ফন্টের ব্যবহারযোগ্যতা উন্নত করে। আপনি buildVariableFamily API এর সাথে ওজন অক্ষ উল্লেখ না করে একটি পরিবর্তনশীল ফন্ট থেকে একটি FontFamily উদাহরণ তৈরি করতে পারেন। টেক্সট রেন্ডারার প্রদর্শন করা টেক্সট মেলে wght অক্ষের মান ওভাররাইড করে।

এপিআই ব্যবহার করে একটি Typeface তৈরির জন্য কোডটিকে যথেষ্ট সরল করে:

কোটলিন

val newTypeface = Typeface.CustomFallbackBuilder(
            FontFamily.Builder(
                Font.Builder(assets, "RobotoFlex.ttf").build())
                    .buildVariableFamily())
    .build()

জাভা

Typeface newTypeface = Typeface.CustomFallbackBuilder(
            new FontFamily.Builder(
                new Font.Builder(assets, "RobotoFlex.ttf").build())
                    .buildVariableFamily())
    .build();

পূর্বে, একই Typeface তৈরি করতে, আপনার আরও অনেক কোডের প্রয়োজন হবে:

কোটলিন

val oldTypeface = Typeface.CustomFallbackBuilder(
            FontFamily.Builder(
                Font.Builder(assets, "RobotoFlex.ttf")
                    .setFontVariationSettings("'wght' 400")
                    .setWeight(400)
                    .build())
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 100")
                        .setWeight(100)
                        .build()
                )
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 200")
                        .setWeight(200)
                        .build()
                )
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 300")
                        .setWeight(300)
                        .build()
                )
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 500")
                        .setWeight(500)
                        .build()
                )
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 600")
                        .setWeight(600)
                        .build()
                )
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 700")
                        .setWeight(700)
                        .build()
                )
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 800")
                        .setWeight(800)
                        .build()
                )
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 900")
                        .setWeight(900)
                        .build()
                ).build()
        ).build()

জাভা

Typeface oldTypeface = new Typeface.CustomFallbackBuilder(
    new FontFamily.Builder(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 400")
            .setWeight(400)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 100")
            .setWeight(100)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 200")
            .setWeight(200)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 300")
            .setWeight(300)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 500")
            .setWeight(500)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 600")
            .setWeight(600)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 700")
            .setWeight(700)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 800")
            .setWeight(800)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 900")
            .setWeight(900)
            .build()
    )
    .build()
).build();

পুরানো এবং নতুন উভয় API এর সাথে কীভাবে একটি Typeface তৈরি হয় তার একটি উদাহরণ এখানে দেওয়া হল:

নতুন এবং পুরানো API ব্যবহার করে টাইপফেস রেন্ডারিং কীভাবে আলাদা তার একটি উদাহরণ

এই উদাহরণে, পুরানো API দিয়ে তৈরি করা Typeface 350, 450, 550 এবং 650 Font উদাহরণগুলির জন্য সঠিক ফন্টের ওজন তৈরি করার ক্ষমতা রাখে না, তাই রেন্ডারার সবচেয়ে কাছের ওজনে ফিরে আসে। সুতরাং এই ক্ষেত্রে, 350 এর পরিবর্তে 300 রেন্ডার করা হয়, 450 এর পরিবর্তে 400 রেন্ডার করা হয়, ইত্যাদি। বিপরীতে, নতুন এপিআইগুলির সাথে তৈরি Typeface গতিশীলভাবে একটি প্রদত্ত ওজনের জন্য একটি Font উদাহরণ তৈরি করে, তাই সঠিক ওজন 350, 450, 550 এবং 650 এর জন্যও রেন্ডার করা হয়।

দানাদার লাইন বিরতি নিয়ন্ত্রণ

অ্যান্ড্রয়েড 15 থেকে শুরু করে, পাঠযোগ্যতা উন্নত করতে একটি TextView এবং অন্তর্নিহিত লাইন ব্রেকার একই লাইনে পাঠ্যের প্রদত্ত অংশ সংরক্ষণ করতে পারে। আপনি স্ট্রিং রিসোর্সে <nobreak> ট্যাগ ব্যবহার করে অথবা createNoBreakSpan এই লাইন ব্রেক কাস্টমাইজেশনের সুবিধা নিতে পারেন। একইভাবে, আপনি <nohyphen> ট্যাগ বা createNoHyphenationSpan ব্যবহার করে হাইফেনেশন থেকে শব্দ সংরক্ষণ করতে পারেন।

উদাহরণ স্বরূপ, নিম্নলিখিত স্ট্রিং রিসোর্সে লাইন ব্রেক নেই এবং "Pixel 8 Pro" লেখার সাথে রেন্ডার করা হয়। একটি অবাঞ্ছিত জায়গায় ভাঙ্গা:

<resources>
    <string name="pixel8pro">The power and brains behind Pixel 8 Pro.</string>
</resources>

বিপরীতে, এই স্ট্রিং রিসোর্সটিতে <nobreak> ট্যাগ অন্তর্ভুক্ত রয়েছে, যা "Pixel 8 Pro" শব্দটিকে মোড়ানো। এবং লাইন ব্রেক প্রতিরোধ করে:

<resources>
    <string name="pixel8pro">The power and brains behind <nobreak>Pixel 8 Pro.</nobreak></string>
</resources>

এই স্ট্রিংগুলি কীভাবে রেন্ডার করা হয় তার পার্থক্য নিম্নলিখিত চিত্রগুলিতে দেখানো হয়েছে:

টেক্সটের একটি লাইনের জন্য লেআউট যেখানে "Pixel 8 Pro।" একটি <nobreak> ট্যাগ ব্যবহার করে মোড়ানো হয় না।
টেক্সটের একই লাইনের জন্য লেআউট যেখানে "Pixel 8 Pro" বাক্যাংশ আছে। একটি <nobreak> ট্যাগ ব্যবহার করে মোড়ানো হয়।

অ্যাপ সংরক্ষণাগার

Android and Google Play announced support for app archiving last year, allowing users to free up space by partially removing infrequently used apps from the device that were published using Android App Bundle on Google Play. Android 15 includes OS level support for app archiving and unarchiving, making it easier for all app stores to implement it.

Apps with the REQUEST_DELETE_PACKAGES permission can call the PackageInstaller requestArchive method to request archiving an installed app package, which removes the APK and any cached files, but persists user data. Archived apps are returned as displayable apps through the LauncherApps APIs; users will see a UI treatment to highlight that those apps are archived. If a user taps on an archived app, the responsible installer will get a request to unarchive it, and the restoration process can be monitored by the ACTION_PACKAGE_ADDED broadcast.

বিকাশকারী বিকল্পগুলি ব্যবহার করে একটি ডিভাইসে 16 KB মোড সক্ষম করুন৷

একটি ডিভাইসকে 16 KB মোডে বুট করতে 16KB পৃষ্ঠা আকারের বিকাশকারী বিকল্পের সাথে বুটটি টগল করুন।

Android 15 QPR1 দিয়ে শুরু করে, আপনি ডিভাইসটিকে 16 KB মোডে বুট করতে এবং ডিভাইসে পরীক্ষা করার জন্য নির্দিষ্ট ডিভাইসে উপলব্ধ ডেভেলপার বিকল্পটি ব্যবহার করতে পারেন।

এই বিকাশকারী বিকল্পটি নিম্নলিখিত ডিভাইসগুলিতে উপলব্ধ:

  • Pixel 8 এবং 8 Pro (Android 15 QPR1 বিটা 1 বা উচ্চতর সহ)
  • Pixel 8a (Android 15 QPR1 বিটা 2 বা উচ্চতর সহ)

গ্রাফিক্স

Android 15 ক্যানভাস গ্রাফিক্স সিস্টেমে ANGLE এবং সংযোজন সহ সাম্প্রতিক গ্রাফিক্স উন্নতি নিয়ে আসে।

অ্যান্ড্রয়েডের জিপিইউ অ্যাক্সেসের আধুনিকীকরণ

ভলকান লোগো

অ্যান্ড্রয়েড হার্ডওয়্যার প্রাথমিক দিনগুলি থেকে বেশ কিছুটা বিবর্তিত হয়েছে যেখানে মূল ওএস একটি একক সিপিইউতে চলবে এবং ফিক্সড-ফাংশন পাইপলাইনগুলির উপর ভিত্তি করে এপিআই ব্যবহার করে জিপিইউগুলি অ্যাক্সেস করা হয়েছিল। Vulkan® গ্রাফিক্স API NDK- এ Android 7.0 (API স্তর 24) থেকে একটি নিম্ন-স্তরের বিমূর্ততা সহ উপলব্ধ রয়েছে যা আধুনিক GPU হার্ডওয়্যারকে আরও ভালভাবে প্রতিফলিত করে, একাধিক CPU কোরকে সমর্থন করার জন্য আরও ভাল স্কেল করে এবং কম CPU ড্রাইভার ওভারহেড অফার করে — যা উন্নত করার দিকে নিয়ে যায় অ্যাপ্লিকেশন কর্মক্ষমতা। ভলকান সমস্ত আধুনিক গেম ইঞ্জিন দ্বারা সমর্থিত।

ভলকান হল জিপিইউ-তে অ্যান্ড্রয়েডের পছন্দের ইন্টারফেস। অতএব, Vulkan এর উপরে OpenGL® ES চালানোর জন্য Android 15 একটি ঐচ্ছিক স্তর হিসাবে ANGLE অন্তর্ভুক্ত করে। ANGLE-এ সরানো উন্নত সামঞ্জস্যের জন্য Android OpenGL বাস্তবায়নকে মানসম্মত করবে, এবং কিছু ক্ষেত্রে, উন্নত কর্মক্ষমতা। আপনি সেটিংস -> সিস্টেম -> বিকাশকারী বিকল্প -> পরীক্ষামূলক: Android 15 এ ANGLE সক্ষম করে বিকাশকারী বিকল্পটি সক্ষম করে ANGLE এর সাথে আপনার OpenGL ES অ্যাপের স্থায়িত্ব এবং কার্যকারিতা পরীক্ষা করতে পারেন।

ভলকান রোডম্যাপে Android ANGLE

Android GPU API-তে আসন্ন পরিবর্তনের রোডম্যাপ।

আমাদের GPU স্ট্যাককে স্ট্রীমলাইন করার অংশ হিসাবে, সামনের দিকে আমরা আরও নতুন ডিভাইসে GL সিস্টেম ড্রাইভার হিসাবে ANGLE শিপিং করব, ভবিষ্যতের প্রত্যাশার সাথে OpenGL/ES শুধুমাত্র ANGLE এর মাধ্যমে উপলব্ধ হবে। বলা হচ্ছে, আমরা সব ডিভাইসে OpenGL ES-এর জন্য সমর্থন চালিয়ে যাওয়ার পরিকল্পনা করছি।

প্রস্তাবিত পরবর্তী পদক্ষেপ

OpenGL ES এর জন্য ANGLE ড্রাইভার নির্বাচন করতে এবং আপনার অ্যাপ পরীক্ষা করতে বিকাশকারী বিকল্পগুলি ব্যবহার করুন৷ নতুন প্রকল্পের জন্য, আমরা C/C++ এর জন্য ভলকান ব্যবহারকে দৃঢ়ভাবে উৎসাহিত করি।

ক্যানভাসের জন্য উন্নতি

Android 15 অতিরিক্ত ক্ষমতা সহ Android এর ক্যানভাস গ্রাফিক্স সিস্টেমের আমাদের আধুনিকীকরণ অব্যাহত রেখেছে:

  • Matrix44 স্থানাঙ্ক রূপান্তরের জন্য একটি 4x4 ম্যাট্রিক্স প্রদান করে যেটি ব্যবহার করা উচিত যখন আপনি 3D তে ক্যানভাসকে ম্যানিপুলেট করতে চান।
  • clipShader বর্তমান ক্লিপকে নির্দিষ্ট শেডারের সাথে ছেদ করে, যখন clipOutShader ক্লিপটিকে বর্তমান ক্লিপ এবং শেডারের পার্থক্যে সেট করে, প্রতিটি শেডারকে আলফা মাস্ক হিসাবে বিবেচনা করে। এটি জটিল আকারের অঙ্কনকে দক্ষতার সাথে সমর্থন করে।

কর্মক্ষমতা এবং ব্যাটারি

অ্যান্ড্রয়েড আপনার অ্যাপ্লিকেশানগুলির কার্যকারিতা এবং গুণমান উন্নত করতে সহায়তা করার উপর তার ফোকাস চালিয়ে যাচ্ছে৷ অ্যান্ড্রয়েড 15 এমন API গুলি প্রবর্তন করে যা আপনার অ্যাপের কাজগুলিকে কার্যকর করতে, অ্যাপের কার্যক্ষমতা অপ্টিমাইজ করতে এবং আপনার অ্যাপ সম্পর্কে অন্তর্দৃষ্টি সংগ্রহ করতে সাহায্য করে।

ব্যাটারি-দক্ষ সর্বোত্তম অনুশীলন, ডিবাগিং নেটওয়ার্ক এবং পাওয়ার ব্যবহার এবং অ্যান্ড্রয়েড 15 এবং অ্যান্ড্রয়েডের সাম্প্রতিক সংস্করণগুলিতে আমরা কীভাবে ব্যাকগ্রাউন্ড কাজের ব্যাটারির দক্ষতা উন্নত করছি তার বিশদ বিবরণের জন্য, Google I/ থেকে Android টক-এ ব্যাকগ্রাউন্ড কাজের ব্যাটারির দক্ষতার উন্নতি দেখুন ও.

ApplicationStartInfo API

অ্যান্ড্রয়েডের পূর্ববর্তী সংস্করণগুলিতে, অ্যাপ স্টার্টআপটি কিছুটা রহস্যজনক ছিল। এটি ঠান্ডা, উষ্ণ বা গরম অবস্থা থেকে শুরু হয়েছে কিনা তা আপনার অ্যাপের মধ্যে নির্ধারণ করা চ্যালেঞ্জিং ছিল। বিভিন্ন লঞ্চের পর্যায়গুলিতে আপনার অ্যাপটি কতক্ষণ ব্যয় করেছে তা জানাও কঠিন ছিল: প্রক্রিয়াটি কাঁটাচামচ করা, onCreate কল করা, প্রথম ফ্রেম আঁকা এবং আরও অনেক কিছু। যখন আপনার Application ক্লাসটি চালু করা হয়েছিল, তখন আপনার জানার কোন উপায় ছিল না যে অ্যাপটি একটি সম্প্রচার থেকে শুরু হয়েছে, একটি বিষয়বস্তু প্রদানকারী, একটি কাজ, একটি ব্যাকআপ, বুট সম্পূর্ণ হয়েছে, একটি অ্যালার্ম, বা একটি Activity

Android 15-এ ApplicationStartInfo API এই সমস্ত এবং আরও অনেক কিছু সরবরাহ করে। এমনকি আপনি এক জায়গায় টাইমিং ডেটা সংগ্রহ করতে সাহায্য করার জন্য প্রবাহে আপনার নিজস্ব টাইমস্ট্যাম্প যোগ করতেও বেছে নিতে পারেন। মেট্রিক্স সংগ্রহের পাশাপাশি, আপনি অ্যাপ স্টার্টআপকে সরাসরি অপ্টিমাইজ করতে সাহায্য করতে ApplicationStartInfo ব্যবহার করতে পারেন; উদাহরণস্বরূপ, যখন আপনার অ্যাপটি একটি সম্প্রচারের কারণে শুরু হয় তখন আপনি আপনার Application ক্লাসের মধ্যে UI-সম্পর্কিত লাইব্রেরিগুলির ব্যয়বহুল ইন্সট্যান্সটি বাদ দিতে পারেন।

বিস্তারিত অ্যাপ্লিকেশন আকার তথ্য

Android 8.0 (API স্তর 26) থেকে, Android StorageStats.getAppBytes API অন্তর্ভুক্ত করেছে যা একটি অ্যাপের ইনস্টল করা আকারকে একক সংখ্যা বাইট হিসাবে সংক্ষিপ্ত করে, যা APK আকারের সমষ্টি, APK থেকে বের করা ফাইলের আকার, এবং ফাইলগুলি যেগুলি ডিভাইসে তৈরি হয়েছিল যেমন আগ-অফ-টাইম (AOT) সংকলিত কোড। আপনার অ্যাপ কীভাবে স্টোরেজ ব্যবহার করছে তার পরিপ্রেক্ষিতে এই সংখ্যাটি খুব অন্তর্দৃষ্টিপূর্ণ নয়।

Android 15 StorageStats.getAppBytesByDataType([type]) API যোগ করে, যা আপনাকে APK ফাইল বিভাজন, AOT এবং স্পিডআপ সম্পর্কিত কোড, ডেক্স মেটাডেটা, লাইব্রেরি এবং নির্দেশিত প্রোফাইল সহ আপনার অ্যাপ কীভাবে সমস্ত স্থান ব্যবহার করছে তার অন্তর্দৃষ্টি পেতে দেয়।

অ্যাপ-পরিচালিত প্রোফাইলিং

অ্যান্ড্রয়েড 15 ProfilingManager ক্লাস অন্তর্ভুক্ত করে, যা আপনাকে আপনার অ্যাপের মধ্যে থেকে প্রোফাইলিং তথ্য সংগ্রহ করতে দেয় যেমন হিপ ডাম্প, হিপ প্রোফাইল, স্ট্যাক স্যাম্পলিং এবং আরও অনেক কিছু। এটি আউটপুট ফাইল সনাক্ত করতে একটি সরবরাহকৃত ট্যাগ সহ আপনার অ্যাপে একটি কলব্যাক প্রদান করে, যা আপনার অ্যাপের ফাইল ডিরেক্টরিতে বিতরণ করা হয়। পারফরম্যান্সের প্রভাব কমানোর জন্য API রেট সীমিত করে।

আপনার অ্যাপে প্রোফাইলিং রিকোয়েস্ট তৈরি করা সহজ করার জন্য, আমরা কোর 1.15.0-rc01 বা উচ্চতর সংস্করণে উপলব্ধ সংশ্লিষ্ট Profiling AndroidX API ব্যবহার করার পরামর্শ দিই।

SQLite ডাটাবেসের উন্নতি

অ্যান্ড্রয়েড 15 SQLite API গুলি প্রবর্তন করে যা অন্তর্নিহিত SQLite ইঞ্জিন থেকে উন্নত বৈশিষ্ট্যগুলিকে প্রকাশ করে যা নির্দিষ্ট কর্মক্ষমতা সমস্যাগুলিকে লক্ষ্য করে যা অ্যাপগুলিতে প্রকাশ করতে পারে। এই APIগুলি SQLite-এর সংস্করণ 3.44.3-এর আপডেটের সাথে অন্তর্ভুক্ত করা হয়েছে।

ডেভেলপারদের তাদের SQLite ডাটাবেস থেকে সর্বাধিক সুবিধা পেতে SQLite পারফরম্যান্সের জন্য সর্বোত্তম অনুশীলনের সাথে পরামর্শ করা উচিত, বিশেষ করে যখন বড় ডাটাবেসের সাথে কাজ করা বা যখন লেটেন্সি-সংবেদনশীল প্রশ্নগুলি চালানো হয়।

  • শুধুমাত্র-পঠন স্থগিত লেনদেন : শুধুমাত্র পঠনযোগ্য লেনদেন জারি করার সময় (লেখার বিবৃতি অন্তর্ভুক্ত করবেন না), ব্যবহার করুন beginTransactionReadOnly() এবং beginTransactionWithListenerReadOnly(SQLiteTransactionListener) শুধুমাত্র-পঠন DEFERRED লেনদেন ইস্যু করতে। এই ধরনের লেনদেনগুলি একে অপরের সাথে একযোগে চলতে পারে, এবং যদি ডাটাবেসটি WAL মোডে থাকে তবে তারা IMMEDIATE বা EXCLUSIVE লেনদেনের সাথে একযোগে চলতে পারে।
  • সারি গণনা এবং আইডি : পরিবর্তিত সারিগুলির গণনা বা শেষ সন্নিবেশিত সারি আইডি একটি অতিরিক্ত ক্যোয়ারী ইস্যু না করেই পুনরুদ্ধার করতে API যোগ করা হয়েছে৷ getLastChangedRowCount() বর্তমান লেনদেনের মধ্যে সবচেয়ে সাম্প্রতিক SQL স্টেটমেন্ট দ্বারা সন্নিবেশিত, আপডেট করা বা মুছে ফেলা সারিগুলির সংখ্যা প্রদান করে, যখন getTotalChangedRowCount() বর্তমান সংযোগের গণনা প্রদান করে। getLastInsertRowId() বর্তমান সংযোগে সন্নিবেশ করা শেষ সারির rowid প্রদান করে।
  • কাঁচা বিবৃতি : একটি কাঁচা SQlite বিবৃতি জারি করুন, সুবিধার র‍্যাপারগুলিকে বাইপাস করে এবং যেকোন অতিরিক্ত প্রসেসিং ওভারহেড যা তাদের খরচ হতে পারে।

অ্যান্ড্রয়েড ডায়নামিক পারফরম্যান্স ফ্রেমওয়ার্ক আপডেট

Android 15 continues our investment in the Android Dynamic Performance Framework (ADPF), a set of APIs that allow games and performance intensive apps to interact more directly with power and thermal systems of Android devices. On supported devices, Android 15 adds ADPF capabilities:

  • A power-efficiency mode for hint sessions to indicate that their associated threads should prefer power saving over performance, great for long-running background workloads.
  • GPU and CPU work durations can both be reported in hint sessions, allowing the system to adjust CPU and GPU frequencies together to best meet workload demands.
  • Thermal headroom thresholds to interpret possible thermal throttling status based on headroom prediction.

To learn more about how to use ADPF in your apps and games, head over to the documentation.

গোপনীয়তা

Android 15-এ বিভিন্ন বৈশিষ্ট্য রয়েছে যা অ্যাপ বিকাশকারীদের ব্যবহারকারীর গোপনীয়তা রক্ষা করতে সহায়তা করে।

স্ক্রীন রেকর্ডিং সনাক্তকরণ

অ্যান্ড্রয়েড 15 অ্যাপ্লিকেশানগুলির জন্য সমর্থন যোগ করে যাতে সনাক্ত করা যায় যে সেগুলি রেকর্ড করা হচ্ছে। যখনই অ্যাপটি একটি স্ক্রীন রেকর্ডিংয়ের মধ্যে দৃশ্যমান বা অদৃশ্য হওয়ার মধ্যে স্থানান্তরিত হয় তখন একটি কলব্যাক আহ্বান করা হয়। নিবন্ধন প্রক্রিয়ার ইউআইডির মালিকানাধীন কার্যকলাপ রেকর্ড করা হলে একটি অ্যাপ দৃশ্যমান বলে মনে করা হয়। এইভাবে, যদি আপনার অ্যাপটি একটি সংবেদনশীল অপারেশন সম্পাদন করে, আপনি ব্যবহারকারীকে জানাতে পারেন যে সেগুলি রেকর্ড করা হচ্ছে৷

val mCallback = Consumer<Int> { state ->
  if (state == SCREEN_RECORDING_STATE_VISIBLE) {
    // We're being recorded
  } else {
    // We're not being recorded
  }
}

override fun onStart() {
   super.onStart()
   val initialState =
      windowManager.addScreenRecordingCallback(mainExecutor, mCallback)
   mCallback.accept(initialState)
}

override fun onStop() {
    super.onStop()
    windowManager.removeScreenRecordingCallback(mCallback)
}

প্রসারিত IntentFilter ক্ষমতা

Android 15 builds in support for more precise Intent resolution through UriRelativeFilterGroup, which contains a set of UriRelativeFilter objects that form a set of Intent matching rules that must each be satisfied, including URL query parameters, URL fragments, and blocking or exclusion rules.

These rules can be defined in the AndroidManifest XML file with the <uri-relative-filter-group> tag, which can optionally include an android:allow tag. These tags can contain <data> tags that use existing data tag attributes as well as the android:query and android:fragment attributes.

Here's an example of the AndroidManifest syntax:

<intent-filter android:autoVerify="true">
  <action android:name="android.intent.action.VIEW" />
  <category android:name="android.intent.category.BROWSABLE" />
  <category android:name="android.intent.category.DEFAULT" />
  <data android:scheme="http" />
  <data android:scheme="https" />
  <data android:host="astore.com" />
  <uri-relative-filter-group>
    <data android:pathPrefix="/auth" />
    <data android:query="region=na" />
  </uri-relative-filter-group>
  <uri-relative-filter-group android:allow="false">
    <data android:pathPrefix="/auth" />
    <data android:query="mobileoptout=true" />
  </uri-relative-filter-group>
  <uri-relative-filter-group android:allow="false">
    <data android:pathPrefix="/auth" />
    <data android:fragmentPrefix="faq" />
  </uri-relative-filter-group>
</intent-filter>

ব্যক্তিগত স্থান

একটি ডিভাইসে সংবেদনশীল অ্যাপ দেখাতে বা লুকানোর জন্য ব্যক্তিগত স্থানটি আনলক এবং লক করা যেতে পারে।

ব্যক্তিগত স্থান ব্যবহারকারীদের তাদের ডিভাইসে একটি পৃথক স্থান তৈরি করতে দেয় যেখানে তারা প্রমাণীকরণের একটি অতিরিক্ত স্তরের অধীনে সংবেদনশীল অ্যাপগুলিকে চোখ থেকে দূরে রাখতে পারে। ব্যক্তিগত স্থান একটি পৃথক ব্যবহারকারী প্রোফাইল ব্যবহার করে। ব্যবহারকারী ব্যক্তিগত স্থানের জন্য ডিভাইস লক বা একটি পৃথক লক ফ্যাক্টর ব্যবহার করতে পারেন।

ব্যক্তিগত স্থানের অ্যাপ্লিকেশনগুলি লঞ্চারে একটি পৃথক পাত্রে প্রদর্শিত হয় এবং ব্যক্তিগত স্থানটি লক করা অবস্থায় সাম্প্রতিক দৃশ্য, বিজ্ঞপ্তি, সেটিংস এবং অন্যান্য অ্যাপ্লিকেশন থেকে লুকিয়ে থাকে৷ ব্যবহারকারী দ্বারা তৈরি এবং ডাউনলোড করা সামগ্রী (যেমন মিডিয়া বা ফাইল) এবং অ্যাকাউন্টগুলি ব্যক্তিগত স্থান এবং প্রধান স্থানের মধ্যে পৃথক করা হয়। সিস্টেম শেয়ারশীট এবং ফটো পিকার ব্যবহার করা যেতে পারে অ্যাপগুলিকে স্পেস জুড়ে সামগ্রীতে অ্যাক্সেস দেওয়ার জন্য যখন ব্যক্তিগত স্থানটি আনলক করা থাকে।

ব্যবহারকারীরা বিদ্যমান অ্যাপ এবং তাদের ডেটা ব্যক্তিগত স্থানে সরাতে পারবেন না। পরিবর্তে, ব্যবহারকারীরা তাদের পছন্দের অ্যাপ স্টোর ব্যবহার করে একটি অ্যাপ ইনস্টল করতে ব্যক্তিগত স্থানে একটি ইনস্টল বিকল্প নির্বাচন করেন। প্রাইভেট স্পেসে অ্যাপগুলি মূল স্পেসের যেকোন অ্যাপ থেকে আলাদা কপি হিসেবে ইনস্টল করা হয় (একই অ্যাপের নতুন কপি)।

যখন একজন ব্যবহারকারী ব্যক্তিগত স্থান লক করে, প্রোফাইলটি বন্ধ হয়ে যায়। প্রোফাইল বন্ধ থাকাকালীন, ব্যক্তিগত স্থানের অ্যাপগুলি আর সক্রিয় থাকে না এবং বিজ্ঞপ্তিগুলি দেখানো সহ ফোরগ্রাউন্ড বা ব্যাকগ্রাউন্ড ক্রিয়াকলাপগুলি সম্পাদন করতে পারে না৷

আমরা সুপারিশ করছি যে আপনি আপনার অ্যাপটি প্রত্যাশিতভাবে কাজ করে তা নিশ্চিত করতে ব্যক্তিগত স্থান দিয়ে আপনার অ্যাপটি পরীক্ষা করুন, বিশেষ করে যদি আপনার অ্যাপ নিম্নলিখিত বিভাগগুলির মধ্যে একটিতে পড়ে:

নির্বাচিত ফটো অ্যাক্সেসের জন্য সাম্প্রতিক ব্যবহারকারী নির্বাচনের জন্য জিজ্ঞাসা করুন

Apps can now highlight only the most-recently-selected photos and videos when partial access to media permissions is granted. This feature can improve the user experience for apps that frequently request access to photos and videos. To use this feature in your app, enable the QUERY_ARG_LATEST_SELECTION_ONLY argument when querying MediaStore through ContentResolver.

Kotlin

val externalContentUri = MediaStore.Files.getContentUri("external")

val mediaColumns = arrayOf(
   FileColumns._ID,
   FileColumns.DISPLAY_NAME,
   FileColumns.MIME_TYPE,
)

val queryArgs = bundleOf(
   // Return only items from the last selection (selected photos access)
   QUERY_ARG_LATEST_SELECTION_ONLY to true,
   // Sort returned items chronologically based on when they were added to the device's storage
   QUERY_ARG_SQL_SORT_ORDER to "${FileColumns.DATE_ADDED} DESC",
   QUERY_ARG_SQL_SELECTION to "${FileColumns.MEDIA_TYPE} = ? OR ${FileColumns.MEDIA_TYPE} = ?",
   QUERY_ARG_SQL_SELECTION_ARGS to arrayOf(
       FileColumns.MEDIA_TYPE_IMAGE.toString(),
       FileColumns.MEDIA_TYPE_VIDEO.toString()
   )
)

Java

Uri externalContentUri = MediaStore.Files.getContentUri("external");

String[] mediaColumns = {
    FileColumns._ID,
    FileColumns.DISPLAY_NAME,
    FileColumns.MIME_TYPE
};

Bundle queryArgs = new Bundle();
queryArgs.putBoolean(MediaStore.QUERY_ARG_LATEST_SELECTION_ONLY, true);
queryArgs.putString(MediaStore.QUERY_ARG_SQL_SORT_ORDER, FileColumns.DATE_ADDED + " DESC");
queryArgs.putString(MediaStore.QUERY_ARG_SQL_SELECTION, FileColumns.MEDIA_TYPE + " = ? OR " + FileColumns.MEDIA_TYPE + " = ?");
queryArgs.putStringArray(MediaStore.QUERY_ARG_SQL_SELECTION_ARGS, new String[] {
    String.valueOf(FileColumns.MEDIA_TYPE_IMAGE),
    String.valueOf(FileColumns.MEDIA_TYPE_VIDEO)
});

অ্যান্ড্রয়েডে গোপনীয়তা স্যান্ডবক্স

অ্যান্ড্রয়েড 15- এ Android-এ গোপনীয়তা স্যান্ডবক্সের সর্বশেষ সংস্করণকে অন্তর্ভুক্ত করে সর্বশেষ Android বিজ্ঞাপন পরিষেবার এক্সটেনশনগুলি অন্তর্ভুক্ত রয়েছে। এই সংযোজনটি এমন প্রযুক্তি বিকাশের জন্য আমাদের কাজের অংশ যা ব্যবহারকারীর গোপনীয়তা উন্নত করে এবং মোবাইল অ্যাপের জন্য কার্যকর, ব্যক্তিগতকৃত বিজ্ঞাপন অভিজ্ঞতা সক্ষম করে। আমাদের গোপনীয়তা স্যান্ডবক্স পৃষ্ঠায় আপনাকে শুরু করতে সহায়তা করার জন্য Android বিকাশকারী পূর্বরূপ এবং বিটা প্রোগ্রামগুলিতে গোপনীয়তা স্যান্ডবক্স সম্পর্কে আরও তথ্য রয়েছে৷

স্বাস্থ্য সংযোগ

Android 15 Android-এর Health Connect- এর আশেপাশে সাম্প্রতিক এক্সটেনশনগুলিকে একীভূত করে, অ্যাপ-সংগৃহীত স্বাস্থ্য ও ফিটনেস ডেটা পরিচালনা ও শেয়ার করার জন্য একটি নিরাপদ এবং কেন্দ্রীভূত প্ল্যাটফর্ম। এই আপডেটটি ফিটনেস , পুষ্টি , ত্বকের তাপমাত্রা, প্রশিক্ষণ পরিকল্পনা এবং আরও অনেক কিছু জুড়ে অতিরিক্ত ডেটা প্রকারের জন্য সমর্থন যোগ করে।

ত্বকের তাপমাত্রা ট্র্যাকিং ব্যবহারকারীদের পরিধানযোগ্য বা অন্যান্য ট্র্যাকিং ডিভাইস থেকে আরও সঠিক তাপমাত্রার ডেটা সঞ্চয় এবং ভাগ করতে দেয়।

প্রশিক্ষণ পরিকল্পনাগুলি হল একটি ব্যবহারকারীকে তাদের ফিটনেস লক্ষ্য অর্জনে সহায়তা করার জন্য কাঠামোগত ওয়ার্কআউট পরিকল্পনা। প্রশিক্ষণ পরিকল্পনা সমর্থনের মধ্যে বিভিন্ন ধরনের সমাপ্তি এবং কর্মক্ষমতা লক্ষ্য অন্তর্ভুক্ত রয়েছে:

Google I/O থেকে অ্যান্ড্রয়েড হেলথ টক সহ অভিযোজনযোগ্য অভিজ্ঞতার বিল্ডিং- এ Android-এ Health Connect-এর সাম্প্রতিক আপডেটগুলি সম্পর্কে আরও জানুন৷

,

Android 15 Android-এর Health Connect- এর আশেপাশে সাম্প্রতিক এক্সটেনশনগুলিকে একীভূত করে, অ্যাপ-সংগৃহীত স্বাস্থ্য ও ফিটনেস ডেটা পরিচালনা ও শেয়ার করার জন্য একটি নিরাপদ এবং কেন্দ্রীভূত প্ল্যাটফর্ম। এই আপডেটটি ফিটনেস , পুষ্টি , ত্বকের তাপমাত্রা, প্রশিক্ষণ পরিকল্পনা এবং আরও অনেক কিছু জুড়ে অতিরিক্ত ডেটা প্রকারের জন্য সমর্থন যোগ করে।

ত্বকের তাপমাত্রা ট্র্যাকিং ব্যবহারকারীদের পরিধানযোগ্য বা অন্যান্য ট্র্যাকিং ডিভাইস থেকে আরও সঠিক তাপমাত্রার ডেটা সঞ্চয় এবং ভাগ করতে দেয়।

প্রশিক্ষণ পরিকল্পনাগুলি হল একটি ব্যবহারকারীকে তাদের ফিটনেস লক্ষ্য অর্জনে সহায়তা করার জন্য কাঠামোগত ওয়ার্কআউট পরিকল্পনা। প্রশিক্ষণ পরিকল্পনা সমর্থনের মধ্যে বিভিন্ন ধরনের সমাপ্তি এবং কর্মক্ষমতা লক্ষ্য অন্তর্ভুক্ত রয়েছে:

Google I/O থেকে অ্যান্ড্রয়েড হেলথ টক সহ অভিযোজনযোগ্য অভিজ্ঞতার বিল্ডিং- এ Android-এ Health Connect-এর সাম্প্রতিক আপডেটগুলি সম্পর্কে আরও জানুন৷

অ্যাপ স্ক্রিন শেয়ারিং

Android 15 supports app screen sharing so users can share or record just an app window rather than the entire device screen. This feature, first enabled in Android 14 QPR2, includes MediaProjection callbacks that allow your app to customize the app screen sharing experience. Note that for apps targeting Android 14 (API level 34) or higher, user consent is required for each MediaProjection capture session.

ব্যবহারকারীর অভিজ্ঞতা এবং সিস্টেম UI

অ্যান্ড্রয়েড 15 অ্যাপ ডেভেলপার এবং ব্যবহারকারীদের তাদের প্রয়োজন অনুসারে তাদের ডিভাইস কনফিগার করার জন্য আরও নিয়ন্ত্রণ এবং নমনীয়তা দেয়।

আপনার অ্যাপের ব্যবহারকারীর অভিজ্ঞতা উন্নত করতে Android 15-এর সর্বশেষ উন্নতিগুলি কীভাবে ব্যবহার করবেন সে সম্পর্কে আরও জানতে, Google I/O থেকে আপনার Android অ্যাপ টকের ব্যবহারকারীর অভিজ্ঞতা উন্নত করুন দেখুন।

জেনারেটেড প্রিভিউ API সহ আরও সমৃদ্ধ উইজেট পূর্বরূপ

অ্যান্ড্রয়েড 15-এর আগে, উইজেট পিকার প্রিভিউ দেওয়ার একমাত্র উপায় ছিল একটি স্ট্যাটিক ইমেজ বা লেআউট রিসোর্স নির্দিষ্ট করা। এই প্রিভিউগুলি প্রায়ই আসল উইজেটটির চেহারা থেকে উল্লেখযোগ্যভাবে আলাদা হয় যখন এটি হোম স্ক্রিনে স্থাপন করা হয়। এছাড়াও, জেটপ্যাক গ্ল্যান্স দিয়ে স্ট্যাটিক রিসোর্স তৈরি করা যায় না, তাই একজন গ্ল্যান্স ডেভেলপারকে তাদের উইজেট স্ক্রিনশট করতে হবে বা উইজেট প্রিভিউ করার জন্য একটি XML লেআউট তৈরি করতে হবে।

অ্যান্ড্রয়েড 15 জেনারেট করা পূর্বরূপগুলির জন্য সমর্থন যোগ করে। এর মানে হল যে অ্যাপ উইজেট প্রদানকারীরা স্ট্যাটিক রিসোর্সের পরিবর্তে পিকার প্রিভিউ হিসেবে ব্যবহার করার জন্য RemoteViews তৈরি করতে পারে।

অ্যাপগুলি উইজেট বাছাইকারীকে দূরবর্তী দৃশ্য সরবরাহ করতে পারে, যাতে ব্যবহারকারীরা যা দেখতে পাবে তার আরও প্রতিনিধি হতে তারা পিকারে সামগ্রী আপডেট করতে পারে।

পুশ API

অ্যাপগুলি একটি পুশ API এর মাধ্যমে জেনারেটেড প্রিভিউ প্রদান করতে পারে। অ্যাপ্লিকেশানগুলি তাদের জীবনচক্রের যেকোনো সময়ে পূর্বরূপ প্রদান করতে পারে এবং পূর্বরূপ প্রদানের জন্য হোস্টের কাছ থেকে একটি সুস্পষ্ট অনুরোধ গ্রহণ করে না। AppWidgetService এ প্রিভিউ টিকে থাকে, এবং হোস্ট তাদের চাহিদা অনুযায়ী অনুরোধ করতে পারে। নিম্নলিখিত উদাহরণটি একটি XML উইজেট লেআউট সংস্থান লোড করে এবং এটিকে পূর্বরূপ হিসাবে সেট করে:

AppWidgetManager.getInstance(appContext).setWidgetPreview(
   ComponentName(
       appContext,
       SociaLiteAppWidgetReceiver::class.java
   ),
   AppWidgetProviderInfo.WIDGET_CATEGORY_HOME_SCREEN,
   RemoteViews("com.example", R.layout.widget_preview)
)

প্রত্যাশিত প্রবাহ হল:

  1. যেকোনো সময়, উইজেট প্রদানকারী setWidgetPreview কল করে। প্রদত্ত প্রিভিউ অন্যান্য প্রদানকারীর তথ্য সহ AppWidgetService এ টিকে থাকে।
  2. setWidgetPreview AppWidgetHost.onProvidersChanged কলব্যাকের মাধ্যমে একটি আপডেট করা প্রিভিউ হোস্টকে অবহিত করে। প্রতিক্রিয়া হিসাবে, উইজেট হোস্ট তার সমস্ত প্রদানকারীর তথ্য পুনরায় লোড করে।
  3. একটি উইজেট পূর্বরূপ প্রদর্শন করার সময়, হোস্ট AppWidgetProviderInfo.generatedPreviewCategories চেক করে, এবং যদি নির্বাচিত বিভাগটি উপলব্ধ থাকে, তাহলে এই প্রদানকারীর জন্য সংরক্ষিত পূর্বরূপ ফেরত দিতে AppWidgetManager.getWidgetPreview কল করে।

setWidgetPreview কখন কল করতে হবে

যেহেতু প্রিভিউ প্রদানের জন্য কোন কলব্যাক নেই, তাই অ্যাপগুলি যেকোন সময়ে প্রিভিউ পাঠানোর জন্য বেছে নিতে পারে যখন তারা চলছে। কত ঘন ঘন প্রিভিউ আপডেট করতে হবে তা নির্ভর করে উইজেটের ব্যবহারের ক্ষেত্রে।

নিম্নলিখিত তালিকাটি পূর্বরূপ ব্যবহারের ক্ষেত্রে দুটি প্রধান বিভাগ বর্ণনা করে:

  • প্রদানকারীরা তাদের উইজেট প্রিভিউতে বাস্তব ডেটা দেখায়, যেমন ব্যক্তিগতকৃত বা সাম্প্রতিক তথ্য। ব্যবহারকারী একবার সাইন ইন করলে বা তাদের অ্যাপে প্রাথমিক কনফিগারেশন সম্পন্ন করলে এই প্রদানকারীরা পূর্বরূপ সেট করতে পারে। এর পরে, তারা তাদের নির্বাচিত ক্যাডেন্সে পূর্বরূপ আপডেট করার জন্য একটি পর্যায়ক্রমিক কাজ সেট আপ করতে পারে। এই ধরনের উইজেটের উদাহরণ একটি ফটো, ক্যালেন্ডার, আবহাওয়া বা সংবাদ উইজেট হতে পারে।
  • প্রোভাইডার যেগুলি প্রিভিউ বা দ্রুত-অ্যাকশন উইজেটগুলিতে স্ট্যাটিক তথ্য দেখায় যা কোনও ডেটা প্রদর্শন করে না। এই প্রদানকারীরা একবার প্রিভিউ সেট করতে পারে, যখন অ্যাপটি প্রথম চালু হয়। এই ধরনের উইজেটের উদাহরণগুলির মধ্যে রয়েছে একটি ড্রাইভ দ্রুত অ্যাকশন উইজেট বা ক্রোম শর্টকাট উইজেট।

কিছু প্রদানকারী হাব মোড পিকারে স্ট্যাটিক প্রিভিউ দেখাতে পারে, কিন্তু হোমস্ক্রিন পিকারে আসল তথ্য। এই সরবরাহকারীদের পূর্বরূপ সেট করতে এই উভয় ব্যবহারের ক্ষেত্রে নির্দেশিকা অনুসরণ করা উচিত।

পিকচার-ইন-পিকচার

Android 15 introduces changes in Picture-in-Picture (PiP) ensuring an even smoother transition when entering into PiP mode. This will be beneficial for apps having UI elements overlaid on top of their main UI, which goes into PiP.

Developers use the onPictureInPictureModeChanged callback to define logic that toggles the visibility of the overlaid UI elements. This callback is triggered when the PiP enter or exit animation is completed. Beginning in Android 15, the PictureInPictureUiState class includes another state.

With this UI state, apps targeting Android 15 (API level 35) will observe the Activity#onPictureInPictureUiStateChanged callback being invoked with isTransitioningToPip() as soon as the PiP animation starts. There are many UI elements that are not relevant for the app when it is in PiP mode, for example views or layout that include information such as suggestions, upcoming video, ratings, and titles. When the app goes to PiP mode, use the onPictureInPictureUiStateChanged callback to hide these UI elements. When the app goes to full screen mode from the PiP window, use onPictureInPictureModeChanged callback to unhide these elements, as shown in the following examples:

override fun onPictureInPictureUiStateChanged(pipState: PictureInPictureUiState) {
        if (pipState.isTransitioningToPip()) {
          // Hide UI elements
        }
    }
override fun onPictureInPictureModeChanged(isInPictureInPictureMode: Boolean) {
        if (isInPictureInPictureMode) {
          // Unhide UI elements
        }
    }

This quick visibility toggle of irrelevant UI elements (for a PiP window) helps ensure a smoother and flicker-free PiP enter animation.

ডোন্ট ডিস্টার্ব নিয়ম উন্নত করা হয়েছে

AutomaticZenRule lets apps customize Attention Management (Do Not Disturb) rules and decide when to activate or deactivate them. Android 15 greatly enhances these rules with the goal of improving the user experience. The following enhancements are included:

  • Adding types to AutomaticZenRule, allowing the system to apply special treatment to some rules.
  • Adding an icon to AutomaticZenRule, helping to make the modes be more recognizable.
  • Adding a triggerDescription string to AutomaticZenRule that describes the conditions on which the rule should become active for the user.
  • Added ZenDeviceEffects to AutomaticZenRule, allowing rules to trigger things like grayscale display, night mode, or dimming the wallpaper.

বিজ্ঞপ্তি চ্যানেলের জন্য ভাইব্রেশন ইফেক্ট সেট করুন

Android 15 NotificationChannel.setVibrationEffect ব্যবহার করে চ্যানেলের মাধ্যমে ইনকামিং বিজ্ঞপ্তিগুলির জন্য সমৃদ্ধ ভাইব্রেশন সেট করা সমর্থন করে, যাতে আপনার ব্যবহারকারীরা তাদের ডিভাইসের দিকে না তাকিয়ে বিভিন্ন ধরনের বিজ্ঞপ্তির মধ্যে পার্থক্য করতে পারে।

মিডিয়া প্রজেকশন স্ট্যাটাস বার চিপ এবং অটো স্টপ

মিডিয়া অভিক্ষেপ ব্যক্তিগত ব্যবহারকারীর তথ্য প্রকাশ করতে পারে। একটি নতুন, বিশিষ্ট স্ট্যাটাস বার চিপ ব্যবহারকারীদের যেকোনো চলমান স্ক্রিন প্রজেকশন সম্পর্কে সচেতন করে। ব্যবহারকারীরা স্ক্রিন কাস্টিং, শেয়ারিং বা রেকর্ডিং বন্ধ করতে চিপটিতে ট্যাপ করতে পারেন। এছাড়াও, আরও স্বজ্ঞাত ব্যবহারকারীর অভিজ্ঞতার জন্য, ডিভাইসের স্ক্রীন লক হয়ে গেলে যেকোনও অগ্রগতি স্ক্রীন প্রজেকশন এখন স্বয়ংক্রিয়ভাবে বন্ধ হয়ে যায়।

স্ক্রিন শেয়ারিং, কাস্টিং এবং রেকর্ডিংয়ের জন্য স্ট্যাটাস বার চিপ।

বড় পর্দা এবং ফর্ম ফ্যাক্টর

Android 15 বড় স্ক্রীন, ফ্লিপাবল এবং ফোল্ডেবল সহ Android এর ফর্ম ফ্যাক্টরগুলির থেকে সর্বাধিক পেতে আপনার অ্যাপগুলিকে সমর্থন দেয়৷

উন্নত বড় পর্দা মাল্টিটাস্কিং

Android 15 gives users better ways to multitask on large screen devices. For example, users can save their favorite split-screen app combinations for quick access and pin the taskbar on screen to quickly switch between apps. This means that making sure your app is adaptive is more important than ever.

Google I/O has sessions on Building adaptive Android apps and Building UI with the Material 3 adaptive library that can help, and our documentation has more to help you Design for large screens.

কভার পর্দা সমর্থন

আপনার অ্যাপটি এমন একটি সম্পত্তি ঘোষণা করতে পারে যা Android 15 আপনার Application বা Activity সমর্থিত ফ্লিপযোগ্য ডিভাইসের ছোট কভার স্ক্রিনে উপস্থাপন করার অনুমতি দিতে ব্যবহার করে। এই স্ক্রিনগুলিকে Android অ্যাপগুলি চালানোর জন্য সামঞ্জস্যপূর্ণ লক্ষ্য হিসাবে বিবেচনা করা খুব ছোট, কিন্তু আপনার অ্যাপগুলিকে সমর্থন করার জন্য বেছে নিতে পারে, আপনার অ্যাপটিকে আরও জায়গায় উপলব্ধ করে।

সংযোগ

Android 15 আপনার অ্যাপকে যোগাযোগ এবং বেতার প্রযুক্তির সর্বশেষ অগ্রগতিতে অ্যাক্সেস দিতে প্ল্যাটফর্ম আপডেট করে।

স্যাটেলাইট সমর্থন

Android 15 স্যাটেলাইট সংযোগের জন্য প্ল্যাটফর্ম সমর্থন প্রসারিত করে চলেছে এবং স্যাটেলাইট সংযোগের ল্যান্ডস্কেপ জুড়ে একটি সামঞ্জস্যপূর্ণ ব্যবহারকারীর অভিজ্ঞতা নিশ্চিত করতে কিছু UI উপাদান অন্তর্ভুক্ত করে।

অ্যাপগুলি ServiceState.isUsingNonTerrestrialNetwork() ব্যবহার করে শনাক্ত করতে পারে যখন একটি ডিভাইস একটি স্যাটেলাইটের সাথে সংযুক্ত থাকে, কেন সম্পূর্ণ নেটওয়ার্ক পরিষেবাগুলি অনুপলব্ধ হতে পারে সে সম্পর্কে তাদের আরও সচেতনতা দেয়৷ উপরন্তু, Android 15 এসএমএস এবং এমএমএস অ্যাপের পাশাপাশি বার্তা পাঠানো এবং গ্রহণ করার জন্য স্যাটেলাইট সংযোগ ব্যবহার করার জন্য প্রিলোড করা RCS অ্যাপগুলির জন্য সমর্থন প্রদান করে।

ডিভাইসটি একটি স্যাটেলাইটের সাথে সংযুক্ত হলে একটি বিজ্ঞপ্তি উপস্থিত হয়৷

মসৃণ NFC অভিজ্ঞতা

Android 15 is working to make the tap to pay experience more seamless and reliable while continuing to support Android's robust NFC app ecosystem. On supported devices, apps can request the NfcAdapter to enter observe mode, where the device listens but doesn't respond to NFC readers, sending the app's NFC service PollingFrame objects to process. The PollingFrame objects can be used to auth ahead of the first communication to the NFC reader, allowing for a one tap transaction in many cases.

In addition, apps can register a filter on supported devices so they can be notified of polling loop activity, which allows for smooth operation with multiple NFC-aware applications.

ওয়ালেট ভূমিকা

অ্যান্ড্রয়েড 15 একটি ওয়ালেট ভূমিকা প্রবর্তন করে যা ব্যবহারকারীর পছন্দের ওয়ালেট অ্যাপের সাথে কঠোর সংহতকরণের অনুমতি দেয়। এই ভূমিকাটি NFC ডিফল্ট কন্ট্যাক্টলেস পেমেন্ট সেটিং প্রতিস্থাপন করে। ব্যবহারকারীরা সেটিংস > অ্যাপ্লিকেশান > ডিফল্ট অ্যাপ্লিকেশানগুলিতে নেভিগেট করে Wallet ভূমিকা ধারক পরিচালনা করতে পারেন৷

পেমেন্ট বিভাগে নিবন্ধিত AID-এর জন্য NFC ট্যাপ রাউট করার সময় Wallet ভূমিকা ব্যবহার করা হয়। ট্যাপগুলি সর্বদা Wallet রোল হোল্ডারের কাছে যায় যদি না একই AID-এর জন্য নিবন্ধিত অন্য একটি অ্যাপ অগ্রভাগে চলছে।

ওয়ালেট কুইক অ্যাকসেস টাইল সক্রিয় করার সময় কোথায় যেতে হবে তা নির্ধারণ করতেও এই ভূমিকা ব্যবহার করা হয়। যখন ভূমিকাটি "কোনও নয়" তে সেট করা থাকে, তখন দ্রুত অ্যাক্সেস টাইল উপলব্ধ থাকে না এবং অর্থপ্রদানের বিভাগ NFC ট্যাপগুলি শুধুমাত্র অগ্রভাগের অ্যাপে বিতরণ করা হয়৷

নিরাপত্তা

Android 15 আপনাকে আপনার অ্যাপের নিরাপত্তা বাড়াতে, আপনার অ্যাপের ডেটা সুরক্ষিত করতে এবং ব্যবহারকারীদের তাদের ডেটার উপর আরও স্বচ্ছতা ও নিয়ন্ত্রণ দিতে সাহায্য করে। ব্যবহারকারীর সুরক্ষার উন্নতি করতে এবং নতুন হুমকির বিরুদ্ধে আপনার অ্যাপকে সুরক্ষিত করতে আমরা কী করছি তার আরও জানতে Google I/O-এর Android টক-এ সেফগার্ডিং ইউজার সিকিউরিটি দেখুন।

অটোফিলের সাথে শংসাপত্র ম্যানেজারকে একীভূত করুন

অ্যান্ড্রয়েড 15 দিয়ে শুরু করে, ডেভেলপাররা ব্যবহারকারীর নাম বা পাসওয়ার্ড ক্ষেত্রগুলির মতো নির্দিষ্ট ভিউগুলিকে ক্রেডেনশিয়াল ম্যানেজার অনুরোধের সাথে লিঙ্ক করতে পারে, যাতে সাইন-ইন প্রক্রিয়া চলাকালীন একটি উপযোগী ব্যবহারকারীর অভিজ্ঞতা প্রদান করা সহজ হয়৷ ব্যবহারকারী যখন এই ভিউগুলির একটিতে ফোকাস করেন, তখন একটি সংশ্লিষ্ট অনুরোধ শংসাপত্র ব্যবস্থাপকের কাছে পাঠানো হয়। ফলস্বরূপ শংসাপত্রগুলি সরবরাহকারীদের মধ্যে একত্রিত করা হয় এবং অটোফিল ফলব্যাক UI-তে প্রদর্শিত হয়, যেমন ইনলাইন পরামর্শ বা ড্রপ-ডাউন পরামর্শ৷ Jetpack androidx.credentials লাইব্রেরি হল ডেভেলপারদের ব্যবহার করার জন্য পছন্দের এন্ডপয়েন্ট এবং শীঘ্রই Android 15 এবং উচ্চতর সংস্করণে এই বৈশিষ্ট্যটিকে আরও উন্নত করার জন্য উপলব্ধ হবে৷

বায়োমেট্রিক প্রম্পট সহ একক ট্যাপ সাইন-আপ এবং সাইন-ইন সংহত করুন

Credential Manager integrates biometric prompts into the credential creation and sign-in processes, eliminating the need for providers to manage biometric prompts. As a result, credential providers only need to focus on the results of the create and get flows, augmented with the biometric flow result. This simplified process creates a more efficient and streamlined credential creation and retrieval process.

এন্ড-টু-এন্ড এনক্রিপশনের জন্য মূল ব্যবস্থাপনা

We are introducing the E2eeContactKeysManager in Android 15, which facilitates end-to-end encryption (E2EE) in your Android apps by providing an OS-level API for the storage of cryptographic public keys.

The E2eeContactKeysManager is designed to integrate with the platform contacts app to give users a centralized way to manage and verify their contacts' public keys.

অনুমতি বিষয়বস্তু URIs চেক

অ্যান্ড্রয়েড 15 এপিআইগুলির একটি সেট প্রবর্তন করে যা সামগ্রী ইউআরআইগুলিতে অনুমতি পরীক্ষা করে:

  • Context.checkContentUriPermissionFull : এটি কন্টেন্ট ইউআরআই-এ সম্পূর্ণ অনুমতি পরীক্ষা করে।
  • Activity ম্যানিফেস্ট অ্যাট্রিবিউটের requireContentUriPermissionFromCaller : এটি অ্যাক্টিভিটি লঞ্চের সময় প্রদত্ত কন্টেন্ট URI-তে নির্দিষ্ট অনুমতি প্রয়োগ করে।
  • Activity কলারদের জন্য ComponentCaller ক্লাস : এটি সেই অ্যাপের প্রতিনিধিত্ব করে যা অ্যাক্টিভিটি চালু করেছে।

অ্যাক্সেসযোগ্যতা

অ্যান্ড্রয়েড 15 এমন বৈশিষ্ট্য যুক্ত করে যা ব্যবহারকারীদের জন্য অ্যাক্সেসযোগ্যতা উন্নত করে।

আরও ভালো ব্রেইল

Android 15-এ, আমরা টকব্যাকের জন্য ব্রেইল ডিসপ্লে সমর্থন করা সম্ভব করেছি যা USB এবং সুরক্ষিত ব্লুটুথ উভয়ের মাধ্যমে HID মান ব্যবহার করছে।

এই স্ট্যান্ডার্ডটি, অনেকটা ইঁদুর এবং কীবোর্ড দ্বারা ব্যবহৃত একটির মতো, সময়ের সাথে সাথে ব্রেইল ডিসপ্লেগুলির একটি বিস্তৃত পরিসরে Android কে সমর্থন করবে৷

আন্তর্জাতিকীকরণ

Android 15 এমন বৈশিষ্ট্য এবং ক্ষমতা যুক্ত করে যা ব্যবহারকারীর অভিজ্ঞতাকে পরিপূরক করে যখন একটি ডিভাইস বিভিন্ন ভাষায় ব্যবহার করা হয়।

CJK পরিবর্তনশীল ফন্ট

অ্যান্ড্রয়েড 15 দিয়ে শুরু করে, চাইনিজ, জাপানিজ এবং কোরিয়ান (CJK) ভাষার ফন্ট ফাইল, NotoSansCJK, এখন একটি পরিবর্তনশীল ফন্ট। পরিবর্তনশীল ফন্টগুলি CJK ভাষায় সৃজনশীল টাইপোগ্রাফির জন্য সম্ভাবনা উন্মুক্ত করে। ডিজাইনাররা শৈলীর একটি বিস্তৃত পরিসর অন্বেষণ করতে পারে এবং দৃশ্যত আকর্ষণীয় লেআউট তৈরি করতে পারে যা অর্জন করা আগে কঠিন বা অসম্ভব ছিল।

চাইনিজ, জাপানিজ এবং কোরিয়ান (CJK) ভাষার জন্য পরিবর্তনশীল ফন্ট বিভিন্ন ফন্টের প্রস্থের সাথে কীভাবে উপস্থিত হয়।

আন্তঃ চরিত্র ন্যায্যতা

Android 15 দিয়ে শুরু করে, JUSTIFICATION_MODE_INTER_CHARACTER ব্যবহার করে অক্ষর ব্যবধান ব্যবহার করে পাঠ্যকে ন্যায়সঙ্গত করা যেতে পারে। আন্তঃশব্দ ন্যায্যতা প্রথম Android 8.0 (API স্তর 26) এ প্রবর্তন করা হয়েছিল, এবং আন্তঃ-অক্ষর ন্যায্যতা সেই ভাষাগুলির জন্য অনুরূপ ক্ষমতা প্রদান করে যেগুলি সেগমেন্টেশনের জন্য হোয়াইটস্পেস অক্ষর ব্যবহার করে, যেমন চাইনিজ, জাপানিজ এবং অন্যান্য।

JUSTIFICATION_MODE_NONE ব্যবহার করে জাপানি পাঠ্যের বিন্যাস।
JUSTIFICATION_MODE_NONE ব্যবহার করে ইংরেজি পাঠ্যের বিন্যাস।


JUSTIFICATION_MODE_INTER_WORD ব্যবহার করে জাপানি পাঠ্যের বিন্যাস।
JUSTIFICATION_MODE_INTER_WORD ব্যবহার করে ইংরেজি পাঠ্যের বিন্যাস।


JUSTIFICATION_MODE_INTER_CHARACTER ব্যবহার করে জাপানি পাঠ্যের জন্য লেআউট।
JUSTIFICATION_MODE_INTER_CHARACTER ব্যবহার করে ইংরেজি পাঠ্যের বিন্যাস।

স্বয়ংক্রিয় লাইন বিরতি কনফিগারেশন

অ্যান্ড্রয়েড অ্যান্ড্রয়েড 13 (এপিআই লেভেল 33) এ জাপানি এবং কোরিয়ানদের জন্য বাক্যাংশ-ভিত্তিক লাইন ব্রেক সমর্থন করা শুরু করেছে। যাইহোক, যদিও বাক্যাংশ-ভিত্তিক লাইন বিরতিগুলি পাঠ্যের ছোট লাইনের পাঠযোগ্যতা উন্নত করে, তারা পাঠ্যের দীর্ঘ লাইনের জন্য ভাল কাজ করে না। Android 15-এ, অ্যাপগুলি LINE_BREAK_WORD_STYLE_AUTO বিকল্পটি ব্যবহার করে শুধুমাত্র পাঠ্যের ছোট লাইনের জন্য বাক্যাংশ-ভিত্তিক লাইন বিরতি প্রয়োগ করতে পারে। এই বিকল্পটি পাঠ্যের জন্য সেরা শব্দ শৈলী বিকল্পটি নির্বাচন করে।

পাঠ্যের সংক্ষিপ্ত লাইনের জন্য, বাক্যাংশ-ভিত্তিক লাইন বিরতি ব্যবহার করা হয়, যা LINE_BREAK_WORD_STYLE_PHRASE এর মতোই কাজ করে, যেমনটি নিম্নলিখিত ছবিতে দেখানো হয়েছে:

পাঠ্যের ছোট লাইনের জন্য, LINE_BREAK_WORD_STYLE_AUTO পাঠ্যের পাঠযোগ্যতা উন্নত করতে বাক্যাংশ-ভিত্তিক লাইন বিরতি প্রয়োগ করে। এটি LINE_BREAK_WORD_STYLE_PHRASE প্রয়োগ করার মতই।

পাঠ্যের দীর্ঘ লাইনের জন্য, LINE_BREAK_WORD_STYLE_AUTO একটি নো লাইন-ব্রেক শব্দ শৈলী ব্যবহার করে, যা LINE_BREAK_WORD_STYLE_NONE এর মতোই কাজ করে, যেমনটি নিম্নলিখিত ছবিতে দেখানো হয়েছে:

পাঠ্যের দীর্ঘ লাইনের জন্য, LINE_BREAK_WORD_STYLE_AUTO পাঠ্যের পাঠযোগ্যতা উন্নত করতে কোনো লাইন-ব্রেক শব্দ শৈলী প্রয়োগ করে না। এটি LINE_BREAK_WORD_STYLE_NONE প্রয়োগ করার মতই।

অতিরিক্ত জাপানি হেনটাইগানা হরফ

In Android 15, a font file for old Japanese Hiragana (known as Hentaigana) is bundled by default. The unique shapes of Hentaigana characters can add a distinctive flair to artwork or design while also helping to preserve accurate transmission and understanding of ancient Japanese documents.

Character and text style for the Japanese Hentaigana font.

VideoLAN শঙ্কু কপিরাইট (c) 1996-2010 VideoLAN। এই লোগো বা একটি পরিবর্তিত সংস্করণ যে কেউ VideoLAN প্রকল্প বা VideoLAN টিম দ্বারা বিকশিত কোনো পণ্য উল্লেখ করার জন্য ব্যবহার বা পরিবর্তিত হতে পারে, কিন্তু প্রকল্পের দ্বারা অনুমোদন নির্দেশ করে না।

Vulkan এবং Vulkan লোগো হল Khronos Group Inc এর নিবন্ধিত ট্রেডমার্ক।

OpenGL হল একটি নিবন্ধিত ট্রেডমার্ক এবং OpenGL ES লোগো হল Hewlett Packard Enterprise-এর একটি ট্রেডমার্ক যা Khronos-এর অনুমতিতে ব্যবহৃত হয়।