当前位置: 首页 > news >正文

检查网站的跳转路径是否清晰 哪里要优化杭州免费网站制作

检查网站的跳转路径是否清晰 哪里要优化,杭州免费网站制作,建设金融网站,ui设计师创意平台我的项目源码托管地址:点击打开我的项目源码地址 来先看一下效果吧(虚拟机录制卡卡的,而且上传图片大小限制) 如果平时用app仔细的话可以不难发现一些介绍页面是顶部图片下边文字,或者顶部大图下面小图列表介绍&#…

我的项目源码托管地址:点击打开我的项目源码地址


来先看一下效果吧(虚拟机录制卡卡的,而且上传图片大小限制)


如果平时用app仔细的话可以不难发现一些介绍页面是顶部图片下边文字,或者顶部大图下面小图列表介绍,原来没有v7的时候需要自己进行手势事件的处理,现在有了然后感觉系统的一些空间就帮你处理了,还是根据代码说问题吧,先看activity的代码

package com.fanyafeng.materialdesign.activity;import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.StaggeredGridLayoutManager;
import android.support.v7.widget.Toolbar;
import android.view.View;import com.fanyafeng.materialdesign.BaseActivity;
import com.fanyafeng.materialdesign.Constant.MaterialDesignConstant;
import com.fanyafeng.materialdesign.R;
import com.fanyafeng.materialdesign.adapter.RVAdapter;
import com.fanyafeng.materialdesign.fragment.ViewPagerFragment;
import com.fanyafeng.materialdesign.util.FitScreenUtil;
import com.fanyafeng.materialdesign.util.MyUtils;import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;public class StaggeredActivity extends BaseActivity {private final static String[] imgList = {"http://img3.imgtn.bdimg.com/it/u=1592877738,3666022423&fm=21&gp=0.jpg","http://img5.imgtn.bdimg.com/it/u=3455823481,3036827216&fm=21&gp=0.jpg","","http://img3.imgtn.bdimg.com/it/u=270179915,2007129802&fm=21&gp=0.jpg","http://img3.imgtn.bdimg.com/it/u=1255836822,4097950891&fm=21&gp=0.jpg"};private List<Fragment> fragmentList;private ViewPager staggerViewpager;private RecyclerView rvStagger;private List<String> stringList;private RVAdapter rvAdapter;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_staggered);title = "测试viewpager和toolbar的嵌套";FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);fab.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View view) {Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG).setAction("Action", null).show();}});initView();initData();}private void initView() {staggerViewpager = (ViewPager) findViewById(R.id.staggerViewpager);fragmentList = new ArrayList<>();for (int i = 0; i < 4; i++) {ViewPagerFragment viewPagerFragment = new ViewPagerFragment();Bundle bundle = new Bundle();bundle.putString("img", imgList[i]);viewPagerFragment.setArguments(bundle);fragmentList.add(viewPagerFragment);}staggerViewpager.setAdapter(new PagerAdapter(getSupportFragmentManager(), fragmentList));staggerViewpager.setCurrentItem(0);rvStagger = (RecyclerView) findViewById(R.id.rvStagger);rvStagger.setHasFixedSize(true);}private void initData() {stringList = new ArrayList<>();stringList = Arrays.asList(MaterialDesignConstant.imageList);rvAdapter = new RVAdapter(this, stringList);rvStagger.setLayoutManager(new StaggeredGridLayoutManager(2, StaggeredGridLayoutManager.VERTICAL));rvStagger.setAdapter(rvAdapter);}class PagerAdapter extends FragmentPagerAdapter {private List<Fragment> fragmentList;public PagerAdapter(FragmentManager fm, List<Fragment> fragmentList) {super(fm);this.fragmentList = fragmentList;}@Overridepublic Fragment getItem(int position) {return fragmentList.get(position);}@Overridepublic int getCount() {return fragmentList.size();}}}
再看它的两个xml代码

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:fitsSystemWindows="false"tools:context="com.fanyafeng.materialdesign.activity.StaggeredActivity"><android.support.design.widget.AppBarLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:theme="@style/AppTheme.AppBarOverlay"><android.support.design.widget.CollapsingToolbarLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:fitsSystemWindows="true"app:contentScrim="?attr/colorPrimary"app:expandedTitleMarginEnd="64dp"app:expandedTitleMarginStart="48dp"app:layout_scrollFlags="scroll|exitUntilCollapsed"><RelativeLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"><com.fanyafeng.materialdesign.view.WrapContentPagerandroid:id="@+id/staggerViewpager"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_gravity="center" /></RelativeLayout><android.support.v7.widget.Toolbarandroid:id="@+id/toolbar"android:layout_width="match_parent"android:layout_height="?attr/actionBarSize"android:background="@android:color/transparent"app:layout_collapseMode="pin"app:popupTheme="@style/AppTheme.PopupOverlay" /></android.support.design.widget.CollapsingToolbarLayout></android.support.design.widget.AppBarLayout><include layout="@layout/content_staggered" /><android.support.design.widget.FloatingActionButtonandroid:id="@+id/fab"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="bottom|end"android:layout_margin="@dimen/fab_margin"android:src="@android:drawable/ic_dialog_email" /></android.support.design.widget.CoordinatorLayout>

第二个xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"app:layout_behavior="@string/appbar_scrolling_view_behavior"tools:context="com.fanyafeng.materialdesign.activity.StaggeredActivity"tools:showIn="@layout/activity_staggered"><android.support.v7.widget.RecyclerViewandroid:id="@+id/rvStagger"android:layout_width="match_parent"android:layout_height="match_parent" /></RelativeLayout>

再来看fragment

package com.fanyafeng.materialdesign.fragment;import android.content.Context;
import android.net.Uri;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.support.v4.view.ViewPager;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;import com.facebook.drawee.view.SimpleDraweeView;
import com.fanyafeng.materialdesign.R;
import com.fanyafeng.materialdesign.util.ControllerListenerUtil;
import com.fanyafeng.materialdesign.util.MyUtils;/*** A simple {@link Fragment} subclass.* Activities that contain this fragment must implement the* to handle interaction events.* Use the {@link ViewPagerFragment#newInstance} factory method to* create an instance of this fragment.*/
public class ViewPagerFragment extends Fragment {// TODO: Rename parameter arguments, choose names that match// the fragment initialization parameters, e.g. ARG_ITEM_NUMBERprivate static final String ARG_PARAM1 = "img";private static final String ARG_PARAM2 = "param2";// TODO: Rename and change types of parametersprivate String mParam1;private String mParam2;private View view;private SimpleDraweeView itemViewpager;public ViewPagerFragment() {// Required empty public constructor}/*** Use this factory method to create a new instance of* this fragment using the provided parameters.** @param param1 Parameter 1.* @param param2 Parameter 2.* @return A new instance of fragment ViewPagerFragment.*/// TODO: Rename and change types and number of parameterspublic static ViewPagerFragment newInstance(String param1, String param2) {ViewPagerFragment fragment = new ViewPagerFragment();Bundle args = new Bundle();args.putString(ARG_PARAM1, param1);args.putString(ARG_PARAM2, param2);fragment.setArguments(args);return fragment;}@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);if (getArguments() != null) {mParam1 = getArguments().getString(ARG_PARAM1);mParam2 = getArguments().getString(ARG_PARAM2);}}@Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {// Inflate the layout for this fragmentview = inflater.inflate(R.layout.fragment_view_pager, container, false);return view;}@Overridepublic void onActivityCreated(@Nullable Bundle savedInstanceState) {super.onActivityCreated(savedInstanceState);initView();initData();}private void initView() {itemViewpager = (SimpleDraweeView) view.findViewById(R.id.itemViewpager);itemViewpager.setAspectRatio(1.6024f);itemViewpager.setImageURI(Uri.parse(mParam1));
//
//        ControllerListenerUtil.setControllerListener(itemViewpager, mParam1, MyUtils.getScreenWidth(getActivity()), getActivity());}private void initData() {}}
fragment的xml

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="wrap_content"tools:context="com.fanyafeng.materialdesign.fragment.ViewPagerFragment"><com.facebook.drawee.view.SimpleDraweeViewandroid:id="@+id/itemViewpager"android:layout_width="match_parent"android:layout_height="wrap_content"app:viewAspectRatio="1.6024" /></FrameLayout>

再有就是rvadapter

package com.fanyafeng.materialdesign.adapter;import android.content.Context;
import android.net.Uri;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;import com.andview.refreshview.recyclerview.BaseRecyclerAdapter;
import com.facebook.drawee.view.SimpleDraweeView;
import com.fanyafeng.materialdesign.R;
import com.fanyafeng.materialdesign.util.ControllerListenerUtil;
import com.fanyafeng.materialdesign.util.MyUtils;import java.util.List;/*** Created by 365rili on 16/6/14.*/
public class RVAdapter extends BaseRecyclerAdapter<RVAdapter.ViewHolder> {private Context context;private List<String> stringList;public RVAdapter(Context context, List<String> stringList) {this.context = context;this.stringList = stringList;}public OnItemClickListener onItemClickListener;public void setOnItemClickListener(OnItemClickListener onItemClickListener) {this.onItemClickListener = onItemClickListener;}public interface OnItemClickListener {void onItemClickListener(View view, String string, int position);void onItemLongClickListener(View view, String string, int position);}@Overridepublic ViewHolder getViewHolder(View view) {return new ViewHolder(view);}@Overridepublic ViewHolder onCreateViewHolder(ViewGroup parent, int viewType, boolean isItem) {View view = LayoutInflater.from(context).inflate(R.layout.item_rv_layout, parent, false);return new ViewHolder(view);}@Overridepublic void onBindViewHolder(ViewHolder holder, final int position, boolean isItem) {
//        holder.sdvRvItem.setImageURI(Uri.parse(stringList.get(position)));
//        holder.sdvRvItem.setControllerListenerUtil.setControllerListener(holder.sdvRvItem, stringList.get(position), MyUtils.getScreenWidth(context) >> 1, context);if (onItemClickListener != null) {holder.sdvRvItem.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {onItemClickListener.onItemClickListener(v, stringList.get(position), position);}});holder.sdvRvItem.setOnLongClickListener(new View.OnLongClickListener() {@Overridepublic boolean onLongClick(View v) {onItemClickListener.onItemClickListener(v, stringList.get(position), position);return false;}});}}@Overridepublic int getAdapterItemCount() {return stringList.size();}public class ViewHolder extends RecyclerView.ViewHolder {private SimpleDraweeView sdvRvItem;public ViewHolder(View itemView) {super(itemView);sdvRvItem = (SimpleDraweeView) itemView.findViewById(R.id.sdvRvItem);}}
}

简单来说一下demo的结构,toolbar,viewpager(viewpager是采用fragment的方式进行实现的),recyclerview瀑布流

这里用的viewpager是自己写的进行自适应的

package com.fanyafeng.materialdesign.view;import android.content.Context;
import android.support.v4.view.ViewPager;
import android.util.AttributeSet;
import android.view.View;/*** Created by zgw on 15/7/23 上午12:45.*/
public class WrapContentPager extends ViewPager {public WrapContentPager(Context context) {super(context);}public WrapContentPager(Context context, AttributeSet attrs) {super(context, attrs);}@Overrideprotected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {int height = 0;for (int i = 0; i < getChildCount(); i++) {View child = getChildAt(i);child.measure(widthMeasureSpec, MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED));int h = child.getMeasuredHeight();if (h > height) height = h;}heightMeasureSpec = MeasureSpec.makeMeasureSpec(height, MeasureSpec.EXACTLY);super.onMeasure(widthMeasureSpec, heightMeasureSpec);}}
这里说一下collapsingtoolbarlayout默认是全部展开,也就是toolbar默认的background,收起的时候是theme主题,可以进行响应的自定义,今天博客好卡,先写到这,以后补充


http://www.yidumall.com/news/16866.html

相关文章:

  • 简单官网模板seo同行网站
  • wordpress菜单栏插件北京seo地址
  • 怎么做自己的网购网站谷歌搜索引擎镜像入口
  • 建设网站号码北京百度推广公司
  • 成都 网站建设培训网站seo推广平台
  • 网页和网站有什么关系晨阳seo服务
  • 如何做网站啊网站seo提升
  • 营销型企业网站建设教案网站建站设计
  • 南宁网站建设招聘搜索引擎营销分析
  • 秦皇岛黄页大全秦皇岛本地信息网济南百度seo
  • 域名 网站宽带营销案例100例
  • 2008r2网站建设搜狗推广
  • 怎么在网上建网站啊在线网页编辑平台
  • 网站反链数4p 4c 4r营销理论区别
  • 哪个网站可以做问卷调查掉发脱发严重是什么原因
  • 手机网站建设公司电话咨询软文的概念
  • 中低端网站建设客户网优化20条措施
  • 晋源网站建设网站注册域名
  • 安宁网站建设与制作360seo关键词优化
  • 焦作网站建设哪家权威企业网站制作公司
  • 如何做新网站保留域名域名注册哪个网站好
  • 考研培训机构排名前五的机构网站信息组织优化
  • 三明做网站seo是什么岗位
  • 静态网页设计网站制作下列关于友情链接说法正确的是
  • 网站开发按钮图片素材百度推广账户登录首页
  • 淘宝二官方网站是做啥的seo怎么做?
  • 合肥公司建站模板哪个推广平台推广最靠谱
  • 做网站和做网页有啥区别小红书关键词检测
  • 做网站 写脚本是什么企业培训方案
  • 珠海网站广州新闻热点事件