android - Android 中的水平滚动页脚菜单

标签 android menu footer horizontal-scrolling

我想在我的应用程序屏幕上添加页脚菜单。页脚菜单将具有菜单图标,当按下向左或向右箭头时,这些图标可以一次水平滚动一个菜单。根据菜单屏幕,页脚菜单应滚动到该菜单屏幕的菜单图标。

例如:

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

假设有 6 个菜单图标,并且一次显示 3 个。按向右箭头时,它应该一次滚动一项。

如果我的屏幕与菜单 4 相关,则必须定位菜单 4。

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

而且每个菜单项都应该是可点击的。

请告诉我如何以编程方式实现这一目标。

感谢和问候

最佳答案

希望对您有所帮助:

使用以下具有精确解(以编程方式和解释)的代码来回答您的问题!

我已经完全按照您在问题中提到的那样对其进行了测试和输出!

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;
        }

    }
}

关于android - Android 中的水平滚动页脚菜单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18398060/

相关文章:

android - 折叠布局但将另一个布局放在底部

android无法解析单个json元素

android - 如何在Unity 5.3.5中实现Google AdMob中介

html - 如何对齐菜单栏上的图片?

css - 粘性页脚问题,页脚上方有空隙

html - CSS页脚无法调整高度

android - 交叉编译 Freetype 2.5.3 for Android

Android adb log - 在应用程序崩溃后收集最近的日志

winapi - 如何使用所有者绘制菜单获得与标准相同的外观?

Delphi:像 FineReader 11 一样创建菜单(选项卡)