UIKit এবং GUI প্রোগ্রামিং

সুইফট প্রোগ্রামিং (Swift Programming) - Computer Programming

175

UIKit হল iOS, iPadOS, tvOS, এবং watchOS-এর জন্য Apple-এর মূল ফ্রেমওয়ার্ক, যা বিভিন্ন ভিজ্যুয়াল উপাদান (components) ও টুলস সরবরাহ করে। UIKit ব্যবহার করে Graphical User Interface (GUI) তৈরি করা সহজ হয়।

UIKit-এর প্রধান উপাদানগুলো:

UIView:

  • UIKit-এর প্রাথমিক বিল্ডিং ব্লক। প্রতিটি ভিজ্যুয়াল উপাদান UIView-এর সাবক্লাস।
  • UIView-এর মাধ্যমে সরল উপাদান যেমন লেবেল, বাটন, বা ইমেজ সহ আরও জটিল লেআউট তৈরি করা যায়।

UIViewController:

  • iOS অ্যাপে প্রতিটি ভিউ এবং এর ইন্টারফেসের জীবনচক্র ম্যানেজ করতে UIViewController ব্যবহৃত হয়।
  • UIViewController-এর মাধ্যমে ভিউগুলিকে লোড করা, ডেটা আপডেট করা, ইভেন্ট হ্যান্ডল করা, এবং অটো লেআউট পরিচালনা করা সহজ হয়।

Auto Layout:

  • Auto Layout ডিভাইসের বিভিন্ন স্ক্রিন সাইজ অনুযায়ী ইন্টারফেসকে রেসপনসিভ রাখতে সহায়ক।
  • কনস্ট্রেন্টের মাধ্যমে উপাদানগুলির পজিশন এবং সাইজ নির্ধারণ করা যায়, যা ডিভাইস ভেদে অ্যাপের UI কে স্বয়ংক্রিয়ভাবে মানিয়ে নিতে সহায়ক।

Event Handling:

  • UIKit-এর মধ্যে UI উপাদানগুলির জন্য বিভিন্ন ইভেন্ট হ্যান্ডলিং সিস্টেম রয়েছে, যা ব্যবহারকারী ইনপুটগুলো (যেমন: টাচ, ট্যাপ, সোয়াইপ) হ্যান্ডল করতে দেয়।
  • উদাহরণস্বরূপ, UIButton-এ addTarget মেথড ব্যবহার করে touchUpInside ইভেন্ট হ্যান্ডল করা যায়।

Storyboard এবং XIB Files:

  • Storyboard এবং XIB ফাইল ব্যবহার করে সহজে অ্যাপের UI ডিজাইন করা যায়।
  • Storyboard-এ সম্পূর্ণ অ্যাপের বিভিন্ন স্ক্রিন ও ভিউ কন্ট্রোলারের সংযোগ দেখা যায়, যা ভিজ্যুয়াল ডেভেলপমেন্টকে সহজ ও দ্রুত করে।

UIKit-এর মাধ্যমে GUI প্রোগ্রামিং উদাহরণ

import UIKit

class ViewController: UIViewController {
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        // UILabel তৈরি এবং সেটআপ
        let label = UILabel()
        label.text = "Welcome to UIKit"
        label.textColor = .black
        label.frame = CGRect(x: 50, y: 100, width: 200, height: 50)
        view.addSubview(label)
        
        // UIButton তৈরি এবং সেটআপ
        let button = UIButton(type: .system)
        button.setTitle("Click Me", for: .normal)
        button.frame = CGRect(x: 50, y: 200, width: 100, height: 50)
        button.addTarget(self, action: #selector(buttonClicked), for: .touchUpInside)
        view.addSubview(button)
    }
    
    @objc func buttonClicked() {
        print("Button clicked!")
    }
}

UIKit-এর প্রধান বৈশিষ্ট্য

  1. সহজ ইন্টারফেস ডিজাইন: Storyboard এবং Interface Builder-এর মাধ্যমে ভিজ্যুয়াল ইন্টারফেস দ্রুত তৈরি করা যায়।
  2. রিচ UI কম্পোনেন্ট: UILabel, UIButton, UITableView-এর মতো প্রচুর UI কম্পোনেন্ট সরবরাহ করে, যা কম কোডে জটিল UI তৈরি করতে সহায়ক।
  3. ইভেন্ট হ্যান্ডলিং এবং অ্যানিমেশন: ইউজার ইন্টারঅ্যাকশন এবং অ্যানিমেশন হ্যান্ডল করা সহজ, যা অ্যাপের UI কে আরও ইন্টারঅ্যাকটিভ করে।

GUI প্রোগ্রামিং-এর সাথে Auto Layout এবং Constraints ব্যবহারের সুবিধা

  • Responsive Design: Auto Layout ব্যবহার করে বিভিন্ন স্ক্রিন সাইজের জন্য UI ডিজাইন করা সহজ।
  • Dynamic Adjustment: কনস্ট্রেইন্ট নির্ধারণ করে UI উপাদানগুলি ডাইনামিক অ্যাডজাস্টমেন্ট দেয়, যা ডিভাইসের পর্দার সাইজ অনুসারে UI কাস্টমাইজ করে।

UIKit এবং GUI প্রোগ্রামিং-এর মাধ্যমে iOS অ্যাপের গ্রাফিক্যাল ইউজার ইন্টারফেস সহজে তৈরি করা যায়, যা ইউজার-ফ্রেন্ডলি ও কার্যকরী অ্যাপ তৈরি করতে সহায়ক। Swift-এর কোড লেখার সুবিধার কারণে UIKit ব্যবহারের মাধ্যমে অ্যাপ ডেভেলপমেন্ট প্রক্রিয়া আরও দ্রুত ও সাশ্রয়ী হয়।

Content added By

UIKit হলো Apple এর iOS এবং tvOS প্ল্যাটফর্মের জন্য একটি শক্তিশালী ফ্রেমওয়ার্ক যা ইউজার ইন্টারফেস তৈরি করতে সহায়ক। UIKit-এ বিভিন্ন UI কম্পোনেন্ট, যেমন- বোতাম, লেবেল, টেক্সটফিল্ড, ইমেজ ভিউ, এবং টেবিল ভিউ রয়েছে। এসব কম্পোনেন্ট ব্যবহার করে ইন্টারঅ্যাকটিভ এবং প্রতিক্রিয়াশীল অ্যাপ্লিকেশন তৈরি করা যায়।

iOS অ্যাপ্লিকেশন তৈরির ধাপসমূহ

১. প্রজেক্ট তৈরি

  • Xcode ওপেন করে Single View App টেমপ্লেট নির্বাচন করে নতুন প্রজেক্ট তৈরি করতে হয়।
  • প্রজেক্টের নাম, অ্যাপ্লিকেশনের জন্য প্যাকেজ আইডেন্টিফায়ার এবং ডিভাইস টাইপ (iPhone, iPad বা উভয়) নির্ধারণ করতে হয়।

২. UIViewController এবং Storyboard

  • UIViewController: প্রতিটি স্ক্রিনকে একটি UIViewController দিয়ে প্রতিনিধিত্ব করা হয়। এটি UIKit এর একটি অংশ যা স্ক্রিনের UI এবং ইন্টারঅ্যাকশন পরিচালনা করে।
  • Storyboard: Interface Builder-এ Storyboard ব্যবহার করে UI ডিজাইন করা যায়। এখানে বিভিন্ন UI উপাদান যেমন UILabel, UIButton, UITextField, UIImageView ড্র্যাগ এবং ড্রপ করে স্ক্রিন ডিজাইন করা যায়।

৩. UI কম্পোনেন্ট এবং IBOutlet ব্যবহার

  • UI উপাদানগুলিকে কোডের সাথে সংযুক্ত করতে IBOutlet এবং IBAction ব্যবহার করা হয়।
  • উদাহরণ:
@IBOutlet weak var myLabel: UILabel!
@IBAction func buttonTapped(_ sender: UIButton) {
    myLabel.text = "Button Pressed"
}

৪. নেভিগেশন এবং কন্ট্রোলার ব্যবহার

  • UINavigationController: এটি একটি নেভিগেশন বার এবং হায়ারার্কি যুক্ত করে যা স্ক্রিনের মধ্যে একে অপরের মধ্যে স্থানান্তর করতে সাহায্য করে।
  • Tab Bar Controller: অ্যাপ্লিকেশনের নিচে ট্যাব নিয়ে আসে, যা বিভিন্ন স্ক্রিনের মধ্যে স্যুইচ করার জন্য উপযোগী।

৫. Auto Layout এবং Responsive Design

  • Auto Layout ব্যবহার করে বিভিন্ন ডিভাইসের স্ক্রিন সাইজ অনুযায়ী UI স্বয়ংক্রিয়ভাবে অ্যাডজাস্ট করা যায়। এটি Storyboard বা কোডের মাধ্যমে কনস্ট্রেইন্ট সেট করে ডিজাইন তৈরি করা যায়।

৬. ইন্টারঅ্যাকশন এবং জেস্টার রিকগনাইজার

  • UIKit-এ বিভিন্ন টাচ জেস্টার, যেমন ট্যাপ, পিঞ্চ, এবং সোয়াইপ রিকগনাইজার যুক্ত করে ইন্টারঅ্যাকশন বাড়ানো যায়।
let tapGesture = UITapGestureRecognizer(target: self, action: #selector(handleTap))
myView.addGestureRecognizer(tapGesture)

৭. API ইন্টিগ্রেশন এবং ডেটা হ্যান্ডলিং

  • URLSession ব্যবহার করে REST API থেকে ডেটা ফেচ করা যায়। JSON ডেটা হ্যান্ডল করতে Codable প্রোটোকল ব্যবহার করা হয়।
struct User: Codable {
    let id: Int
    let name: String
}

৮. Core Data বা Database Management

  • অ্যাপের ডেটা স্থায়ীভাবে সংরক্ষণের জন্য Core Data ব্যবহার করা হয়।

৯. ডিবাগিং এবং টেস্টিং

  • Xcode-এ বিল্ট-ইন ডিবাগার ব্যবহার করে বাগ ফিক্স করা যায় এবং XCTest ফ্রেমওয়ার্ক ব্যবহার করে অ্যাপ্লিকেশন টেস্টিং করা যায়।

১০. অ্যাপের ডেপ্লয়মেন্ট

  • অ্যাপটি টেস্ট করতে Simulator ব্যবহার করা যায় এবং App Store-এ প্রকাশ করার আগে App Store Connect-এর মাধ্যমে পরীক্ষা ও জমা দিতে হয়।

সংক্ষেপে

UIKit এবং Xcode ব্যবহার করে iOS অ্যাপ তৈরি করতে বিভিন্ন ধাপ রয়েছে, যার মধ্যে রয়েছে UI ডিজাইন, নেভিগেশন ব্যবস্থাপনা, API ইন্টিগ্রেশন, এবং ডেটা ম্যানেজমেন্ট। এই ফ্রেমওয়ার্ক iOS ডেভেলপমেন্টকে দ্রুত, কার্যকরী এবং উন্নত করে তোলে।

Content added By

Swift-এ ভিউ (View) হলো এমন একটি গ্রাফিকাল উপাদান যা ব্যবহারকারীর সাথে ইন্টারঅ্যাক্ট করে। UIView শ্রেণিটি ভিউ-এর একটি সাধারণ ধরনের শ্রেণি যা UI উপাদানগুলির চিত্র এবং অবস্থান ম্যানেজ করে। ভিউ UI উপাদান যেমন লেবেল, বোতাম, ইমেজ, এবং টেক্সটফিল্ড ধারণ করে এবং স্ক্রিনে UI রেন্ডার করতে ব্যবহৃত হয়।

UIView-এর বৈশিষ্ট্য

  • UI উপাদান ধারণ: UILabel, UIButton, UITextField প্রভৃতি রাখে।
  • ইন্টারঅ্যাকশন: ব্যবহারকারী ভিউতে টাচ, ট্যাপ বা স্ক্রোলিং করতে পারে।
  • সাবভিউ: একটি ভিউয়ে অন্যান্য ভিউ যোগ করা যায়, যা মাল্টিলেভেল UI গঠন করতে সহায়ক।
  • আকার এবং অবস্থান: frame, bounds, এবং center ব্যবহার করে ভিউর আকার এবং অবস্থান সেট করা যায়।

ভিউ কন্ট্রোলার (UIViewController)

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

UIViewController-এর গুরুত্বপূর্ণ মেথড:

  1. viewDidLoad(): ভিউ লোড হওয়ার পরপরই প্রথমবারের মতো কল হয়।
  2. viewWillAppear(): ভিউ স্ক্রিনে আসার ঠিক আগে কল হয়।
  3. viewDidAppear(): ভিউ স্ক্রিনে প্রদর্শিত হওয়ার পর কল হয়।
  4. viewWillDisappear(): ভিউ স্ক্রিন থেকে সরে যাওয়ার ঠিক আগে কল হয়।
  5. viewDidDisappear(): ভিউ স্ক্রিন থেকে সম্পূর্ণভাবে সরে যাওয়ার পর কল হয়।

উদাহরণ

import UIKit

class MyViewController: UIViewController {
    override func viewDidLoad() {
        super.viewDidLoad()
        
        let label = UILabel()
        label.text = "Hello, World!"
        label.frame = CGRect(x: 50, y: 50, width: 200, height: 50)
        view.addSubview(label)
    }
}

এখানে, MyViewController একটি UIViewController ক্লাস, যা viewDidLoad()-এ একটি UILabel তৈরি করে এবং সেটি ভিউতে যোগ করে।

ভিউ এবং ভিউ কন্ট্রোলারের কার্যকারিতা

  • ডাটা প্রসেসিং: ভিউ কন্ট্রোলার ডেটা প্রসেসিং করে এবং প্রয়োজনীয় UI আপডেট করে।
  • ইভেন্ট হ্যান্ডলিং: ব্যবহারকারীর ইন্টারঅ্যাকশন এবং নেভিগেশন ম্যানেজ করে।
  • কোড মডুলারিটি: ভিউ এবং লজিক পৃথক করে কোড মডুলার ও পুনঃব্যবহারযোগ্য করে তোলে।

সংক্ষেপে

Swift-এ ভিউ ব্যবহার করে UI তৈরি করা হয় এবং ভিউ কন্ট্রোলার ব্যবহার করে UI-এর কার্যকারিতা নিয়ন্ত্রণ করা হয়। UIView এবং UIViewController এর মাধ্যমে অ্যাপ্লিকেশনের ভিজ্যুয়াল এবং ইন্টারঅ্যাকশন ম্যানেজ করা যায়, যা Swift-এ অ্যাপ ডেভেলপমেন্টের ভিত্তি তৈরি করে।

Content added By

UIKit-এর বিভিন্ন UI কম্পোনেন্ট যেমন UIButton, UILabel, এবং UITextField iOS অ্যাপ্লিকেশন তৈরির সময় ব্যাপকভাবে ব্যবহৃত হয়। এগুলোর মাধ্যমে সহজেই গ্রাফিক্যাল ইউজার ইন্টারফেস তৈরি করা যায়।

UIKit-এর বিভিন্ন UI কম্পোনেন্ট


১. UIButton (বাটন)

  • একটি টাচ ইন্টারঅ্যাক্টিভ উপাদান, যা ব্যবহারকারীর ক্রিয়াকলাপ গ্রহণ করে।
  • প্রোপার্টি: title, backgroundColor, image
  • ব্যবহার: addTarget ফাংশনের মাধ্যমে ইভেন্ট হ্যান্ডল করা হয়।

উদাহরণ:

let button = UIButton(type: .system)
button.setTitle("Submit", for: .normal)
button.addTarget(self, action: #selector(buttonTapped), for: .touchUpInside)

২. UILabel (লেবেল)

  • স্ট্যাটিক বা ডায়নামিক টেক্সট প্রদর্শনের জন্য ব্যবহৃত হয়।
  • প্রোপার্টি: text, textColor, font, textAlignment

উদাহরণ:

let label = UILabel()
label.text = "Hello, World!"
label.textColor = .black
label.textAlignment = .center

৩. UITextField (টেক্সট ফিল্ড)

  • ইউজারের ইনপুট (যেমন: নাম, ইমেল) গ্রহণের জন্য ব্যবহৃত হয়।
  • প্রোপার্টি: placeholder, text, keyboardType
  • delegate ব্যবহার করে টেক্সট পরিবর্তন, সাবমিশন ইত্যাদি নিয়ন্ত্রণ করা যায়।

উদাহরণ:

let textField = UITextField()
textField.placeholder = "Enter your name"
textField.borderStyle = .roundedRect

UI কম্পোনেন্টের ব্যবহারের সুবিধা

  • ইন্টারঅ্যাক্টিভ ইউজার ইন্টারফেস: বাটন, লেবেল, এবং টেক্সট ফিল্ডসহ UIKit কম্পোনেন্টের মাধ্যমে ব্যবহারকারীর সাথে ইন্টারঅ্যাকশন সহজ হয়।
  • সহজ কাস্টমাইজেশন: প্রতিটি উপাদানের প্রপার্টি এবং মেথড ব্যবহার করে ডিজাইন এবং ফাংশনালিটি কাস্টমাইজ করা যায়।

UIKit কম্পোনেন্টগুলির ব্যবহারের মাধ্যমে iOS অ্যাপে দ্রুত এবং সুন্দর গ্রাফিক্যাল ইউজার ইন্টারফেস তৈরি করা সম্ভব।

Content added By

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

অটো লেআউটের মূল উপাদানসমূহ

কনস্ট্রেইন্ট (Constraints): এটি UI উপাদানের বিভিন্ন পজিশন এবং আকার নিয়ন্ত্রণ করে। উদাহরণস্বরূপ, আপনি কোনো বাটনের জন্য কনস্ট্রেইন্ট সেট করতে পারেন যেন এটি স্ক্রিনের কেন্দ্রে থাকে বা নির্দিষ্ট মার্জিনে অবস্থিত হয়।

উদাহরণ:

  • বাটনটির শীর্ষ কনস্ট্রেইন্ট স্ক্রিনের শীর্ষ থেকে ২০ পিক্সেল।
  • লেবেলের প্রস্থ স্ক্রিনের প্রস্থের ৭০%।

পিনিং এবং অ্যালাইনমেন্ট: UI উপাদানকে কোনো নির্দিষ্ট স্থান বা অবস্থানের সাথে যুক্ত করা যায়, যা বিভিন্ন ডিভাইসে একই রকম থাকে। Align অপশনটি ব্যবহার করে উপাদানগুলিকে স্ক্রিনের কেন্দ্রে, বাম বা ডানে অ্যালাইন করা যায়।

রেসপন্সিভ লেআউট: অটো লেআউটের মাধ্যমে ভিন্ন ভিন্ন স্ক্রিন সাইজে UI উপাদানগুলো একই অবস্থান এবং আকার বজায় রাখতে পারে। অটো লেআউটের কনস্ট্রেইন্ট নির্ধারণ করে iPhone এবং iPad উভয় ডিভাইসে UI রেসপন্সিভ থাকে।

Size Classes এবং Trait Variations: এগুলো iOS ডিজাইনে ফ্রেমওয়ার্কের মাধ্যমে বিভিন্ন স্ক্রিন সাইজ অনুযায়ী লেআউট সামঞ্জস্য করতে সহায়ক। Xcode-এ Size Class পরিবর্তন করে UI উপাদানগুলির বিভিন্ন লেআউট দেখা যায়, যেমন কম্প্যাক্ট (Compact) এবং নিয়মিত (Regular)।

স্টোরিবোর্ড

স্টোরিবোর্ড হলো Xcode-এর ভিজ্যুয়াল ডিজাইন টুল যা একাধিক স্ক্রিন ডিজাইন এবং নেভিগেশন কন্ট্রোল ম্যানেজ করতে ব্যবহৃত হয়। একটি প্রজেক্টে একাধিক স্টোরিবোর্ড থাকতে পারে, তবে সাধারণত প্রতিটি প্রজেক্টে একটি স্টোরিবোর্ড থাকে যা একাধিক ভিউ কন্ট্রোলার ধারণ করে। স্টোরিবোর্ডে ভিউ কন্ট্রোলার এবং তাদের মধ্যে নেভিগেশন কন্ট্রোলারগুলো ভিজ্যুয়ালি প্রদর্শিত হয়।

স্টোরিবোর্ডের গুরুত্বপূর্ণ বৈশিষ্ট্য

Scenes এবং Segues: স্টোরিবোর্ডের প্রতিটি ভিউ কন্ট্রোলারকে একটি Scene বলা হয়। স্ক্রিনের মধ্যে নেভিগেশনের জন্য Segues ব্যবহৃত হয় যা বিভিন্ন ভিউ কন্ট্রোলারের মধ্যে যোগাযোগ স্থাপন করে।

Segue প্রকারভেদ:

  • Show: নতুন স্ক্রিন নেভিগেশন কন্ট্রোলারের মাধ্যমে পুশ করা হয়।
  • Modal: সম্পূর্ণ ভিন্ন কন্টেক্সটে নতুন স্ক্রিন প্রেজেন্ট করা হয়।
  • Embed: একটি ভিউ কন্ট্রোলারের ভিতর Child ভিউ কন্ট্রোলার এম্বেড করা হয়।

IBAction এবং IBOutlet: UI উপাদানগুলোর সাথে কোডের মাধ্যমে ইন্টারঅ্যাকশন করতে IBOutlet এবং IBAction ব্যবহার করা হয়। IBOutlet UI উপাদানের প্রপার্টি ম্যানেজ করে এবং IBAction ব্যবহার করে ব্যবহারকারীর ইন্টারঅ্যাকশন হ্যান্ডল করা যায়।

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

উদাহরণ প্রজেক্ট: অটো লেআউট এবং স্টোরিবোর্ড

একটি সাধারণ iOS প্রজেক্টে স্টোরিবোর্ড ব্যবহার করে একটি ফর্ম তৈরি করা যেতে পারে, যেখানে নিচের ধাপগুলো অনুসরণ করা হবে:

  1. স্টোরিবোর্ডে UI উপাদান যোগ: UILabel, UITextField, এবং UIButton স্টোরিবোর্ডে যুক্ত করা হয়।
  2. কনস্ট্রেইন্ট নির্ধারণ: প্রতিটি UI উপাদানের জন্য পিনিং ও অ্যালাইনমেন্ট কনস্ট্রেইন্ট যোগ করে তাদের অবস্থান স্থির করা।
  3. IBOutlets এবং IBActions তৈরি: কোডে IBOutlet ব্যবহার করে UI উপাদানের সাথে কোড সংযোগ করা এবং IBAction ব্যবহার করে বাটন ক্লিক ইভেন্ট হ্যান্ডল করা।

অটো লেআউট এবং স্টোরিবোর্ড ব্যবহার করে সুবিধা

  • রেসপন্সিভ ডিজাইন: একই লেআউট বিভিন্ন ডিভাইসে মানানসই থাকে।
  • সহজ নেভিগেশন: একাধিক স্ক্রিনের মধ্যে সহজে নেভিগেশন স্থাপন করা যায়।
  • কোড এবং ডিজাইনের মধ্যে সিমলেস ইন্টিগ্রেশন: UI ডিজাইন এবং ব্যাকএন্ড কোড সহজে একত্রিত করা যায়।

অটো লেআউট এবং স্টোরিবোর্ড iOS অ্যাপ ডেভেলপমেন্টে গুরুত্বপূর্ণ ভূমিকা পালন করে, যা UI ডিজাইন এবং ফ্লো ম্যানেজমেন্ট সহজ করে।

Content added By
Promotion

Are you sure to start over?

Loading...