综合Demo

这里主要是:Banner+网络判断+网络请求+XListView多条目+跑马灯+fragment+AlertDialog

上代码:首先布局

activity_main:

 <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        >

   <Button
       android:layout_weight="1"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:id="@+id/btn1"
       android:text="热门"
       android:background="@drawable/btn_selector"
       />
    <Button
        android:layout_weight="1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/btn2"
        android:text="分类"
        android:background="@drawable/btn_selector"
        />
    <Button
        android:layout_weight="1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/btn3"
        android:text="作者"
        android:background="@drawable/btn_selector"
        />
    </LinearLayout>

    <RelativeLayout
        android:id="@+id/rela"
        android:layout_width="match_parent"
        android:layout_height="match_parent"></RelativeLayout>
fragment01:

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


    <com.youth.banner.Banner
        android:layout_width="match_parent"
        android:layout_height="200dp"
        android:id="@+id/bannerer"
        ></com.youth.banner.Banner>



    <zhangxuelei1506d.mounth_demo.xListView.XListView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/xxxxxlist"
        ></zhangxuelei1506d.mounth_demo.xListView.XListView>

</LinearLayout>
fragment02:

    <TextView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:textSize="50dp"
        android:text="分类"
        />

fragment03:

<TextView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:textSize="50dp"
        android:text="作者"
        />
item:

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

    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/image_image"
        />
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/title_title"
        />

    <zhangxuelei1506d.mounth_demo.xListView.MarqueeTextView
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:ellipsize="marquee"
        android:marqueeRepeatLimit="marquee_forever"
        android:singleLine="true"
        android:text="我是跑马灯效果!!!,我是跑马灯效果!!!我是跑马灯效果!!!我是跑马灯效果!!!我是跑马灯效果!!!我是跑马灯效果!!!我是跑马灯效果!!!我是跑马灯效果!!!我是跑马灯效果!!!我是跑马灯效果!!!我是跑马灯效果!!!我是跑马灯效果!!!"/>

</LinearLayout>
开始编写类里面的代码:

MainActivity:

public class MainActivity extends FragmentActivity implements View.OnClickListener {

    private Fragment01 fragment01;
    private Fragment02 fragment02;
    private Fragment03 fragment03;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        boolean iscintent = Utils.iscintent(MainActivity.this);
        if(iscintent==true){

             Toast.makeText(this,"当前网络已连接",Toast.LENGTH_SHORT).show();
        }else{
            Toast.makeText(this,"当前网络已断开",Toast.LENGTH_SHORT).show();
            AlertDialog.Builder alterdialog=new AlertDialog.Builder(this);
            alterdialog.setTitle("警告");
            alterdialog.setMessage(" 通过移动数据访问?");
            alterdialog.setPositiveButton("确定", new DialogInterface.OnClickListener() {
                @Override
                public void onClick(DialogInterface dialog, int which) {
                    startActivity(new Intent(ACTION_WIRELESS_SETTINGS));

                }
            });
            alterdialog.setNegativeButton("取消",null);
            alterdialog.create();
            alterdialog.show();

        }


        Button button1 = (Button) findViewById(R.id.btn1);
        button1.setOnClickListener(this);
        Button button2 = (Button) findViewById(R.id.btn2);
        button2.setOnClickListener(this);
        Button button3 = (Button) findViewById(R.id.btn3);
        button3.setOnClickListener(this);

        fragment01 = new Fragment01();
        fragment02 = new Fragment02();
        fragment03 = new Fragment03();

        getSupportFragmentManager().beginTransaction().add(R.id.rela, fragment01).commit();
        getSupportFragmentManager().beginTransaction().add(R.id.rela, fragment02).commit();
        getSupportFragmentManager().beginTransaction().add(R.id.rela, fragment03).commit();
        getSupportFragmentManager().beginTransaction().show(fragment01).hide(fragment02).hide(fragment03).commit();

    }

    @Override
    public void onClick(View v) {

        switch (v.getId()) {

            case R.id.btn1:
                getSupportFragmentManager().beginTransaction().show(fragment01).hide(fragment02).hide(fragment03).commit();
                break;
            case R.id.btn2:
                getSupportFragmentManager().beginTransaction().show(fragment02).hide(fragment01).hide(fragment03).commit();
                break;
            case R.id.btn3:
                getSupportFragmentManager().beginTransaction().show(fragment03).hide(fragment01).hide(fragment02).commit();
                break;

        }


    }
}
fragment01:

public class Fragment01 extends Fragment implements XListView.IXListViewListener {
    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment01, container, false);


        List<String> images = new ArrayList();

        images.add("http://img3.imgtn.bdimg.com/it/u=3242709860,2221903223&fm=214&gp=0.jpg");
        images.add("http://pic.58pic.com/58pic/14/25/01/74w58PICP5D_1024.jpg");
        images.add("http://img1.imgtn.bdimg.com/it/u=3803696467,3357537026&fm=214&gp=0.jpg");
        images.add("http://img5.niutuku.com/phone/1301/3131/3131-niutuku.com-109273.jpg");
        Banner banner = (Banner) view.findViewById(R.id.bannerer);
        banner.setImageLoader(new GlideImageLoader());
        banner.setImages(images);
        banner.start();


        final XListView xListView = (XListView) view.findViewById(R.id.xxxxxlist);
        xListView.setXListViewListener(this);

        new AsyncTask<Void, Void, String>() {
            @Override
            protected String doInBackground(Void... params) {
                try {
                    URL url = new URL("http://huixinguiyu.cn/Assets/js/newsnew.js");
                    HttpURLConnection httpURLConnection = (HttpURLConnection) url.openConnection();
                    httpURLConnection.setRequestMethod("GET");
                    httpURLConnection.setConnectTimeout(8000);
                    httpURLConnection.setReadTimeout(8000);
                    int code = httpURLConnection.getResponseCode();
                    if (code == 200) {
                        InputStream inputStream = httpURLConnection.getInputStream();
                        ByteArrayOutputStream outputstream = new ByteArrayOutputStream();
                        int len = 0;
                        byte[] buffer = new byte[1024];
                        while ((len = inputStream.read(buffer)) != -1) {
                            outputstream.write(buffer, 0, len);

                        }
                        return outputstream.toString();
                    }
                } catch (MalformedURLException e) {
                    e.printStackTrace();
                } catch (IOException e) {
                    e.printStackTrace();
                }


                return null;
            }

            @Override
            protected void onPostExecute(String s) {
                super.onPostExecute(s);
                List<myBean.NewslistBean.NewsBean> list=new ArrayList<myBean.NewslistBean.NewsBean>();
                Gson gson=new Gson();
                myBean myBean = gson.fromJson(s, myBean.class);
                list=myBean.newslist.news;

                myBaseAdapter adapter=new myBaseAdapter(list,getActivity());
                xListView.setAdapter(adapter);


            }
        }.execute();


        return view;
    }

    @Override
    public void onRefresh() {

    }

    @Override
    public void onLoadMore() {

    }
}

fragment02:

public class Fragment02 extends Fragment{
    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment02, container, false);
        return view;
    }
}

fragment03:

public class Fragment03 extends Fragment{
    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment03, container, false);
        return view;
    }
}
适配器:

public class myBaseAdapter extends BaseAdapter {
    private List<myBean.NewslistBean.NewsBean> list;
    private Context context;

    public myBaseAdapter(List<myBean.NewslistBean.NewsBean> list, Context context) {
        this.list = list;
        this.context = context;
    }

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

    @Override
    public Object getItem(int position) {
        return list.get(position);
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        viewHolder holder = null;
        if (convertView == null) {
            holder = new viewHolder();
            convertView = convertView.inflate(context, R.layout.item, null);

            holder.image = (ImageView) convertView.findViewById(R.id.image_image);
            holder.title = (TextView) convertView.findViewById(R.id.title_title);

            convertView.setTag(holder);

        }else{
            holder= (viewHolder) convertView.getTag();

        }

        holder.title.setText(list.get(position).title);

        //这步骤是用imageloder加载图片的
                DisplayImageOptions displayImageOptions = new DisplayImageOptions.Builder()
                        .cacheInMemory(true)
                        .cacheOnDisk(true)  .build();
                ImageLoaderConfiguration config = new ImageLoaderConfiguration.Builder(context)
                        .defaultDisplayImageOptions(displayImageOptions)
                        .build();
                ImageLoader.getInstance().init(config);
                ImageLoader.getInstance().displayImage(list.get(position).image, holder.image);



        return convertView;
    }

    class viewHolder {

        ImageView image;
        TextView title;


    }
}


下面这些都是上面需要用到的一些工具类及javaBean:

Banner及Fresco的工具类:

public class GlideImageLoader extends ImageLoader{
    @Override
    public void displayImage(Context context, Object path, ImageView imageView) {
        Uri uri = Uri.parse((String) path);
        imageView.setImageURI(uri);
    }

    @Override
    public ImageView createImageView(Context context) {
        //使用fresco,需要创建它提供的ImageView,当然你也可以用自己自定义的具有图片加载功能的ImageView
        SimpleDraweeView simpleDraweeView=new SimpleDraweeView(context);
        return simpleDraweeView;
    }



}
Fresco初始化:
public class MyApplication extends Application{

    @Override
    public void onCreate() {
        super.onCreate();
        Fresco.initialize(this);
    }


}

javaBean类:

public class myBean {
    public NewslistBean newslist;
    public static myBean objectFromData(String str) {
        return new Gson().fromJson(str, myBean.class);
    }
    public static class NewslistBean {
        public List<NewsBean> news;
        public static NewslistBean objectFromData(String str) {

            return new Gson().fromJson(str, NewslistBean.class);
        }
        public static class NewsBean {
            public String title;
            public String detail;
            public String comment;
            public String image;
            public static NewsBean objectFromData(String str) {
                return new Gson().fromJson(str, NewsBean.class);
            }
        }
    }
}

判断手机网络类:

public class Utils {

    public static boolean iscintent(Context context) {
        ConnectivityManager mConnectivityManager = (ConnectivityManager) context
                .getSystemService(Context.CONNECTIVITY_SERVICE);
        NetworkInfo info = mConnectivityManager.getActiveNetworkInfo();
        if (info != null) {
            return true;
        }
        return false;
    }
}



这里还导入XListView的依赖(这个可以从我前面的博客找),

导入Gson jar包,

在清单文件里注册 

android:name=".MyApplication"




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 综合指挥大屏 Demo 是一个基于 Vue 框架开发的可视化大屏展示应用。该 Demo 主要目的是为了展示 Vue 前端技术的优势,以及如何将这些技术应用到实际场景中,从而提高工作效率和生产力。 该 Demo 主要有以下几个特点: 1. 具备可视化大屏展示能力:Vue 综合指挥大屏 Demo 通过图表、地图、表格等多种形式,将不同类型的数据进行可视化展示,从而方便用户对数据进行实时监测和分析。 2. 实现了数据的实时更新:通过 WebSocket 技术,Vue 综合指挥大屏 Demo 能够实时接收数据,并将其实时更新到展示界面上,从而保证数据的准确性和及时性。 3. 拥有良好的用户体验:Vue 综合指挥大屏 Demo 采用了响应式设计和自适应布局,能够在不同屏幕尺寸和设备上呈现出最佳展示效果。同时,Demo 也提供了交互性能强的界面,用户能够通过界面进行数据筛选、排序、搜索等操作,使得用户在使用过程中具有更好的操作体验和使用效果。 4. 关注安全性和可靠性:Vue 综合指挥大屏 Demo 所用的技术和程序均经过优化和测试,通过了严格的安全测试和质量保证,从而保证了系统的安全性和可靠性。 总之,Vue 综合指挥大屏 Demo 是一个基于 Vue 前端技术开发,具有可视化大屏展示、数据实时更新、良好用户体验、安全可靠等特点的自适应应用程序。在各种需要大屏展示和数据监测的场景中,都有广泛的应用前景。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值