1

アプリケーション画面にフッター メニューを追加したいと考えています。フッター メニューには、左矢印または右矢印を押すと一度に 1 つのメニューを水平スクロールできるメニュー アイコンがあります。メニュー画面に基づいて、そのメニュー画面のメニュー アイコンまでフッター メニューをスクロールする必要があります。

元。:

    ----------------------------------------
     <   menu1     |  menu2  |   menu3   >
   -----------------------------------------

6 つのメニュー アイコンがあり、一度に 3 つ表示されているとします。右矢印を押すと、一度に 1 項目ずつスクロールする必要があります。

私の画面がメニュー4に関連している場合、メニュー4を配置する必要があります。

   ----------------------------------------
     <   menu4     |  menu5  |   menu6   >
   -----------------------------------------

また、各メニュー項目はクリック可能にする必要があります。

プログラムでこれを達成する方法を教えてください。

感謝と敬意

4

3 に答える 3

1

私はこれがあなたを助けることを願っています:

below code which has Exact Solution ( Programmatically with Explanation )あなたの答えに使用してください!

あなたが質問で述べたように、私はそれをテストし、その出力を正確に出力しました!

public class MainActivity extends Activity implements OnClickListener {
    Context context;
    int scrWidth, scrWidth80by3, scrWidth10;
    Button btnMenu[], btnNext, btnPre;
    LinearLayout llRoot, llHsMain, llMenuGroup1, llMenuGroup2;
    HorizontalScrollView hScrollView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        DisplayMetrics dm = new DisplayMetrics();
        getWindowManager().getDefaultDisplay().getMetrics(dm);
        scrWidth = dm.widthPixels;
        scrWidth = (int) (0.8 * scrWidth); // Calculating 80 % Width of Screen for Horizontal Scroll View
        scrWidth80by3 = (int) (scrWidth / 3); // Calulation 1/3 of Width of  Horizontal Scroll View for 3  menu items
        scrWidth10 = (int) (0.1 * scrWidth);// Calulation 10% Width of Screen for Previous And Next Button

        context = MainActivity.this;

        btnMenu = new Button[7];

        llMenuGroup1 = new LinearLayout(context);
        llMenuGroup2 = new LinearLayout(context);

        llMenuGroup1.setLayoutParams(new LayoutParams(scrWidth,
                LayoutParams.WRAP_CONTENT));
        llMenuGroup2.setLayoutParams(new LayoutParams(scrWidth,
                LayoutParams.WRAP_CONTENT));
        for (int i = 1; i < btnMenu.length; i++) {
            // Starting from int i=1  to Set Menu Item Counting from 1 like Menu 1 instead of Menu 0
            btnMenu[i] = new Button(context);
            btnMenu[i].setId(i);
            btnMenu[i].setOnClickListener(this);
            btnMenu[i].setLayoutParams(new LayoutParams(scrWidth80by3,
                    LayoutParams.WRAP_CONTENT));
            btnMenu[i].setText("Menu" + i);
            if (i <= 3) {
                llMenuGroup1.addView(btnMenu[i]);
            } else {
                llMenuGroup2.addView(btnMenu[i]);
            }
        }

        btnNext = new Button(context);
        btnNext.setOnClickListener(this);
        btnNext.setId(0);
        btnPre = new Button(context);
        btnPre.setOnClickListener(this);
        btnPre.setId(-1);

        //  llRoot its Main Root Layout ! 
        llRoot = new LinearLayout(context);
        llRoot.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT,
                LayoutParams.WRAP_CONTENT));

        btnNext.setLayoutParams(new LayoutParams(scrWidth10,
                LayoutParams.WRAP_CONTENT));
        btnNext.setText(">");
        btnPre.setLayoutParams(new LayoutParams(scrWidth10,
                LayoutParams.WRAP_CONTENT));
        btnPre.setText("<");

        //  hScrollView its HorizontalScrollView ! 
        hScrollView = new HorizontalScrollView(context);
        hScrollView.setLayoutParams(new LayoutParams(scrWidth,
                LayoutParams.WRAP_CONTENT));

        // As HorizontalScrollView can Have one Direct Child ! so llHsMain is one Direct Child of hScrollView!
        llHsMain = new LinearLayout(context);
        llHsMain.setLayoutParams(new LayoutParams(scrWidth,
                LayoutParams.WRAP_CONTENT));

        //Adding Menu Group1 And Menu Group 2 to  llHsMain as its Direct Child of hScrollView
        llHsMain.addView(llMenuGroup1);
        llHsMain.addView(llMenuGroup2);

        //Adding Direct Child llHsMain to hScrollView
        hScrollView.addView(llHsMain);

        //  Adding views to llRoot (its Main Root Layout) ! 
        llRoot.addView(btnPre);
        llRoot.addView(hScrollView);
        llRoot.addView(btnNext);

        //Displaying llRoot (its Main Root Layout) !
        setContentView(llRoot);  
    }

    @Override
    public void onClick(View v) {
        // TODO Auto-generated method stub
        switch (v.getId()) {
        case -1: // Previous Button Clicked
            hScrollView.scrollTo(-scrWidth, 0); // see -ve sign to scroll back horizontally only scrWidth is 80% of Total Screen
            break;
        case 0: // Next Button Clicked
            hScrollView.scrollTo(scrWidth, 0); // scrolls next horizontally only scrWidth is 80% of Total Screen
            break;

        case 1: // Menu Button1 Clicked
            Toast.makeText(getApplicationContext(), "Menu 1 Clicked",1).show();
            break;

            // repeat up to 6

        case 6:
            Toast.makeText(getApplicationContext(), "Menu 6 Clicked",1).show();
            break;
        default:
            break;
        }

    }
}
于 2013-08-23T11:34:42.973 に答える
0

HorizontalScrollView子として LinearLayout を使用して追加します。内にメニュー ボタンを追加しますLinearLayout

メニューボタン(getWidth())の幅を測定し、左または右のボタンをクリックすると、ビューをスクロールするsmoothScrollBy ( width of menu button + padding ,0);か、使用することもできますscrollBy(x,y)

于 2013-08-23T08:27:17.263 に答える