বিকাশকারী API Google ফন্ট দ্বারা পরিবেশিত সমস্ত পরিবারের মেটাডেটাতে অ্যাক্সেস দেয়। এটি অ্যাপ্লিকেশানগুলিকে উপলব্ধ ফন্ট পরিবারগুলির জন্য Google ফন্টগুলি জিজ্ঞাসা করার অনুমতি দেয়৷ REST API JSON ফর্ম্যাটে ডেটা সরবরাহ করে যাতে প্রতিটি পরিবারে শৈলী এবং স্ক্রিপ্ট (গুগল ফন্টে উপসেট বলা হয়) অন্তর্ভুক্ত থাকে। API পরিবারের তালিকাকে বর্ণানুক্রমিকভাবে, যোগ করার তারিখ অনুসারে, শৈলীর সংখ্যা অনুসারে, প্রবণতা অনুসারে বা জনপ্রিয়তা অনুসারে সাজাতে পারে।
শ্রোতা
এই নথিটি ওয়েব এবং অ্যাপ্লিকেশন ডেভেলপারদের উদ্দেশ্যে। বিকাশকারী API ব্যবহার করার জন্য জাভাস্ক্রিপ্টের জ্ঞান প্রয়োজন।
একটি দ্রুত উদাহরণ
Google ফন্ট পরিষেবা দ্বারা প্রদত্ত ফন্টগুলির গতিশীল তালিকা পুনরুদ্ধার করতে, নিম্নলিখিত অনুরোধটি পাঠান:
https://www.googleapis.com/webfonts/v1/webfonts?key=YOUR-API-KEY
ফলাফলের একটি নমুনা এই মত দেখাবে:
{ "kind": "webfonts#webfontList", "items": [ [...] { "family": "Anonymous Pro", "variants": [ "regular", "italic", "700", "700italic" ], "subsets": [ "cyrillic", "greek", "latin", "latin-ext" ], "version": "v21", "lastModified": "2022-09-22", "files": { "regular": "http://fonts.gstatic.com/s/anonymouspro/v21/rP2Bp2a15UIB7Un-bOeISG3pLlw89CH98Ko.ttf", "italic": "http://fonts.gstatic.com/s/anonymouspro/v21/rP2fp2a15UIB7Un-bOeISG3pHl428AP44Kqr2Q.ttf", "700": "http://fonts.gstatic.com/s/anonymouspro/v21/rP2cp2a15UIB7Un-bOeISG3pFuAT0CnW7KOywKo.ttf", "700italic": "http://fonts.gstatic.com/s/anonymouspro/v21/rP2ap2a15UIB7Un-bOeISG3pHl4OTCzc6IG30KqB9Q.ttf" }, "category": "monospace", "kind": "webfonts#webfont", "menu": "http://fonts.gstatic.com/s/anonymouspro/v21/rP2Bp2a15UIB7Un-bOeISG3pHl028A.ttf" }, { "family": "Antic", "variants": [ "regular" ], "subsets": [ "latin" ], "version": "v19", "lastModified": "2022-09-22", "files": { "regular": "http://fonts.gstatic.com/s/antic/v19/TuGfUVB8XY5DRaZLodgzydtk.ttf" }, "category": "sans-serif", "kind": "webfonts#webfont", "menu": "http://fonts.gstatic.com/s/antic/v19/TuGfUVB8XY5DRZZKq9w.ttf" }, [...] ] }
Google-এ আপনার আবেদন শনাক্ত করা
প্রতিটি অনুরোধের সাথে একটি API কী অন্তর্ভুক্ত করে Google Fonts Developer API-কে অনুরোধ পাঠানোর সময় আপনার অ্যাপ্লিকেশনটিকে নিজেকে সনাক্ত করতে হবে।
একটি API কী অর্জন এবং ব্যবহার করা
একটি চাবি পানঅথবা শংসাপত্র পৃষ্ঠায় একটি তৈরি করুন।
আপনার একটি API কী থাকার পরে, আপনার অ্যাপ্লিকেশনটি সমস্ত অনুরোধের URL-এ ক্যোয়ারী প্যারামিটার key= yourAPIKey
যোগ করতে পারে।
API কী ইউআরএল-এ এম্বেড করার জন্য নিরাপদ; এটা কোন এনকোডিং প্রয়োজন নেই.
বিস্তারিত
JSON প্রতিক্রিয়া (উপরের নমুনা পড়ুন) "আইটেম" নামের একটি অ্যারে নিয়ে গঠিত যাতে প্রতিটি ফন্ট পরিবার সম্পর্কে তথ্য সহ অবজেক্ট থাকে।
একটি পারিবারিক বস্তু নিম্নলিখিত ক্ষেত্রগুলি নিয়ে গঠিত:
- kind: বস্তুর ধরনের, একটি webfont অবজেক্ট
- পরিবার: পরিবারের নাম
- উপসেট: পরিবার দ্বারা সমর্থিত স্ক্রিপ্টগুলির একটি তালিকা৷
- মেনু: পারিবারিক উপসেটের একটি url শুধুমাত্র পরিবারের নাম কভার করে।
- বৈকল্পিক: পরিবারের জন্য উপলব্ধ বিভিন্ন শৈলী
- সংস্করণ: ফন্ট ফ্যামিলি সংস্করণ।
- অক্ষ: অক্ষ পরিসীমা, পরিবর্তনশীল ফন্টের জন্য শুধুমাত্র অনুরোধের (নীচে দেখুন) উপস্থাপন করুন।
- lastModified: তারিখ (ফরম্যাট "yyyy-MM-dd") ফন্ট ফ্যামিলি শেষবারের মতো পরিবর্তন করা হয়েছে।
- ফাইল: ফন্ট ফ্যামিলি ফাইল (সমস্ত সমর্থিত স্ক্রিপ্ট সহ) উপলব্ধ ভেরিয়েন্টগুলির প্রতিটির জন্য।
প্রতিটি পরিবারের জন্য তথ্য একত্রিত করে একটি ফন্ট API অনুরোধ তৈরি করা সহজ। উদাহরণস্বরূপ অনুমান করা হচ্ছে যে আমাদের কাছে বেনামী প্রো-এর জন্য পারিবারিক বস্তুর একটি রেফারেন্স রয়েছে:
[...] var apiUrl = []; apiUrl.push('https://fonts.googleapis.com/css?family='); apiUrl.push(anonymousPro.family.replace(/ /g, '+')); if (contains('italic', anonymousPro.variants)) { apiUrl.push(':'); apiUrl.push('italic'); } if (contains('greek', anonymousPro.subsets)) { apiUrl.push('&subset='); apiUrl.push('greek'); } // url: 'https://fonts.googleapis.com/css?family=Anonymous+Pro:italic&subset=greek' var url = apiUrl.join(''); [...]
বাছাই
পরিবারের তালিকা ডিফল্টরূপে কোনো নির্দিষ্ট ক্রমে ফেরত দেওয়া হয় না। তবে সাজানোর পরামিতি ব্যবহার করে তালিকাটি সাজানো সম্ভব:
https://www.googleapis.com/webfonts/v1/webfonts?sort=popularity
সম্ভাব্য বাছাই মান হল:
- alpha: তালিকাটি বর্ণানুক্রমে সাজান
- তারিখ: যোগ করা তারিখ অনুসারে তালিকা সাজান (সর্বশেষ ফন্ট যোগ করা বা প্রথমে আপডেট করা হয়েছে)
- জনপ্রিয়তা: জনপ্রিয়তা অনুসারে তালিকা সাজান (প্রথমে সবচেয়ে জনপ্রিয় পরিবার)
- শৈলী: উপলব্ধ শৈলীর সংখ্যা অনুসারে তালিকা বাছাই করুন (প্রথমে বেশিরভাগ শৈলী সহ পরিবার)
- প্রবণতা: ব্যবহারের বৃদ্ধি দেখে পরিবার অনুসারে তালিকা বাছাই করুন (প্রথমে সবচেয়ে বেশি বৃদ্ধি পাচ্ছে পরিবার)
ফিল্টারিং
একটি নির্দিষ্ট পরিবারকে জিজ্ঞাসা করুন
https://www.googleapis.com/webfonts/v1/webfonts?family=family_name
গ্রীক উপসেট সমর্থন করে এমন সমস্ত পরিবার
https://www.googleapis.com/webfonts/v1/webfonts?subset=subset_name
অপ্টিমাইজেশান
woff2 ফরম্যাটে সংকুচিত ফন্ট ফাইল পুনরুদ্ধার করার জন্য
https://www.googleapis.com/webfonts/v1/webfonts?capability=WOFF2
পরিবর্তনশীল হরফ
পরিবর্তনশীল ফন্টগুলি ক্রমাগত শৈলীর রেঞ্জ অফার করে। ডিফল্টরূপে, স্ট্যাটিক ফন্ট ফাইলগুলির একটি সংমিশ্রণ স্ট্যান্ডার্ড পজিশনে তাত্ক্ষণিক পরিবর্তনশীল ফন্টগুলির জন্য ফেরত দেওয়া হয়। যদি capability=VF
সেট করা থাকে, তাহলে ভ্যারিয়েবল ফন্ট ফাইলটি স্ট্যাটিক ফাইলের পরিবর্তে উপলব্ধ অক্ষ রেঞ্জ মেটাডেটা সহ ফেরত দেওয়া হয়। নমুনা উদাহরণ:
https://www.googleapis.com/webfonts/v1/webfonts?capability=VF
নমুনা প্রতিক্রিয়া:
{ "kind": "webfonts#webfontList", "items": [ [...] { "family": "Noto Sans Display", "variants": [ "regular", "italic" ], "subsets": [ "cyrillic", "cyrillic-ext", "greek", "greek-ext", "latin", "latin-ext", "vietnamese" ], "version": "v20", "lastModified": "2022-09-22", "files": { "regular": "http://fonts.gstatic.com/s/notosansdisplay/v20/RLplK4fy6r6tOBEJg0IAKzqdFZVZxokvfn_BDLxR.ttf", "italic": "http://fonts.gstatic.com/s/notosansdisplay/v20/RLpjK4fy6r6tOBEJg0IAKzqdFZVZxrktdHvjCaxRgew.ttf" }, "category": "sans-serif", "kind": "webfonts#webfont", "menu": "http://fonts.gstatic.com/s/notosansdisplay/v20/RLpbK4fy6r6tOBEJg0IAKzqdFZVZxpMkXJMhnB9XjO1o90LuV-PT4Doq_AKp_3cKZTCa3g.ttf", "axes": [ { "tag": "wdth", "start": 62.5, "end": 100 }, { "tag": "wght", "start": 100, "end": 900 } ] }, [...] ] }
API URL স্পেসিফিকেশন
webfonts?key=<your_key>[&family=<family>][&subset=<subset>][&capability=<capability>...][&sort=<sort>]
your_key
: আপনার বিকাশকারী API কী।
family
: একটি ফন্ট পরিবারের নাম।
subset
: একটি ফন্ট সাবসেটের নাম।
capability
: VF
| WOFF2
।
sort
: alpha
| date
| popularity
| style
| trending
বিকাশকারী API Google ফন্ট দ্বারা পরিবেশিত সমস্ত পরিবারের মেটাডেটাতে অ্যাক্সেস দেয়। এটি অ্যাপ্লিকেশানগুলিকে উপলব্ধ ফন্ট পরিবারগুলির জন্য Google ফন্টগুলি জিজ্ঞাসা করার অনুমতি দেয়৷ REST API JSON ফর্ম্যাটে ডেটা সরবরাহ করে যাতে প্রতিটি পরিবারে শৈলী এবং স্ক্রিপ্ট (গুগল ফন্টে উপসেট বলা হয়) অন্তর্ভুক্ত থাকে। API পরিবারের তালিকাকে বর্ণানুক্রমিকভাবে, যোগ করার তারিখ অনুসারে, শৈলীর সংখ্যা অনুসারে, প্রবণতা অনুসারে বা জনপ্রিয়তা অনুসারে সাজাতে পারে।
শ্রোতা
এই নথিটি ওয়েব এবং অ্যাপ্লিকেশন ডেভেলপারদের উদ্দেশ্যে। বিকাশকারী API ব্যবহার করার জন্য জাভাস্ক্রিপ্টের জ্ঞান প্রয়োজন।
একটি দ্রুত উদাহরণ
Google ফন্ট পরিষেবা দ্বারা প্রদত্ত ফন্টগুলির গতিশীল তালিকা পুনরুদ্ধার করতে, নিম্নলিখিত অনুরোধটি পাঠান:
https://www.googleapis.com/webfonts/v1/webfonts?key=YOUR-API-KEY
ফলাফলের একটি নমুনা এই মত দেখাবে:
{ "kind": "webfonts#webfontList", "items": [ [...] { "family": "Anonymous Pro", "variants": [ "regular", "italic", "700", "700italic" ], "subsets": [ "cyrillic", "greek", "latin", "latin-ext" ], "version": "v21", "lastModified": "2022-09-22", "files": { "regular": "http://fonts.gstatic.com/s/anonymouspro/v21/rP2Bp2a15UIB7Un-bOeISG3pLlw89CH98Ko.ttf", "italic": "http://fonts.gstatic.com/s/anonymouspro/v21/rP2fp2a15UIB7Un-bOeISG3pHl428AP44Kqr2Q.ttf", "700": "http://fonts.gstatic.com/s/anonymouspro/v21/rP2cp2a15UIB7Un-bOeISG3pFuAT0CnW7KOywKo.ttf", "700italic": "http://fonts.gstatic.com/s/anonymouspro/v21/rP2ap2a15UIB7Un-bOeISG3pHl4OTCzc6IG30KqB9Q.ttf" }, "category": "monospace", "kind": "webfonts#webfont", "menu": "http://fonts.gstatic.com/s/anonymouspro/v21/rP2Bp2a15UIB7Un-bOeISG3pHl028A.ttf" }, { "family": "Antic", "variants": [ "regular" ], "subsets": [ "latin" ], "version": "v19", "lastModified": "2022-09-22", "files": { "regular": "http://fonts.gstatic.com/s/antic/v19/TuGfUVB8XY5DRaZLodgzydtk.ttf" }, "category": "sans-serif", "kind": "webfonts#webfont", "menu": "http://fonts.gstatic.com/s/antic/v19/TuGfUVB8XY5DRZZKq9w.ttf" }, [...] ] }
Google-এ আপনার আবেদন শনাক্ত করা
প্রতিটি অনুরোধের সাথে একটি API কী অন্তর্ভুক্ত করে Google Fonts Developer API-কে অনুরোধ পাঠানোর সময় আপনার অ্যাপ্লিকেশনটিকে নিজেকে সনাক্ত করতে হবে।
একটি API কী অর্জন এবং ব্যবহার করা
একটি চাবি পানঅথবা শংসাপত্র পৃষ্ঠায় একটি তৈরি করুন।
আপনার একটি API কী থাকার পরে, আপনার অ্যাপ্লিকেশনটি সমস্ত অনুরোধের URL-এ ক্যোয়ারী প্যারামিটার key= yourAPIKey
যোগ করতে পারে।
API কী ইউআরএল-এ এম্বেড করার জন্য নিরাপদ; এটা কোন এনকোডিং প্রয়োজন নেই.
বিস্তারিত
JSON প্রতিক্রিয়া (উপরের নমুনা পড়ুন) "আইটেম" নামের একটি অ্যারে নিয়ে গঠিত যাতে প্রতিটি ফন্ট পরিবার সম্পর্কে তথ্য সহ অবজেক্ট থাকে।
একটি পারিবারিক বস্তু নিম্নলিখিত ক্ষেত্রগুলি নিয়ে গঠিত:
- kind: বস্তুর ধরনের, একটি webfont অবজেক্ট
- পরিবার: পরিবারের নাম
- উপসেট: পরিবার দ্বারা সমর্থিত স্ক্রিপ্টগুলির একটি তালিকা৷
- মেনু: পারিবারিক উপসেটের একটি url শুধুমাত্র পরিবারের নাম কভার করে।
- বৈকল্পিক: পরিবারের জন্য উপলব্ধ বিভিন্ন শৈলী
- সংস্করণ: ফন্ট ফ্যামিলি সংস্করণ।
- অক্ষ: অক্ষ পরিসীমা, পরিবর্তনশীল ফন্টের জন্য শুধুমাত্র অনুরোধের (নীচে দেখুন) উপস্থাপন করুন।
- lastModified: তারিখ (ফরম্যাট "yyyy-MM-dd") ফন্ট ফ্যামিলি শেষবারের মতো পরিবর্তন করা হয়েছে।
- ফাইল: ফন্ট ফ্যামিলি ফাইল (সমস্ত সমর্থিত স্ক্রিপ্ট সহ) উপলব্ধ ভেরিয়েন্টগুলির প্রতিটির জন্য।
প্রতিটি পরিবারের জন্য তথ্য একত্রিত করে একটি ফন্ট API অনুরোধ তৈরি করা সহজ। উদাহরণস্বরূপ অনুমান করা হচ্ছে যে আমাদের কাছে বেনামী প্রো-এর জন্য পারিবারিক বস্তুর একটি রেফারেন্স রয়েছে:
[...] var apiUrl = []; apiUrl.push('https://fonts.googleapis.com/css?family='); apiUrl.push(anonymousPro.family.replace(/ /g, '+')); if (contains('italic', anonymousPro.variants)) { apiUrl.push(':'); apiUrl.push('italic'); } if (contains('greek', anonymousPro.subsets)) { apiUrl.push('&subset='); apiUrl.push('greek'); } // url: 'https://fonts.googleapis.com/css?family=Anonymous+Pro:italic&subset=greek' var url = apiUrl.join(''); [...]
বাছাই
পরিবারের তালিকা ডিফল্টরূপে কোনো নির্দিষ্ট ক্রমে ফেরত দেওয়া হয় না। তবে সাজানোর পরামিতি ব্যবহার করে তালিকাটি সাজানো সম্ভব:
https://www.googleapis.com/webfonts/v1/webfonts?sort=popularity
সম্ভাব্য বাছাই মান হল:
- alpha: তালিকাটি বর্ণানুক্রমে সাজান
- তারিখ: যোগ করা তারিখ অনুসারে তালিকা সাজান (সর্বশেষ ফন্ট যোগ করা বা প্রথমে আপডেট করা হয়েছে)
- জনপ্রিয়তা: জনপ্রিয়তা অনুসারে তালিকা সাজান (প্রথমে সবচেয়ে জনপ্রিয় পরিবার)
- শৈলী: উপলব্ধ শৈলীর সংখ্যা অনুসারে তালিকা বাছাই করুন (প্রথমে বেশিরভাগ শৈলী সহ পরিবার)
- প্রবণতা: ব্যবহারের বৃদ্ধি দেখে পরিবার অনুসারে তালিকা বাছাই করুন (প্রথমে সবচেয়ে বেশি বৃদ্ধি পাচ্ছে পরিবার)
ফিল্টারিং
একটি নির্দিষ্ট পরিবারকে জিজ্ঞাসা করুন
https://www.googleapis.com/webfonts/v1/webfonts?family=family_name
গ্রীক উপসেট সমর্থন করে এমন সমস্ত পরিবার
https://www.googleapis.com/webfonts/v1/webfonts?subset=subset_name
অপ্টিমাইজেশান
woff2 ফরম্যাটে সংকুচিত ফন্ট ফাইল পুনরুদ্ধার করার জন্য
https://www.googleapis.com/webfonts/v1/webfonts?capability=WOFF2
পরিবর্তনশীল হরফ
পরিবর্তনশীল ফন্টগুলি ক্রমাগত শৈলীর রেঞ্জ অফার করে। ডিফল্টরূপে, স্ট্যাটিক ফন্ট ফাইলগুলির একটি সংমিশ্রণ স্ট্যান্ডার্ড পজিশনে তাত্ক্ষণিক পরিবর্তনশীল ফন্টগুলির জন্য ফেরত দেওয়া হয়। যদি capability=VF
সেট করা থাকে, তাহলে ভ্যারিয়েবল ফন্ট ফাইলটি স্ট্যাটিক ফাইলের পরিবর্তে উপলব্ধ অক্ষ রেঞ্জ মেটাডেটা সহ ফেরত দেওয়া হয়। নমুনা উদাহরণ:
https://www.googleapis.com/webfonts/v1/webfonts?capability=VF
নমুনা প্রতিক্রিয়া:
{ "kind": "webfonts#webfontList", "items": [ [...] { "family": "Noto Sans Display", "variants": [ "regular", "italic" ], "subsets": [ "cyrillic", "cyrillic-ext", "greek", "greek-ext", "latin", "latin-ext", "vietnamese" ], "version": "v20", "lastModified": "2022-09-22", "files": { "regular": "http://fonts.gstatic.com/s/notosansdisplay/v20/RLplK4fy6r6tOBEJg0IAKzqdFZVZxokvfn_BDLxR.ttf", "italic": "http://fonts.gstatic.com/s/notosansdisplay/v20/RLpjK4fy6r6tOBEJg0IAKzqdFZVZxrktdHvjCaxRgew.ttf" }, "category": "sans-serif", "kind": "webfonts#webfont", "menu": "http://fonts.gstatic.com/s/notosansdisplay/v20/RLpbK4fy6r6tOBEJg0IAKzqdFZVZxpMkXJMhnB9XjO1o90LuV-PT4Doq_AKp_3cKZTCa3g.ttf", "axes": [ { "tag": "wdth", "start": 62.5, "end": 100 }, { "tag": "wght", "start": 100, "end": 900 } ] }, [...] ] }
API URL স্পেসিফিকেশন
webfonts?key=<your_key>[&family=<family>][&subset=<subset>][&capability=<capability>...][&sort=<sort>]
your_key
: আপনার বিকাশকারী API কী।
family
: একটি ফন্ট পরিবারের নাম।
subset
: একটি ফন্ট সাবসেটের নাম।
capability
: VF
| WOFF2
।
sort
: alpha
| date
| popularity
| style
| trending