আমি কি ভিউয়ের সাথে পেজার ব্যবহার করতে পারি (টুকরো টুকরো দিয়ে নয়)


131

আমি এর ViewPagerমধ্যে সোয়াইপ করার জন্য ব্যবহার করছি Fragments, তবে আমি কি সাধারণ এক্সএমএল বিন্যাসের ViewPagerমধ্যে সোয়াইপ করতে ব্যবহার করতে পারি Views?

এটি Adapterভিউপিজারের জন্য আমার পৃষ্ঠা যা খণ্ডগুলির মধ্যে সোয়াইপ করতে ব্যবহৃত হয়:

import java.util.List;

import com.app.name.fragments.TipsFragment;

import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.app.FragmentTransaction;
import android.view.ViewGroup;

public class PageAdapter extends FragmentPagerAdapter {

    /**
     *
     */
    List<Fragment> fragments;
    public PageAdapter(FragmentManager fm,List<Fragment> frags) {
        super(fm);
        fragments = frags;

    }

    @Override
    public Fragment getItem(int arg0) {
        // TODO Auto-generated method stub
        return TipsFragment.newInstance(0, 0);
    }

    @Override
    public int getCount() {
        // TODO Auto-generated method stub
        return 4;
    }

    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
        FragmentManager manager = ((Fragment) object).getFragmentManager();
        FragmentTransaction trans = manager.beginTransaction();
        trans.remove((Fragment) object);
        trans.commit();

        super.destroyItem(container, position, object);
    }

}

এবং এটি আমার টিপ টুকরা:

public class TipsFragment extends Fragment
{
    public static TipsFragment newInstance(int image,int content)
    {
        TipsFragment fragment = new TipsFragment();
        return fragment;
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.tip_layout, null);
        return view;
    }
}

আমি কীভাবে আমার কোডটিকে খণ্ডনের পরিবর্তে ভিউগুলির সাথে কাজ করতে সংশোধন করতে পারি?


এই উদাহরণটি দেখুন stackoverflow.com/a/37916222/3496570
জার ই আহমের

না কেন টুকরো টুকরো ব্যবহার? আমরা টুকরা ব্যবহার করি না বা ব্যবহার না করি তবে আমরা কী অর্জন করব বা হারাব?
ইফতেখারী

@ ইফতেখারী টুকরা => জটিল লাইফসাইকেল => আরও বাগ => বিশৃঙ্খলা
হর্ষিল পানসারে

1
@ হর্ষিলপানসারে হ্যাঁ, আমি ফেব্রুয়ারিতে এই প্রশ্নগুলি করার পরে আমি এই সমস্ত বিপর্যয় পেরিয়েছি এবং আমি আর আমার প্রকল্পগুলিতে টুকরো ব্যবহার করব না। আমার কোন উপায় কিন্তু থেকে সমস্ত টুকরা পরিষ্কার করা ছিল ViewPagerউপর onDestroyউপর এইভাবে onResume3 টুকরা উদ্ধার করার কোন প্রয়োজন থাকবে কার্যকলাপ may আর উপলব্ধ হবে। শুধু সমস্যার একটি উল্লেখ করতে চেয়েছিলেন।
ইফতেখারী

টুকরো টুকরো মুক্ত জীবন!
হর্ষিল পানসারে

উত্তর:


95

আপনাকে এই দুটি পদ্ধতির পরিবর্তে ওভাররাইড করতে হবে getItem():

@Override
public Object instantiateItem(ViewGroup collection, int position) {
    View v = layoutInflater.inflate(...);
    ...
    collection.addView(v,0);
    return v;
}

@Override
public void destroyItem(ViewGroup collection, int position, Object view) {
    collection.removeView((View) view);
}

5
একটি ভাল .. আমাকে অনেক সাহায্য করুন ... আমি ফ্রেগমেন্টপেজএডাপ্টারের পরিবর্তে পেজএডাপ্টার প্রসারিত করেছি ........ এখন এটির কাজ ঠিক .....
রঞ্জিত

3
সম্পূর্ণ কার্যকারী উদাহরণের জন্য, এই প্রশ্নে পাওয়া কোডটি দেখুন: stackoverflow.com/q/7263291
টিয়াগো

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

2
আপনি ইন্টারফেসের ViewPagerসাথে যেমন ViewGroup
ডোরী

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

66

এই উদাহরণ ব্যবহার করুন

আপনি শিশুদের দর্শন নেস্ট করে একটি একক এক্সএমএল লেআউট ব্যবহার করতে পারেন use

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">

        <android.support.v4.view.ViewPager
            android:id="@+id/pager"
            android:layout_width="match_parent"
            android:layout_height="match_parent">

            <LinearLayout
                android:id="@+id/page_one"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:orientation="vertical" >
                        <TextView
                        android:text="PAGE ONE IN"
                        android:layout_width="match_parent"
                        android:layout_height="match_parent"
                        android:textColor="#fff"
                        android:textSize="24dp"/>
            </LinearLayout>

            <LinearLayout
                android:id="@+id/page_two"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:orientation="vertical" >
                        <TextView
                        android:text="PAGE TWO IN"
                        android:layout_width="match_parent"
                        android:layout_height="match_parent"
                        android:textColor="#fff"
                        android:textSize="24dp"/>
            </LinearLayout>

    </android.support.v4.view.ViewPager>
</LinearLayout>

তবে ... এটি আপনাকে একটি অ্যাডাপ্টারের সাহায্যে পরিচালনা করতে হবে। এখানে আমরা অন্য কোনও লেআউটকে স্ফীত না করে সন্ধানী ভিউ আইডিটি ফিরিয়ে দেব।

class WizardPagerAdapter extends PagerAdapter {

    public Object instantiateItem(ViewGroup collection, int position) {

        int resId = 0;
        switch (position) {
        case 0:
            resId = R.id.page_one;
            break;
        case 1:
            resId = R.id.page_two;
            break;
        }
        return findViewById(resId);
    }

    @Override
    public int getCount() {
        return 2;
    }

    @Override
    public boolean isViewFromObject(View arg0, Object arg1) {
        return arg0 == arg1;
    }

    @Override public void destroyItem(ViewGroup container, int position, Object object) {
        // No super
    }
}

// ভিউপ্যাজার অ্যাডাপ্টার সেট করুন

WizardPagerAdapter adapter = new WizardPagerAdapter();
ViewPager pager = (ViewPager) findViewById(R.id.pager);
pager.setAdapter(adapter);

2
@ ব্যবহারকারী1672337 সন্ধান ভিউবাইআইডি ক্রিয়াকলাপ শ্রেণি থেকে অ্যাক্সেসযোগ্য। সুতরাং আপনার অ্যাকটিভিটিতে অভ্যন্তরীণ (অ স্থির) শ্রেণি তৈরি করুন। অথবা আপনাকে অ্যাডাপ্টারে ক্রিয়াকলাপ উদাহরণটি পাস করতে হবে
রুक्स

7
ভিউপ্যাজারে 2 টিরও বেশি শিশু দর্শন থাকলে এটি কাজ করে না। উদাহরণস্বরূপ, যদি আমার ভিউপাগারে আমার তিনটি রিলেটিভ লেআউট থাকে এবং তৃতীয় পৃষ্ঠায় সোয়াইপ করার চেষ্টা করি তবে তৃতীয় পৃষ্ঠাটি ফাঁকা হিসাবে দেখায়। কোন ধারণা কি দেয়?
নাথান ওয়াল্টার্স

15
@ নাথানওয়াল্টার্স, আজ আমার একই সমস্যা ছিল, এটি ভিউপ্যাজারের অফস্ক্রিনপেজ লিমিট সম্পত্তি বাড়িয়ে সমাধান করেছে। সম্ভবত এই তথ্যের সাথে একটি উত্তর আপডেট করা মূল্যবান।
মিখাইল

2
আপনি return collection.findViewById(resId);যদি কোনও ক্রিয়াকলাপের উদাহরণটি পাস করতে না চান তবে আপনি ব্যবহার করতে পারেন
ਅਕসিওম

3
দয়া করে এই কোডটি যুক্ত করুন@Override public void destroyItem(ViewGroup container, int position, Object object) {}
ভোলডিমায়ার কুলিক

11

আমরা ViewPagerকখনও কখনও এটি ব্যবহার করি তার একটি খুব সাধারণ সাবক্লাস তৈরি করেছি।

/**
 * View pager used for a finite, low number of pages, where there is no need for
 * optimization.
 */
public class StaticViewPager extends ViewPager {

    /**
     * Initialize the view.
     *
     * @param context
     *            The application context.
     */
    public StaticViewPager(final Context context) {
        super(context);
    }

    /**
     * Initialize the view.
     *
     * @param context
     *            The application context.
     * @param attrs
     *            The requested attributes.
     */
    public StaticViewPager(final Context context, final AttributeSet attrs) {
        super(context, attrs);
    }

    @Override
    protected void onAttachedToWindow() {
        super.onAttachedToWindow();

        // Make sure all are loaded at once
        final int childrenCount = getChildCount();
        setOffscreenPageLimit(childrenCount - 1);

        // Attach the adapter
        setAdapter(new PagerAdapter() {

            @Override
            public Object instantiateItem(final ViewGroup container, final int position) {
                return container.getChildAt(position);
            }

            @Override
            public boolean isViewFromObject(final View arg0, final Object arg1) {
                return arg0 == arg1;

            }

            @Override
            public int getCount() {
                return childrenCount;
            }

            @Override
            public void destroyItem(final View container, final int position, final Object object) {}
        });
    }

}

এই শ্রেণীর কোনও অ্যাডাপ্টারের প্রয়োজন নেই কারণ এটি বিন্যাস থেকে দর্শনগুলি লোড করবে। আপনার প্রকল্পগুলি এটি ব্যবহার করতে, কেবলমাত্র এর পরিবর্তে এটি ব্যবহার করুন android.support.v4.view.ViewPager

সমস্ত অভিনব জিনিসগুলি এখনও কাজ করবে, তবে আপনাকে অ্যাডাপ্টারের সাথে বিরক্ত করার দরকার নেই।


1
এটি প্রায় আমার জন্য কাজ করেছে, কিন্তু আমাকে পরিবর্তন onAttachedToWindow()করতে হয়েছিল onFinishInflate()
এহহহ

@ ইফতেখারী টুকরো ছাড়াই এটি সহজ এবং আপনি কম কোড লেখেন, যার অর্থ পরে পড়া এবং বুঝতে আরও সহজ এবং বাগের ঝুঁকি কম
Sabo

11

পূর্ববর্তী উত্তরের উপর ভিত্তি করে, আমি এটি সঠিক ও পরিষ্কার উপায়ে অর্জন করার জন্য নিম্নলিখিত ক্লাসটি তৈরি করেছি (আশা করি):

public class MyViewPagerAdapter extends PagerAdapter {

    ArrayList<ViewGroup> views;
    LayoutInflater inflater;

    public MyViewPagerAdapter(ActionBarActivity ctx){
        inflater = LayoutInflater.from(ctx);
        //instantiate your views list
        views = new ArrayList<ViewGroup>(5);
    }

    /**
     * To be called by onStop
     * Clean the memory
     */
    public void release(){
     views.clear();
        views = null;
    }

    /**
     * Return the number of views available.
     */
    @Override
    public int getCount() {
        return 5;
    }

    /**
     * Create the page for the given position. The adapter is responsible
     * for adding the view to the container given here, although it only
     * must ensure this is done by the time it returns from
     * {@link #finishUpdate(ViewGroup)}.
     *
     * @param container The containing View in which the page will be shown.
     * @param position The page position to be instantiated.
     * @return Returns an Object representing the new page. This does not
     *         need to be a View, but can be some other container of
     *         the page.  ,container
     */
    public Object instantiateItem(ViewGroup container, int position) {
        ViewGroup currentView;
        Log.e("MyViewPagerAdapter", "instantiateItem for " + position);
        if(views.size()>position&&views.get(position) != null){
            Log.e("MyViewPagerAdapter",
                  "instantiateItem views.get(position) " +
                  views.get(position));
            currentView = views.get(position);
        }
        else{
            Log.e("MyViewPagerAdapter", "instantiateItem need to create the View");
            int rootLayout = R.layout.view_screen;
            currentView = (ViewGroup) inflater.inflate(rootLayout, container, false);

            ((TextView)currentView.findViewById(R.id.txvTitle)).setText("My Views " + position);
            ((TextView)currentView.findViewById(R.id.btnButton)).setText("Button");
            ((ImageView)currentView.findViewById(R.id.imvPicture)).setBackgroundColor(0xFF00FF00);
        }
        container.addView(currentView);
        return currentView;
    }

    /**
     * Remove a page for the given position. The adapter is responsible
     * for removing the view from its container, although it only must ensure
     * this is done by the time it returns from {@link #finishUpdate(ViewGroup)}.
     *
     * @param container The containing View from which the page will be removed.
     * @param position The page position to be removed.
     * @param object The same object that was returned by
     * {@link #instantiateItem(View, int)}.
     */
    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
        container.removeView((View)object);

    }

    /**
     * Determines whether a page View is associated with a specific key object
     * as returned by {@link #instantiateItem(ViewGroup, int)}. This method is
     * required for a PagerAdapter to function properly.
     *
     * @param view   Page View to check for association with <code>object</code>
     * @param object Object to check for association with <code>view</code>
     * @return true if <code>view</code> is associated with the key object <code>object</code>
     */
    @Override
    public boolean isViewFromObject(View view, Object object) {
        return view==((View)object);
    }
}

এবং আপনার এটিকে আপনার ক্রিয়াকলাপে সেট করতে হবে:

public class ActivityWithViewsPaged extends ActionBarActivity {

    /**
     * The page Adapter: Manage the list of views (in fact here, its fragments)
     * And send them to the ViewPager
     */
    private MyViewPagerAdapter pagerAdapter;

    /**
     * The ViewPager is a ViewGroup that manage the swipe from left
     * to right to left.
     * Like a listView with a gesture listener...
     */
    private ViewPager viewPager;

    @Override
    protected void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_with_views);

        // Find the viewPager
        viewPager = (ViewPager) super.findViewById(R.id.viewpager);

        // Instantiate the PageAdapter
        pagerAdapter = new MyViewPagerAdapter(this);

        // Affectation de l'adapter au ViewPager
        viewPager.setAdapter(pagerAdapter);
        viewPager.setClipToPadding(false);
        viewPager.setPageMargin(12);

        // Add animation when the page are swiped
        // this instanciation only works with honeyComb and more
        // if you want it all version use AnimatorProxy of the nineoldAndroid lib
        //@see:http://stackoverflow.com/questions/15767729/backwards-compatible-pagetransformer
        if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB){
            viewPager.setPageTransformer(true, new PageTransformer());
        }
    }

    @Override
    protected void onStop() {
        super.onStop();
        pagerAdapter.release();
    }

যেখানে এক্সএমএল ফাইলগুলি সুস্পষ্ট দৃশ্য_স্ক্রিন.এক্সএমএল:

<xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/screen"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

 <TextView
        android:id="@+id/txvTitle"
        android:layout_width="wrap_content"
        android:layout_gravity="center"
        android:layout_height="wrap_content"
        android:layout_marginBottom="5dp"
        android:layout_marginTop="5dp"
        android:shadowColor="#FF00FF"
        android:shadowDx="10"
        android:shadowDy="10"
        android:shadowRadius="5"
        android:textSize="32dp"
        android:textStyle="italic"
        android:background="#FFFFF000"/>
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#FFFF00F0">
        <TextView
            android:id="@+id/txvLeft"
            android:layout_width="wrap_content"
            android:layout_gravity="left"
            android:layout_height="wrap_content"
            android:layout_marginBottom="5dp"
            android:layout_marginTop="5dp"/>
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_weight="1"/>
        <TextView
            android:id="@+id/txvRight"
            android:layout_width="wrap_content"
            android:layout_gravity="right"
            android:layout_height="wrap_content"
            android:layout_marginBottom="5dp"
            android:layout_marginTop="5dp"/>
    </LinearLayout>
    <Button
        android:id="@+id/btnButton"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"/>
    <ImageView
        android:id="@+id/imvPicture"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_gravity="center"/>
</LinearLayout>

এবং অ্যাক্টিটিমেনের নিম্নলিখিত লেআউট রয়েছে:

<?xml version="1.0" encoding="utf-8"?>

<android.support.v4.view.ViewPager
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:paddingLeft="24dp"
    android:paddingRight="24dp"
    android:id="@+id/viewpager"
    android:background="#FF00F0F0">
</android.support.v4.view.ViewPager>

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


1
খুব ভাল নয়, আপনি তৈরি করা সমস্ত দৃশ্য সংরক্ষণ করছেন। এটি কেবল দৃশ্যমান দর্শনগুলি সংরক্ষণ করলে আরও ভাল better (তালিকাগুলিতে রূপান্তর মত)
htafoya

4

আমি @ নিকোলাস জবাবটি বিস্তারিতভাবে বলতে চাই, আপনি আইডি দ্বারা মতামতগুলি পেতে পারেন বা যদি তারা গতিশীলভাবে যুক্ত হয় তবে কেবলমাত্র ভিউটিকে সরাসরি তার অবস্থান দেওয়া হবে

class WizardPagerAdapter extends PagerAdapter {

    public Object instantiateItem(View collection, int position) {

        View v = pager.getChildAt(position);

        return v;
    }

    @Override
    public int getCount() {
        return 3;
    }

    @Override
    public boolean isViewFromObject(View arg0, Object arg1) {
        return arg0 == ((View) arg1);
    }
}

4

আমি আমার সমাধানটি এখানে যুক্ত করতে চাই। প্রদত্ত আপনার ব্যবহারের টুকরা প্রয়োজন হবে না, আপনি এখনও একটি তৈরি করতে পারেন PagerAdapterযা সংযুক্ত viewsপরিবর্তে fragmentsকরার ViewPager

এর PagerAdapterপরিবর্তে প্রসারিত করুনFragmentPagerAdapter

public class CustomPagerAdapter extends PagerAdapter {

  private Context context;

  public CustomPagerAdapter(Context context) {
    super();
    this.context = context;
  }


  @Override
  public Object instantiateItem(ViewGroup collection, int position) {
    LayoutInflater inflater = LayoutInflater.from(context);
    View view = null;
    switch (position){
      case 0:
        view = MemoryView.getView(context, collection);
        break;
      case 1:
        view = NetworkView.getView(context, collection);
        break;
      case 2:
        view = CpuView.getView(context, collection);
        break;
    }

    collection.addView(view);
    return view;
  }

  @Override
  public int getCount() {
    return 3;
  }

  @Override
  public boolean isViewFromObject(View view, Object object) {
    return view==object;
  }

  @Override
  public void destroyItem(ViewGroup collection, int position, Object view) {
    collection.removeView((View) view);
  }
}

এখন আপনাকে তিনটি ক্লাস সংজ্ঞায়িত করতে হবে যা viewsস্ফীত হওয়াতে ফিরে আসবে viewpager। অনুরূপ CpuViewআপনি হবে MemoryViewএবং NetworkViewক্লাস। তাদের প্রত্যেকে তাদের নিজ নিজ লেআউটগুলি স্ফীত করে দেবে।

public class CpuView {

public static View getView(Context context, ViewGroup collection) {

    LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context
        .LAYOUT_INFLATER_SERVICE);
    return inflater.inflate(R.layout.debugger_cpu_layout, collection, false);
  }
}

এবং অবশেষে একটি বিন্যাস যা প্রতিটি দর্শনে স্ফীত হবে

    <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:orientation="vertical"
              android:layout_width="match_parent"
              android:layout_height="match_parent">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textColor="#000000"
        android:text="CPU"/>
</LinearLayout>

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


আইএমও, ক্রিয়াকলাপগুলি ব্যবহার করা সহজ
ডেনি

-1

হ্যাঁ ... আপনি ভিউপিজারে ফ্র্যাগমেন্টের পরিবর্তে ভিউ ব্যবহার করতে পারেন। এখানে আপনি পুরো উদাহরণটি আবিষ্কার করতে পারেন যা আপনাকে খণ্ড ছাড়াই ভিউপ্যাজার অর্জনে সহায়তা করবে। এই ডকুমেন্টেশন মাধ্যমে যান।

https://www.bignerdranch.com/blog/viewpager-without-fragments/

আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.