频道管理

本文介绍了一个包含HorizontalScrollView和ViewPager的Android布局实现方案,通过TextView数组实现了频道切换效果,并且详细展示了如何初始化视图组件和数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

xml布局

<HorizontalScrollView
        android:id="@+id/hs"
        android:layout_width="400dp"
        android:scrollbars="none"
        android:layout_height="40dp">
        <LinearLayout
            android:id="@+id/linearlayout"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal"></LinearLayout>
    </HorizontalScrollView>


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






    <Button
        android:id="@+id/button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_above="@+id/viewpager"
        android:layout_toEndOf="@+id/hs"
        android:layout_toRightOf="@+id/hs"

        android:text="频道管理" />




pindaoguanli


    private View view;
    private HorizontalScrollView hs;
    private LinearLayout ll;
    private ViewPager vp;
    private Button button;
    private List<TextView> list;
    private List<ChannelBean> channelBeans;


    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {


        view = inflater.inflate(R.layout.fragment01, container, false);


        initViews();
        initDatas();
        return view;
    }




    private void initViews() {
        hs = view.findViewById(R.id.hs);
        ll = view.findViewById(R.id.linearlayout);
        vp = view.findViewById(R.id.viewpager);
        button = view.findViewById(R.id.button);
    }


    private void initDatas() {
        list = new ArrayList<>();
        channelBeans = new ArrayList<>();
        channelBeans.add(new ChannelBean("头条", true));
        channelBeans.add(new ChannelBean("娱乐", true));
        channelBeans.add(new ChannelBean("科技", true));
        channelBeans.add(new ChannelBean("信息", true));
        channelBeans.add(new ChannelBean("八卦", true));
        channelBeans.add(new ChannelBean("北京", false));
        channelBeans.add(new ChannelBean("上海", false));
        channelBeans.add(new ChannelBean("天津", false));
        channelBeans.add(new ChannelBean("重庆", false));
        channelBeans.add(new ChannelBean("大大燕网", false));


        for (int i = 0; i < channelBeans.size(); i++) {
            TextView textView = new TextView(getActivity());
            textView.setText(channelBeans.get(i).getName() + "");
            textView.setTextSize(20);
            textView.setId(i + 1000);
            textView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View view) {
                    int id = view.getId();
                    vp.setCurrentItem(id - 1000);
                }
            });


            if (i == 0) {
                textView.setTextColor(Color.RED);
            } else {
                textView.setTextColor(Color.BLACK);
            }
            LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT);
            layoutParams.setMargins(50, 10, 50, 10);
            ll.addView(textView, layoutParams);
            list.add(textView);
        }
        vp.setAdapter(new MyAdapter(getActivity().getSupportFragmentManager()));
        vp.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
                for (int i = 0; i < list.size(); i++) {
                    if (position == i) {
                        list.get(i).setTextColor(Color.RED);
                    } else {
                        list.get(i).setTextColor(Color.BLACK);
                    }
                }
                TextView textView = list.get(position);
                int width = textView.getWidth() + 10;
                hs.scrollTo(width * position, 0);




            }


            @Override
            public void onPageSelected(int position) {


            }


            @Override
            public void onPageScrollStateChanged(int state) {


            }
        });
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                ChannelActivity.startChannelActivity((AppCompatActivity) getActivity(),channelBeans);
            }
        });
    }


    class MyAdapter extends FragmentPagerAdapter {


        public MyAdapter(FragmentManager fragmentManager) {
            super(fragmentManager);
        }


        @Override
        public Fragment getItem(int position) {
            return Fragment001.getinstance(list.get(position).getText().toString());
        }


        @Override
        public int getCount() {
            return list.size();
        }
    }

}




内容概要:本文档详细介绍了基于Google Earth Engine (GEE) 构建的阿比让绿地分析仪表盘的设计与实现。首先,定义了研究区域的几何图形并将其可视化。接着,通过云掩膜函数和裁剪操作预处理Sentinel-2遥感影像,筛选出高质量的数据用于后续分析。然后,计算中值图像并提取NDVI(归一化差异植被指数),进而识别绿地及其面积。此外,还实现了多个高级分析功能,如多年变化趋势分析、人口-绿地交叉分析、城市热岛效应分析、生物多样性评估、交通可达性分析、城市扩张分析以及自动生成优化建议等。最后,提供了数据导出、移动端适配和报告生成功能,确保系统的实用性和便捷性。 适合人群:具备一定地理信息系统(GIS)和遥感基础知识的专业人士,如城市规划师、环境科学家、生态学家等。 使用场景及目标:①评估城市绿地分布及其变化趋势;②分析绿地与人口的关系,为城市规划提供依据;③研究城市热岛效应及生物多样性,支持环境保护决策;④评估交通可达性,优化城市交通网络;⑤监测城市扩张情况,辅助土地利用管理。 其他说明:该系统不仅提供了丰富的可视化工具,还集成了多种空间分析方法,能够帮助用户深入理解城市绿地的空间特征及其对环境和社会的影响。同时,系统支持移动端适配,方便随时随地进行分析。用户可以根据实际需求选择不同的分析模块,生成定制化的报告,为城市管理提供科学依据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值