程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> MyBatis主動生成Where語句

MyBatis主動生成Where語句

編輯:關於JAVA

MyBatis主動生成Where語句。本站提示廣大學習愛好者:(MyBatis主動生成Where語句)文章只能為提供參考,不一定能成為您想要的結果。以下是MyBatis主動生成Where語句正文


Google在2015的IO年夜會上,給我們帶來了加倍具體的Material Design設計標准,同時,也給我們帶來了全新的Android Design Support Library,在這個support庫外面,Google給我們供給了加倍標准的MD設計作風的控件。最主要的是,Android Design Support Library的兼容性更廣,直接可以向下兼容到Android 2.2。

這兩天須要做一個仿京東概況的頁面,下面的Tab切換,之前都是本身寫Viewpager+fragment,或許Indicator的深度定制,一向想測驗考試一下TabLayout,因而就有了上面的坑。


然後上面是我簡略的完成後果(小我認為很坑,還不如本身自界說的導航器)


添加援用庫

dependencies {
  compile fileTree(dir: 'libs', include: ['*.jar'])
  compile 'com.android.support:appcompat-v7:24.2.0'
  compile 'com.android.support:design:24.2.0'
  compile 'com.android.support:recyclerview-v7:24.2.0'
  compile 'com.android.support:cardview-v7:24.2.0'
}

Toolbar與TabLayout

我們來看一下完成的結構:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:app="http://schemas.android.com/apk/res-auto"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="vertical">

  <android.support.v7.widget.Toolbar
    android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="48dp"
    android:gravity="center_vertical"
    app:navigationIcon="@drawable/back_icon"
   >

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

      <android.support.design.widget.TabLayout
        android:id="@+id/tabLayout"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        
        />

    </LinearLayout>

    <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_gravity="right"
      android:background="@drawable/more_icon" />

  </android.support.v7.widget.Toolbar>

  <View  />

  <android.support.v4.view.ViewPager
    android:id="@+id/viewPager"
    android:layout_width="match_parent"
    android:layout_height="match_parent" />
</LinearLayout>

這結構文件最症結的一點就是android.support.design.widget.TabLayout 標簽中的app:tabMode=”scrollable”,他設置tab的形式為“可滑動的”。

其他的用法和Indicator的用法差不多,都須要設置適配器,然後經由過程數據完成頁面的適配。直接上代碼

Adapter

public class ProductDetailPagerAdapter extends FragmentPagerAdapter {

  private List<String> mTitles;

  public ProductDetailPagerAdapter(FragmentManager fm, List<String> mTitles) {
    super(fm);
    this.mTitles = mTitles;
  }

  @Override
  public Fragment getItem(int position) {
    if (position == 0) {
      return new ProductFragment();
    } else if (position == 1) {
      return new ProductDetailFragment();
    }
    return new ProductFragment();
  }

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

  @Override
  public CharSequence getPageTitle(int position) {
    return mTitles.get(position);
  }
}

主頁面的相干邏輯,這裡的Fragment就是簡略的Fragment。

public class ProductDetailsActivity extends BaseActivity {

  @BindView(R.id.viewPager)
  ViewPager viewPager;
  @BindView(R.id.tabLayout)
  TabLayout tabLayout;
  @BindView(R.id.toolbar)
  Toolbar toolbar;

  private TextView tabProduct;
  private TextView tabDetail;

  private List<String> mTitles = null;
  private ProductDetailPagerAdapter productPagerAdapter = null;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_product_details);
    ButterKnife.bind(this);
    init();
  }

  private void init() {
    initToolbar();
    initViewPager();
  }

  private void initToolbar() {
    setTitle("");
    toolbar.setNavigationOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View view) {
        finish();
      }
    });
    initTab();
    initTabChange();
  }

  private void initTabChange() {
    tabLayout.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
      @Override
      public void onTabSelected(TabLayout.Tab tab) {
        viewPager.setCurrentItem(tab.getPosition());
        switch (tab.getPosition()){
          case 0:
            tabProduct.setTextColor(getResources().getColor(R.color.c8));
            tabProduct.setTextSize(18);
            break;

          case 1:
            tabDetail.setTextColor(getResources().getColor(R.color.c8));
            tabDetail.setTextSize(18);
            break;
        }
      }

      @Override
      public void onTabUnselected(TabLayout.Tab tab) {
        tabProduct.setTextColor(getResources().getColor(R.color.c7));
        tabDetail.setTextColor(getResources().getColor(R.color.c7));
      }

      @Override
      public void onTabReselected(TabLayout.Tab tab) {

      }
    });
  }

  private void initTab() {
    tabLayout.setSelectedTabIndicatorColor(getResources().getColor(R.color.c8));
    tabLayout.setSelectedTabIndicatorHeight(UIUtils.dp2px(this, 2));
    tabLayout.setTabTextColors(R.color.c7, R.color.c8);

    tabLayout.addTab(tabLayout.newTab().setCustomView(R.layout.item_detail_tab_product_layout));
    tabProduct= (TextView) findViewById(R.id.tab_product);
    tabProduct.setTextColor(getResources().getColor(R.color.c8));

    tabLayout.addTab(tabLayout.newTab().setCustomView(R.layout.item_detail_tab_detail_layout));
    tabDetail= (TextView) findViewById(R.id.tab_detail);
    tabProduct.setTextColor(getResources().getColor(R.color.c7));
    
  }

  private void initViewPager() {
    mTitles = new ArrayList<>();
    mTitles.add("商品");
    mTitles.add("概況");
    productPagerAdapter = new ProductDetailPagerAdapter(getSupportFragmentManager(), mTitles);
    viewPager.setAdapter(productPagerAdapter);
    viewPager.addOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() {
      @Override
      public void onPageSelected(int position) {
        tabLayout.getTabAt(position).select();
      }
    });
  }


  public static void open(Context context) {
    Intent intent = new Intent(context, ProductDetailsActivity.class);
    context.startActivity(intent);
  }
}

我信任許多人看了下面的代碼會認為很費事,其實我也認為,這類固然可定制高,然則絕對於之前的寫法,代碼涓滴沒有削減,我照樣建議應用自界說控件,之前有一篇Android全能的指導器,年夜家可以自創自創。

以上就是本文的全體內容,願望對年夜家的進修有所贊助,也願望年夜家多多支撐。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved