From c2fa46d875ae40dd6613ad181513e57ce2d8bc0a Mon Sep 17 00:00:00 2001 From: "ssavi.ict" Date: Mon, 27 Mar 2023 23:49:26 +0600 Subject: [PATCH 1/2] Bangla Tutorial Added --- CHANGELOG.md | 1 + README.md | 2 +- ...76\340\246\202\340\246\262\340\246\276.md" | 224 ++++++++++++++++++ docs/index.md | 1 + 4 files changed, 227 insertions(+), 1 deletion(-) create mode 100644 "docs/Tutorial-\340\246\254\340\246\276\340\246\202\340\246\262\340\246\276.md" diff --git a/CHANGELOG.md b/CHANGELOG.md index d497d2643..b19e84477 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -21,6 +21,7 @@ This can also be enabled programmatically with `warnings.simplefilter('default', ## [2.7.1] - 2023-03-27 ### Changed - renamed `fonts.FontStyle` to [`fonts.FontFace`](https://pyfpdf.github.io/fpdf2/fpdf/fonts.html#fpdf.fonts.FontFace), and `FPDF.use_font_style` to [`FPDF.use_font_face`](https://pyfpdf.github.io/fpdf2/fpdf/fpdf.html#fpdf.FPDF.FPDF.use_font_face), to avoid confusions with `FPDF.font_style` +- new translation of the tutorial in [বাংলা](https://pyfpdf.github.io/fpdf2/Tutorial-বাংলা.html) - thanks to @ssavi-ict ## [2.7.0] - 2023-03-27 ### Added diff --git a/README.md b/README.md index 5248a5064..b749c3c51 100644 --- a/README.md +++ b/README.md @@ -104,7 +104,7 @@ This library relies on community interactions. Please consider sharing a post ab ## Documentation - [Documentation Home](https://pyfpdf.github.io/fpdf2/) -- Tutorial in several languages: [English](https://pyfpdf.github.io/fpdf2/Tutorial.html) - [Deutsch](https://pyfpdf.github.io/fpdf2/Tutorial-de.html) - [español](https://pyfpdf.github.io/fpdf2/Tutorial-es.html) - [हिंदी](https://pyfpdf.github.io/fpdf2/Tutorial-हिंदी.html) - [português](https://pyfpdf.github.io/fpdf2/Tutorial-pt.html) - [Русский](https://pyfpdf.github.io/fpdf2/Tutorial-ru.html) - [Italian](https://pyfpdf.github.io/fpdf2/Tutorial-it.html) - [français](https://pyfpdf.github.io/fpdf2/Tutorial-fr.html) - [Ελληνικά](https://pyfpdf.github.io/fpdf2/Tutorial-gr.html) - [עברית](https://pyfpdf.github.io/fpdf2/Tutorial-he.html) - [简体中文](https://pyfpdf.github.io/fpdf2/Tutorial-zh.html) +- Tutorial in several languages: [English](https://pyfpdf.github.io/fpdf2/Tutorial.html) - [Deutsch](https://pyfpdf.github.io/fpdf2/Tutorial-de.html) - [español](https://pyfpdf.github.io/fpdf2/Tutorial-es.html) - [हिंदी](https://pyfpdf.github.io/fpdf2/Tutorial-हिंदी.html) - [português](https://pyfpdf.github.io/fpdf2/Tutorial-pt.html) - [Русский](https://pyfpdf.github.io/fpdf2/Tutorial-ru.html) - [Italian](https://pyfpdf.github.io/fpdf2/Tutorial-it.html) - [français](https://pyfpdf.github.io/fpdf2/Tutorial-fr.html) - [Ελληνικά](https://pyfpdf.github.io/fpdf2/Tutorial-gr.html) - [עברית](https://pyfpdf.github.io/fpdf2/Tutorial-he.html) - [简体中文](https://pyfpdf.github.io/fpdf2/Tutorial-zh.html) - [বাংলা](https://pyfpdf.github.io/fpdf2/Tutorial-বাংলা.html) - Release notes: [CHANGELOG.md](https://github.com/PyFPDF/fpdf2/blob/master/CHANGELOG.md) - A series of blog posts: [fpdf2 tag @ ludochaordic](https://chezsoi.org/lucas/blog/tag/fpdf2.html) diff --git "a/docs/Tutorial-\340\246\254\340\246\276\340\246\202\340\246\262\340\246\276.md" "b/docs/Tutorial-\340\246\254\340\246\276\340\246\202\340\246\262\340\246\276.md" new file mode 100644 index 000000000..fc1619764 --- /dev/null +++ "b/docs/Tutorial-\340\246\254\340\246\276\340\246\202\340\246\262\340\246\276.md" @@ -0,0 +1,224 @@ +# Tutorial # + +Method গুলোর সম্পূর্ণ ডকুমেন্টেশন: [`fpdf.FPDF` API doc](https://pyfpdf.github.io/fpdf2/fpdf/fpdf.html#fpdf.fpdf.FPDF) + +[ TOC ] + +## টিউটোরিয়াল ১ - সংক্ষিপ্ত উদাহরণ ## + +একটি ক্লাসিক উদাহরণ দিয়ে শুরু করা যাক: + +```python +{% include "../tutorial/tuto1.py" %} +``` + +[Resulting PDF](https://github.com/PyFPDF/fpdf2/raw/master/tutorial/tuto1.pdf) + +প্রয়োজনীয় লাইব্রেরীগুলো যুক্ত করার পর, আমরা একটা `FPDF` অব্জেক্ট তৈরি করবো. +[FPDF](fpdf/fpdf.html#fpdf.fpdf.FPDF) কনস্ট্রাক্টরটি এখানে ডিফল্ট ভ্যালুগুলো ব্যবহার করছে: +পৃষ্ঠাগুলো A4 পোর্ট্রেট সাইজের এবং পরিমাপক একক হচ্ছে মিলিমিটার. +এটাকে বাহ্যিকভাবে উল্লেখ করা যায় নিচের স্নিপেট এর মত করে - + +```python +pdf = FPDF(orientation="P", unit="mm", format="A4") +``` + +পিডিএফ কে ল্যান্ডস্কেপ মোড (`L`) অথবা অন্যান্য ফরম্যাট এও পৃষ্ঠা বিন্যাস করা যায় (যেমন `Letter` এবং `Legal`) +এবং পরিমাপক একক (`pt`, `cm`, `in`)। + + +এই মুহুর্তে এখানে কোন পৃষ্ঠা নেই, তাই আমাদের একটা পৃষ্ঠা যুক্ত করতে হবে +[add_page](fpdf/fpdf.html#fpdf.fpdf.FPDF.add_page)। শুরুটা উপর-নাম কোণায় এবং বর্তমান অবস্থানটি +সীমান্ত থেকে গতানুগতিকভাবে ১ সেন্টিমিটার নিচের দিকে অবস্থান করে; মার্জিন পরিবর্তন করা যাবে +[set_margins](fpdf/fpdf.html#fpdf.fpdf.FPDF.set_margins)। + +লিখা প্রিন্ট করার পূর্বেই ফন্ট সিলেক্ট করে নিতে হয় [set_font](fpdf/fpdf.html#fpdf.fpdf.FPDF.set_font), +নতুবা ডকুমেন্ট টা অকার্যকর হয়ে যাবে। আমরা Helvetica bold 16 পছন্দ করলামঃ + +```python +pdf.set_font('helvetica', 'B', 16) +``` + +ইটালিক সেট করতে চাইলে `I`, আন্ডারলাইন করতে চাইলে `U` অথবা একটি সাধারণ ফন্টে একটি খালি স্ট্রিং +(অথবা যেকোন কম্বিনেশন)। উল্লেখ্য ফন্ট সাইজ পয়েন্টে দেয়া আছে, মিলিমিটারে নয় (অন্য কোন এককেও নয়); +এটাই একমাত্র ব্যাতিক্রম। অন্যান্য মৌলিক ফন্টগুলো হলো, `Times`, `Courier`, `Symbol` এবং `ZapfDingbats` + +এখন আমরা একটি cell প্রিন্ট করতে পারি [cell](fpdf/fpdf.html#fpdf.fpdf.FPDF.cell)। cell হলো একটি আয়তাকৃতি +ক্ষেত্র, হয়তো ফ্রেম করা, যেখানে কিছু টেক্সট থাকবে। এটা রেন্ডার হয় বর্তমান অবস্থানে। আমরা ডাইমেনশন, +টেক্সট (মাঝামাঝি কিংবা সাজানো) নির্দিষ্ট করতে পারি, যদি বর্ডার আকানো হয়, এবং বর্তমান অবস্থান বর্ডারের পরে এগিয়ে যাবে +(ডানে, নিচে অথবা পরবর্তী লাইনের শুরুতে)। ফ্রেম যুক্ত করার আমরা নিচের মত করতে পারিঃ + +```python +pdf.cell(40, 10, 'Hello World!', 1) +``` + +এর পর কেন্দ্র বরাবর একটি নতুন cell যুক্ত করে এবং পরের লাইনে এগোনোর জন্য আমরা নিচের মত করতে পারিঃ + +```python +pdf.cell(60, 10, 'Powered by FPDF.', new_x="LMARGIN", new_y="NEXT", align='C') +``` + +**মন্তব্য**: পরবর্তী লাইনে আমরা এভাবেও যেতে পারি [ln](fpdf/fpdf.html#fpdf.fpdf.FPDF.ln)। এই মেথডের +মাধ্যমে লাইন ব্রেক এর উচ্চতাও যুক্ত করা যায়। + +সবশেষে, ডকুমেন্টটি বন্ধ করা হয় এবং [output](fpdf/fpdf.html#fpdf.fpdf.FPDF.output) এই ফাইল পাথ +এ সেভ করা হলো। কোন প্যারামিটার ছাড়া `output()` পিডিএফ এর একটি `bytearray` রিটার্ন করে। + +## টিউটোরিয়াল ২ - হেডার, ফুটার, পেজ ব্রেক এবং ইমেজ ## + +হেডার, ফুটার এবং লোগো সহ একটা দুই পৃষ্ঠার উদাহরণ দেয়া হলোঃ + +```python +{% include "../tutorial/tuto2.py" %} +``` + +[Resulting PDF](https://github.com/PyFPDF/fpdf2/raw/master/tutorial/tuto2.pdf) + +এই উদাহরণটি headers এবং footers প্রসেস করার জন্য [header](fpdf/fpdf.html#fpdf.fpdf.FPDF.header) এবং +[footer](fpdf/fpdf.html#fpdf.fpdf.FPDF.footer) মেথডকে ব্যবহারকে দেখায়। এরা স্বয়ংক্রিয়ভাবেই চালিত হয়। +এরা FPDF ক্লাসেই থাকে কিন্তু কোন আলাদা প্রসেস করে না, তাই এই ক্লাসগুলোকে এক্সটেন্ড করতে হবে এবং +ওভাররাইড করতে হবে। + +অবস্থান উপরের কোণা এবং চওড়ার পরিমান নির্দ্দিষ্ট করে লোগোটি প্রিন্ট করা হয় +[image](fpdf/fpdf.html#fpdf.fpdf.FPDF.image) মেথডকে কল করলে। ছবির অনুপাতকে ঠিক রাখার জন্য + উচ্চতাটা স্বয়ংক্রিয়ভাবেই নিরূপিত হয়। + +পৃষ্ঠা নম্বর প্রিন্ট করার জন্য, একটি শূণ্য মান cell width হিসেবে পাঠানো হয়। এর মানে cell টি +পৃষ্ঠার ডান মার্জিন পর্যন্ত প্রসারিত হওয়া উচিত; যেটা লিখা গুলোকে কেন্দ্র বরাবর সারিবদ্ধ করা হলো। +[page_no](fpdf/fpdf.html#fpdf.fpdf.FPDF.page_no) মেথড বর্তমান পৃষ্ঠা নাম্বারটি রিটার্ন করে; +মোট পৃষ্ঠা নাম্বারটা একটি বিশেষ ভ্যালু `{nb}` এর মাধ্যমে পাওয়া যায় যেটা ডকুমেন্ট ক্লোজারের এর +সময় প্রতিস্থাপিত হয়। (এই বিশেষ ভ্যালু পরিবর্তন করা যায় +[alias_nb_pages()](fpdf/fpdf.html#fpdf.fpdf.FPDF.alias_nb_pages) এর মাধ্যমে)। উল্লেখ্য, + উপর কিংবা নিচ থেকে শুরু করে পৃষ্ঠার অবস্থান [set_y](fpdf/fpdf.html#fpdf.fpdf.FPDF.set_y) + মেথডের ব্যবহার করে সেট করা যায়। + +এখানে আরেকটি মজার বৈশিষ্ট্য ব্যবহার করা হয়েছেঃ অটোমেটিক পেজ ব্রেকিং। যখনই একটা cell একটা +পেজ লিমিট ক্রস করে যায় ( নিচ থেকে ২ সেন্টিমিটার ), পেজ ব্রেক এ্যাপ্লাই হয় এবং ফন্ট রিস্টোর হয়। +যদিও হেডার এবং ফুটার নিজ নিজ ফন্ট (`helvetica`) সিলেক্ট করে, পেজ বডি `Times` হিসেবেই +এগোতে থাকে। অটোমেটিক রিস্টোর এর ব্যাপার টা কালার এবং লাইন উইডথ এর ব্যাপারেও প্রযোজ্য হয়। +পেজ ব্রেক এর লিমিট টি [set_auto_page_break](fpdf/fpdf.html#fpdf.fpdf.FPDF.set_auto_page_break) +মেথডের মাধ্যমেও সেট করা যায়। + +## টিউটোরিয়াল ৩ - লাইন ব্রেক এবং কালারস ## + +জাস্টিফাইড প্যারাগ্রাফে প্রিন্ট করা একটি উদাহরণ এর সাথে এগোনো যাক। যা একইসাথে colors নিয়েও ধারণা দেবে। + +```python +{% include "../tutorial/tuto3.py" %} +``` + +[Resulting PDF](https://github.com/PyFPDF/fpdf2/raw/master/tutorial/tuto3.pdf) + +[Jules Verne text](https://github.com/PyFPDF/fpdf2/raw/master/tutorial/20k_c1.txt) + +[get_string_width](fpdf/fpdf.html#fpdf.fpdf.FPDF.get_string_width) মেথড বর্তমান ফন্টে একটি স্ট্রিং এর +দৈর্ঘ্য নির্ণয় করে দেয়, যা এখানে অবস্থা এবং টাইটেল সমেত ফ্রেম ও এর আশপাশসহ উইদথ মাপজোকের জন্য ব্যবহার +করা যায়। colors সেট করা যায় ([set_draw_color](fpdf/fpdf.html#fpdf.fpdf.FPDF.set_draw_color), +[set_fill_color](fpdf/fpdf.html#fpdf.fpdf.FPDF.set_fill_color) এবং +[set_text_color](fpdf/fpdf.html#fpdf.fpdf.FPDF.set_text_color) মাধ্যমে) এবং লাইনের পুরুত্ব বা থিকনেস সেট +করা হলো 1 mm ( 0.2 এর বিপরীতে বাই ডিফল্ট) [set_line_width](fpdf/fpdf.html#fpdf.fpdf.FPDF.set_line_width) +এর মাধ্যমে। অবশেষে, আমরা cell টা আউটপুট দিলাম (সর্বশেষ প্যারামিটার টা true যার মানে ব্যাকগ্রাউন্ড আবশ্যিকভাবে +পরিপূর্ণ থাকতে হবে)। + +প্যারাগ্রাফ প্রিন্ট করার জন্য [multi_cell](fpdf/fpdf.html#fpdf.fpdf.FPDF.multi_cell) মেথড ব্যবহার করা হয়েছে। লিখাগুলো জাস্টিফাইড এলাইনমেন্টে +এ থাকে গতানুগতিকভাবে। প্রত্যেক লাইন যখন cell এর শেষ এ পৌছায় অথবা একটি carriage return ক্যারেক্টার (`\n`) পাওয়া যায়, একটি লাইন ব্রেক +এ্যাপ্লাই করা হয় এবং একটি নতুন cell অটোমেটিক্যালি বর্তমানটির নিচে তৈরি হয়। +সঠিক লিমিটের পূর্বেই কাছাকাছি স্পেস কিংবা সফট হাইফেন (`\u00ad`) ক্যারেক্টার এর জায়গায় একটা অটোমেটিক ব্রেক তৈরি হয়। +যখন একটি লাইন ব্রেক এ্যাপ্লাই করা হয় তখন একটা সফট-হাইফেন একটি নরমাল হাইফেন এর দ্বারা প্রতিস্থাপিত হয় নতুবা ইগ্নোর হয়। + +ডকুমেন্ট দুটো প্রপার্টি সংঙ্গায়িত করা হয়ঃ title ([set_title](fpdf/fpdf.html#fpdf.fpdf.FPDF.set_title)) মেথড এবং +author ([set_author](fpdf/fpdf.html#fpdf.fpdf.FPDF.set_author)) মেথড। প্রপার্টি দুই উপায়ে দেখা যায়। +প্রথমটি হলো ডকুমেন্টকে ডিরেক্টলি Acrobat Reader দিয়ে ওপেন করা হয়, File মেন্যূ তে গিয়ে Document Properties +অপশনটি চুজ করা হয়। পরেরটি হলো, প্লাগিন থেকে রাইট ক্লিক করে ডকুমেন্ট প্রপার্টি সিলেক্ট করে। + +## টিউটোরিয়াল ৪ - মাল্টি কলাম ## + +এই উদাহরণটি পূর্বের উদাহরণ এর অন্যরকম সংস্করণ, যা আসলে কিভাবে কয়েকটি কলাম এর মধ্যে টেক্সট রাখতে হয় +সেটা দেখানো হয়েছে। + +```python +{% include "../tutorial/tuto4.py" %} +``` + +[Resulting PDF](https://github.com/PyFPDF/fpdf2/raw/master/tutorial/tuto4.pdf) + +[Jules Verne text](https://github.com/PyFPDF/fpdf2/raw/master/tutorial/20k_c1.txt) + +পূর্বের টিউটরিয়ালের সাথে এর মূল পার্থক্য হলো +[accept_page_break](fpdf/fpdf.html#fpdf.fpdf.FPDF.accept_page_break) এবং the set_col মেথডের ব্যবহার। + +[accept_page_break](fpdf/fpdf.html#fpdf.fpdf.FPDF.accept_page_break) মেথড ব্যবহার করে, যদি cell পৃষ্ঠার বর্তমান + সর্বনিম্ন লিমিট পার করে, এই মেথড তখন বর্তমান কলাম নাম্বার চেক করে। যখন তা ২ এর ছোট হয় (আমরা একটি পৃষ্ঠাকে তিনটি + কলামে ভাগ করেছি), তখন set_col মেথডটি কল হয়, কলাম নাম্বার বেড়ে যায় এবং লিখার অবস্থান পরবর্তী কলামে চলে যায় যাতে + করে লিখা সেখানেই চলমান থাকে। + +যখন ৩য় কলামের সর্বনিম্ন লিমিটে পৌছায়, [accept_page_break](fpdf/fpdf.html#fpdf.fpdf.FPDF.accept_page_break) মেথডটি +রিসেট হয় এবং একটি পেজ ব্রেক এপ্লাই করে আবার প্রথম কলামে চলে যায়। + +## টিউটোরিয়াল ৫ - টেবিল তৈরি করা ## + +এই টিউটোরিয়ালটি কিভাবে হালকা কিছু পরিবর্তন করেই সহজেই ভিন্ন দুইটি টেবিল তৈরি করা যায় সেটা ব্যাখ্যা করবে। +না না কাঠের না! সারি-কলাম এর টেবিল। + +```python +{% include "../tutorial/tuto5.py" %} +``` + +[Resulting PDF](https://github.com/PyFPDF/fpdf2/raw/master/tutorial/tuto5.pdf) - +[Countries CSV data](https://github.com/PyFPDF/fpdf2/raw/master/tutorial/countries.txt) + +প্রথম উদাহরণটি [`FPDF.table()`](https://pyfpdf.github.io/fpdf2/Tables.html) এর ভেতরে ডেটা সরবরাহের মাধ্যমে +খুবই সাধারণভাবেই তৈরি করা যায়। ফলাফল খুবই সাধারণ কিন্তু খুব সহজেই তৈরি করা যায় এমন। + +পরবর্তী টেবিলে কিছু পরিবর্তন আনা হয়েছেঃ কালার, টেবিলের নিয়ন্ত্রিত বিস্তার, হ্রাসকৃত লাইনের উচ্চতা, মাঝ বরাবর এলাইন করা শিরোনাম, + ডান দিকে এলাইন করা ছবি ... এসবের মাধ্যমে। + তাছাড়া, আনুভূমিক লাইনগুলোও সরানো হয়েছে। এটা করা হয়েছে এভেইলেবল ভ্যালু গুলো থেকে `borders_layout` এর একটি ভ্যালু + নেবার মাধ্যমে [`TableBordersLayout`](https://pyfpdf.github.io/fpdf2/fpdf/enums.html#fpdf.enums.TableBordersLayout). + + +## টিউটোরিয়াল ৬ - লিংক এবং মিশ্র টেক্সট স্টাইল তৈরি করা ## + +এই টিউটোরিয়ালটি PDF এর মধ্যে লিংক প্রবেশ করানো সহ বিভিন্ন বাহ্যিক উৎসের লিংক যুক্ত করার বিষয়ে বর্ণনা করবে। +একইসাথে লিখার বিভিন্ন রকম স্টাইল (bold, italic, underline) এর ব্যাপারেও আলোকপাত করবে। + +```python +{% include "../tutorial/tuto6.py" %} +``` + +[Resulting PDF](https://github.com/PyFPDF/fpdf2/raw/master/tutorial/tuto6.pdf) - +[fpdf2-logo](https://raw.githubusercontent.com/PyFPDF/fpdf2/master/docs/fpdf2-logo.png) + +লিখার প্রিন্ট করার নতুন মেথড এখানে দেখানো হলো - + [write()](https://pyfpdf.github.io/fpdf2/fpdf/fpdf.html#fpdf.fpdf.FPDF.write) +। যা + [multi_cell()](https://pyfpdf.github.io/fpdf2/fpdf/fpdf.html#fpdf.fpdf.FPDF.multi_cell) + এর খুব কাছাকাছি, মূল পার্থক্য হলো: + +- লাইনের শেষ হয় ডানপ্রান্ত থেকে এবং পরের লাইনের শুরু হয় বামপ্রান্ত থেকে। +- বর্তমান অবস্থান লিখার একদম শেষে গিয়ে পৌছায়। + +এই মেথডের মাধ্যমে কিছু টেক্সট একসাথে লিখা যায়, ফন্ট স্টাইল পরিবর্তন করা যায়, এবং যেই স্থান হতে লিখা + বন্ধ করা হয়েছে পুনরায় সেখান থেকেই শুরু করা যায়। +অন্যদিকে এই মেথডের মূল প্রতিবন্ধকতা হচ্ছে, টেক্সটগুলোকে জাস্টিফাই করা যায় না যেমনটা আমরা + [multi_cell()](https://pyfpdf.github.io/fpdf2/fpdf/fpdf.html#fpdf.fpdf.FPDF.multi_cell) মেথডের + মাধ্যমে করতে পারি। + +উদাহরণের প্রথম পৃষ্ঠায়, আমরা এই উদ্দেশ্যে + [write()](https://pyfpdf.github.io/fpdf2/fpdf/fpdf.html#fpdf.fpdf.FPDF.write) মেথড ব্যবহার করেছিলাম। + বাক্যের শুরুটা সাধারণ টেক্সট স্টাইলেই লিখা হয়েছে, এরপরে + [set_font()](https://pyfpdf.github.io/fpdf2/fpdf/fpdf.html#fpdf.fpdf.FPDF.set_font) মেথড ব্যবহার করে, + আমরা আন্ডারলাইন করে বাক্যটি শেষ করলাম। + +পরবর্তী পৃষ্ঠার একটি আন্তর্বর্তী লিংক যুক্ত করার জন্য, আমরা + [add_link()](https://pyfpdf.github.io/fpdf2/fpdf/fpdf.html#fpdf.fpdf.FPDF.add_link) মেথডটি ব্যবহার করেছি, + যা ক্লিক করার মত একটি এলাকা তৈরি করে দিলো যেটাকে আমরা "লিংক" বলছি যা ডকুমেন্ট এর ভেতরেরই অন্য একটি + পৃষ্ঠায় নিয়ে যায়। + +ছবির মাধ্যমে একটি বাহ্যিক লিংক তৈরি করার জন্য, আমরা + [image()](https://pyfpdf.github.io/fpdf2/fpdf/fpdf.html#fpdf.fpdf.FPDF.image) মেথডটি ব্যবহার করেছি। + এই মেথডের মাধ্যমে আর্গুমেন্ট হিসেবে লিংক পাস করার মত সুবিধা আছে। এই লিংক ডকুমেন্ট এর ভেতরকার বা বাইরের যেকোন + লিংকই হতে পারে। + +বিকল্প হিসেবে ফন্ট স্টাইল এবং লিংক যুক্ত করার অন্য আরেকটি মাধ্যম আছে, সেটি হলো `write_html()` + মেথড ব্যবহার করা। এটা একটা html পারসার, যার মাধ্যমে html ব্যবহার করে টেক্সট যুক্ত করার, ফন্ট + স্টাইল পরিবর্তন করা এবং লিংক যুক্ত করা যায়। diff --git a/docs/index.md b/docs/index.md index 628463800..367bdb662 100644 --- a/docs/index.md +++ b/docs/index.md @@ -62,6 +62,7 @@ Go try it **now** online in a Jupyter notebook: [![Open In Colab](https://colab. * [Ελληνικά](Tutorial-gr.md) * [עברית](Tutorial-he.md) * [简体中文](Tutorial-zh.md) +* [বাংলা](Tutorial-%E0%A6%AC%E0%A6%BE%E0%A6%82%E0%A6%B2%E0%A6%BE.md) ## Installation ## From c89724789f6f311cec80ded557a63d7fae398998 Mon Sep 17 00:00:00 2001 From: "ssavi.ict" Date: Fri, 31 Mar 2023 22:36:57 +0600 Subject: [PATCH 2/2] [Added] Doc on generating Code128 Barcode --- CHANGELOG.md | 3 +++ docs/Barcodes.md | 34 ++++++++++++++++++++++++++++++++++ docs/code128_barcode.png | Bin 0 -> 38069 bytes 3 files changed, 37 insertions(+) create mode 100644 docs/code128_barcode.png diff --git a/CHANGELOG.md b/CHANGELOG.md index 425f5b5fa..eb2125434 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -20,6 +20,9 @@ This can also be enabled programmatically with `warnings.simplefilter('default', ### Fixed - the SVG parser now accepts `` with `width` / `height` defined as percents +### Added +- documentation on how to generate Code128 barcodes using the `python-barcode` lib: [documentation section](https://pyfpdf.github.io/fpdf2/Barcodes.html#Code128) + ## [2.7.1] - 2023-03-27 ### Changed - renamed `fonts.FontStyle` to [`fonts.FontFace`](https://pyfpdf.github.io/fpdf2/fpdf/fonts.html#fpdf.fonts.FontFace), and `FPDF.use_font_style` to [`FPDF.use_font_face`](https://pyfpdf.github.io/fpdf2/fpdf/fpdf.html#fpdf.FPDF.FPDF.use_font_face), to avoid confusions with `FPDF.font_style` diff --git a/docs/Barcodes.md b/docs/Barcodes.md index 915d94790..08134d0ab 100644 --- a/docs/Barcodes.md +++ b/docs/Barcodes.md @@ -138,3 +138,37 @@ pdf.set_font("Helvetica", size=24) pdf.datamatrix("Hello world!", w=100) pdf.output("datamatrix.pdf") ``` + +## Code128 ## + +Here is an example on how to generate a [Code 128](https://en.wikipedia.org/wiki/Code_128) barcode +using the [`python-barcode`](https://github.com/WhyNotHugo/python-barcode) lib: + +``` +from io import BytesIO +from fpdf import FPDF +from barcode import Code128 +from barcode.writer import SVGWriter + +# Create a new PDF document +pdf = FPDF() +pdf.add_page() + +# Set the position and size of the image in the PDF +x = 50 +y = 50 +w = 100 +h = 70 + +# Generate a Code128 Barcode +byte_stream_object = BytesIO() +Code128(str("100000902922"), writer=SVGWriter()).write(byte_stream_object) +pdf.image(byte_stream_object, x=x, y=y, w=w, h=h) + +# Output a PDF named code128_barcode.pdf +pdf.output('code128_barcode.pdf') +``` + +Output Preview: +![](code128_barcode.png) + diff --git a/docs/code128_barcode.png b/docs/code128_barcode.png new file mode 100644 index 0000000000000000000000000000000000000000..7cabfa3c91c4397acce353974a8fff1a172a5612 GIT binary patch literal 38069 zcmeHQZA_C_6uu0mL(({HbV{epjlmMakWES!P*!wG)!N25msulo#7UtA7n!Lnz-&aF z8M@(y3!T+z z+f^Es5bcNK9&LS+p2zOUdwZu4v&;BDYWTebvk;%JRXd=h)Frn6bWbA!$rTkO3)8l8I(crkE`<_efJSk*tG2>|(U1_$;KR|kw&VDu`SFhLVvPfaN>e869>+n_d~C5??}w%L-~7Dzdx&}^kSO5%+MYbA{y&CurO zCX}qzBaE)%;t&HFvMnP`;;mf8?;v^~RGBUpZu{(s_tiPHxMPE*W}negkFD;*Dg>+DKU? z0S9>`<%~kJPs(&bu_ef(l&TJy|IdP6(jB#U(-63hu0J}rj9l{nVwn(u>igN;-6X2Wxhh;b{!(katjB#R& z6JwN3plkwV6H*-tYKKregxVn#(4l}11$3w)MHMNkNVz^0rPL^;MkzJ=3D8e~egZVr zps5B;HQdF6&N6hCNfjmNEJJ%G+AC?th)L5v`3>o&?bO30kjD~ zt^jfckSo9)0`3rShZs!?;9CIS0{9jX=zu^61UkSl0)`PVjKCrV7Adeu0mutLUI6j} zl^UqjK&56(W2vGr49XTO4H~{vsL~9!a!9z`|GX4B%s&ovK-F3 zbk(IXW!V*)Gb_55S z8{LURnWmGCr)>7?fy5!Dsl|4x#_nFCp6D^w{&uYCXwX@;mUnDf{NcR0<|H9Fb zho`xKfZWg~%(KuxE{HD#bTgbtnv)du>GCHX@3&vp$vNYddNV98d}K+9?rhE_w0 zDPyU+Q=>PWF}&bkLT^nwMyu1xCTZ$8txiIh{OYcytX|z!8r&3I$+lLcR*agClvS}g zJwLbhBuLR_YRT%C>3{5dLlH~iWfxgeY40P>3CiX6_c^!l(PQh1h&``9dLHzP)Is5YIgPbh`K`Zuiw_@lAF1?I`h6 f?*A-)XQU@Q{ldZX!GyqKL4WEu)~z_3`;O&rihgUC literal 0 HcmV?d00001