1. পণ্য
  2.   OMR
  3.   C++
  4.   Aspose.OMR for C++

Aspose.OMR for C++

 
 

OMR ফর্ম তৈরি ও ডেটা রেকগনিশনের জন্য C++ লাইব্রেরি

C++ ডেভেলপারদের জন্য একটি আধুনিক অপটিক্যাল মার্ক রেকগনিশন (OMR) সমাধান, যা C++ অ্যাপ্লিকেশনে OMR টেমপ্লেট/ফর্ম তৈরি এবং স্ক্যান করা ইমেজ ও ফটো রেকগনিশন করতে সক্ষম।

Aspose.OMR for C++ কি?

Aspose.OMR for C++ হল একটি শক্তিশালী এবং নমনীয় C++ OMR API, যা C++ অ্যাপ্লিকেশনের মধ্যে অপটিক্যাল মার্ক রেকগনিশন কাজগুলোকে সহজ করে। জরিপ সিস্টেম, পরীক্ষার প্রক্রিয়াকরণ টুল বা কাস্টম OMR অ্যাপ তৈরি করতে চাওয়া ডেভেলপারদের জন্য আদর্শ, এই SDK সহজ ইন্টিগ্রেশন, গভীর ডকুমেন্টেশন, নমুনা কোড এবং ক্রস-প্ল্যাটফর্ম সাপোর্ট প্রদান করে। বহুনির্বাচনী, গ্রিড, এবং টেক্সট-ভিত্তিক প্রশ্ন টাইপ প্রোসেস করার ক্ষমতা সহ, এটি স্ক্যান করা ইমেজ ও ফটো সঠিকভাবে পড়তে পারদর্শী। ডেভেলপাররা রেকগনিশন ফলাফল CSV ফরম্যাটে এক্সপোর্ট করতে পারে, যা বিভিন্ন প্ল্যাটফর্মে টেস্ট, ফর্ম বা প্রশ্নাবলি থেকে ডেটা বিশ্লেষণকে সহজ করে, কোনো সামঞ্জস্য সমস্যার বিষয়ে চিন্তা না করে।

আপনি যদি কাস্টম C++ OMR সফটওয়্যার ডেভেলপ করছেন বা C++ এর জন্য নির্ভরযোগ্য OMR SDK খুঁজছেন, Aspose.OMR একটি বিস্তৃত সমাধান হিসেবে আলাদা। এটি চেকবক্স সনাক্তকরণ, গ্রিড ফিল্ড, এবং নমনীয় OMR টেমপ্লেটের মতো উন্নত ফিচার সমর্থন করে। লাইব্রেরি অন্যান্য Aspose API গুলোর সঙ্গে মসৃণভাবে ইন্টিগ্রেট হয়, ডেভেলপারদের তাদের অ্যাপ্লিকেশনকে অতিরিক্ত ফাইল ফরম্যাট বা ডকুমেন্ট অটোমেশন ফিচার দিয়ে সমৃদ্ধ করতে দেয়। C++ দিয়ে উচ্চ-নির্ভুলতা OMR ইমেজ অ্যানালাইসিস থেকে স্কেলযোগ্য ফর্ম প্রসেসিং সিস্টেম তৈরির ক্ষেত্রে, Aspose.OMR for C++ ডেভেলপারদের দ্রুত ও নির্ভরযোগ্যভাবে কার্যকর এবং ফিচার-সমৃদ্ধ OMR সমাধান তৈরি করতে সক্ষম করে।

Previous Next

Aspose.OMR for C++ দিয়ে শুরু করা

ASP.NET-এ Aspose.OMR for C++ ইনস্টল করার সুপারিশকৃত উপায় হল NuGet এর মাধ্যমে। সুসঙ্গত ইনস্টলেশনের জন্য নিম্নলিখিত কমান্ডটি ব্যবহার করুন।

NuGet এর মাধ্যমে Aspose.OMR for C++ ইনস্টল করুন

 
Install-Package Aspose.OMR.Cpp

আপনি সরাসরি Aspose.OMR পণ্য পেজ থেকে লাইব্রেরি ডাউনলোড করতে পারেন।

C++ API দিয়ে OMR টেমপ্লেট/ফর্ম জেনারেট করুন

Aspose.OMR for C++ API টেমপ্লেট তৈরিকে সহজ করে, যা OMR সিস্টেমের একটি গুরুত্বপূর্ণ দিক। C++ OMR API ব্যবহার করে সফ্টওয়্যার ডেভেলপাররা বিভিন্ন ধরনের ফর্মের জন্য টেমপ্লেট ডিজাইন করতে পারেন, যা স্ক্যানিং প্রক্রিয়ায় সঠিক ডেটা এক্সট্র্যাকশন নিশ্চিত করে। API ব্যবহার করে কাগজের আকার, ওরিয়েন্টেশন, ফন্ট, রঙ এবং অন্যান্য লেআউট সেটিংস কাস্টমাইজ করা যায় যা সব টেমপ্লেট পৃষ্ঠায় প্রযোজ্য থাকে এবং আরও অনেক কিছু। এই ফিচারটি বিভিন্ন ক্ষেত্র যেমন জরিপ, পরীক্ষা এবং মূল্যায়নে OMR ক্ষমতার ইন্টিগ্রেশনকে সহজ করে। নিম্নলিখিত উদাহরণটি দেখায় কীভাবে একটি ফর্ম ইমেজ জেনারেট করা যায় যা মুদ্রণ করা যায় এবং C++ অ্যাপ্লিকেশনের মধ্যে উত্তরদাতাদের কাছে হ্যান্ডল করা যায়।

C++ অ্যাপ্লিকেশনের মধ্যে ফর্ম ইমেজ কীভাবে তৈরি করবেন?

//Generate the form for ANSI Letter paper size

System::SharedPtr engine = System::MakeObject();
// Generate the form for ANSI Letter paper size (8.5 by 11 inches)
System::SharedPtr settings = System::MakeObject();
settings->setPaperSize(Api::PaperSize::Letter);
System::SharedPtr result = engine->GenerateTemplate(markupPath, nullptr, settings);

C++ API ব্যবহার করে OMR ফর্ম রেকগনাইজ করুন

Aspose.OMR for C++ উন্নত OMR কার্যকারিতা যুক্ত, যা সফটওয়্যার ডেভেলপারদেরকে সহজে জটিল ফর্ম ডিজাইন ও প্রোসেস করতে সক্ষম করে। API ব্যবহার করে অপটিক্যাল মার্ক রেকগনিশন (OMR) ফর্ম রেকগনাইজ করা একটি সরল প্রক্রিয়া, যার মধ্যে কয়েকটি মূল ধাপ রয়েছে। ইনস্টলেশনের পর ব্যবহারকারীর প্রথম কাজ হলো সেই OMR টেমপ্লেট লোড করা যা আপনি রেকগনাইজ করতে চাওয়া ফর্মের সাথে মেলে। তারপর OMR ফর্মের স্ক্যানড ইমেজ লোড করে লোড করা টেমপ্লেট দিয়ে প্রোসেস করুন, রেকগনাইজড ডেটা সংগ্রহ করুন এবং প্রয়োজন হলে সংরক্ষণ করুন। নিম্নলিখিত উদাহরণটি দেখায় কীভাবে C++ অ্যাপ্লিকেশনের মধ্যে OMR ফর্ম রেকগনাইজ এবং ডেটা এক্সট্র্যাক্ট করা যায়।

C++ API ব্যবহার করে OMR ফর্ম থেকে ডেটা রেকগনাইজ ও এক্সট্র্যাক্ট কীভাবে করবেন?

#include 

omr::AsposeOmrApi api;
api.LoadTemplate("path/to/your/template.omr");

// Load and Process the Image

api.LoadImage("path/to/your/scanned/image.jpg");
api.Process();

// Access Recognized Data

omr::OmrPageReader reader = api.GetOmrPageReader();
std::vector pages = reader.ExtractPages();
omr::OmrPage page = pages[0]; // Assuming there's only one page in the form

// Access and handle recognized data

// Example: Extracting data from the grid
omr::Grid grid = page.GetGrids()[0]; // Assuming there's only one grid on the page
std::vector> data = grid.ExtractData();

// Finalize and Cleanup

api.Finalize();

উচ্চগতির ও কার্যকর OMR স্ক্যানিং

দক্ষতা গুরুত্বপূর্ণ, বিশেষ করে যখন বড় পরিমাণে স্ক্যান করা ডকুমেন্টের সঙ্গে কাজ করা হয়। Aspose.OMR for C++ উচ্চগতির স্ক্যানিংয়ে উৎকৃষ্ট, যা OMR শিট থেকে দ্রুত ও সুনির্দিষ্ট ডেটা এক্সট্র্যাকশনকে সক্ষম করে। এই ফিচারটি বিশেষভাবে গুরুত্বপূর্ণ এমন অ্যাপ্লিকেশনগুলির জন্য যেখানে সময় অতি গুরুত্বপূর্ণ, যেমন সময় নির্ধারিত পরীক্ষা বা জরিপ। API অনেক ধরনের OMR উপাদানকে সমর্থন করে, যার মধ্যে চেকবক্স, গ্রিড এবং টেক্সট এরিয়া অন্তর্ভুক্ত। এই সমগ্র সমর্থন ডেভেলপারদেরকে বিভিন্ন ধরণের ডকুমেন্ট হ্যান্ডেল করতে সহায়তা করে, ফলে OMR কার্যকারিতা প্রয়োজনীয় অ্যাপ্লিকেশনগুলির জন্য এটি একটি বহুমুখী পছন্দ।

একাধিক পৃষ্ঠার ডকুমেন্ট প্রসেসিং

Aspose.OMR for C++ একাধিক পৃষ্ঠার ডকুমেন্ট প্রসেসিংয়ে উৎকৃষ্ট, যা ডেভেলপারদেরকে বিশাল ডেটাসেট সহজে হ্যান্ডেল করতে দেয়। এই ক্ষমতা বিশেষভাবে জরিপ বা পরীক্ষার মতো বহু অংশগ্রহণকারীযুক্ত অ্যাপ্লিকেশনগুলির জন্য মূল্যবান। OMR C++ API ব্যবহার করে একাধিক পৃষ্ঠার ডকুমেন্ট প্রসেসিংয়ে প্রতিটি পৃষ্ঠা লোড, প্রসেস এবং ডেটা এক্সট্র্যাক্ট করার একটি সিরিজ ধাপ জড়িত। যেমন OMR টেমপ্লেট লোড করা, একাধিক পৃষ্ঠার ডকুমেন্টের প্রতিটি পৃষ্ঠা প্রসেস করা এবং ডেটা সেভ করা।

কীভাবে C++ API ব্যবহার করে একাধিক পৃষ্ঠার ডকুমেন্টের প্রতিটি পৃষ্ঠা লোড ও প্রসেস করবেন?

#include 
// Load the OMR template
omr::AsposeOmrApi api;
api.LoadTemplate("path/to/your/template.omr");
//process each page of the multi-page document.
const int pageCount = 5; // Change this to the total number of pages in your document
for (int currentPage = 1; currentPage <= pageCount; ++currentPage) {
    std::string imagePath = "path/to/your/scanned/image" + std::to_string(currentPage) + ".jpg";
    api.LoadImage(imagePath);
    api.Process();
    // Access and handle recognized data for each page
    omr::OmrPageReader reader = api.GetOmrPageReader();
    std::vector pages = reader.ExtractPages();
    omr::OmrPage page = pages[0]; // Assuming there's only one page in each image
    // Access and handle recognized data
    // Example: Extracting data from the grid
    omr::Grid grid = page.GetGrids()[0]; // Assuming there's only one grid on the page
    std::vector> data = grid.ExtractData();
    // Further processing or storage of the data can be done here
    // Cleanup for the next iteration
    api.Finalize();
}
// release resources.
api.Finalize();

 বাংলা