Commit b9b5e32e932b577966989ede790baa37c6350e12
Exists in
yxb_dev
and in
2 other branches
Merge branch 'developer' into yxb_dev
# Conflicts: # app/src/main/java/com/shunzhi/parent/ui/activity/WebViewActivity.java
Showing
25 changed files
with
298 additions
and
76 deletions
Show diff stats
app/src/main/AndroidManifest.xml
| @@ -112,7 +112,8 @@ | @@ -112,7 +112,8 @@ | ||
| 112 | android:name=".ui.activity.WebViewActivity" | 112 | android:name=".ui.activity.WebViewActivity" |
| 113 | android:screenOrientation="portrait" /> | 113 | android:screenOrientation="portrait" /> |
| 114 | <activity android:name=".ui.activity.consult.ConsultTwoLevelActivity" /> | 114 | <activity android:name=".ui.activity.consult.ConsultTwoLevelActivity" /> |
| 115 | - <activity android:name=".ui.activity.orderdetail.OrderDetailActivity"></activity> | 115 | + <activity android:name=".ui.activity.orderdetail.OrderDetailActivity" /> |
| 116 | + <activity android:name=".ui.activity.WebViewActivity"></activity> | ||
| 116 | </application> | 117 | </application> |
| 117 | 118 | ||
| 118 | </manifest> | 119 | </manifest> |
| 119 | \ No newline at end of file | 120 | \ No newline at end of file |
app/src/main/java/com/shunzhi/parent/AppConfig.java
| @@ -28,6 +28,7 @@ public class AppConfig { | @@ -28,6 +28,7 @@ public class AppConfig { | ||
| 28 | public static int ORDER_CENTER = 3; | 28 | public static int ORDER_CENTER = 3; |
| 29 | 29 | ||
| 30 | public static String USER_ID="user_id"; | 30 | public static String USER_ID="user_id"; |
| 31 | + public static String APP_IS_START="app_is_start"; | ||
| 31 | 32 | ||
| 32 | //http://campus.myjxt.com/ | 33 | //http://campus.myjxt.com/ |
| 33 | public static String BASE_URL="http://60.190.202.57:1000/"; | 34 | public static String BASE_URL="http://60.190.202.57:1000/"; |
app/src/main/java/com/shunzhi/parent/AppContext.java
| @@ -19,7 +19,7 @@ public class AppContext extends GlobalApplication { | @@ -19,7 +19,7 @@ public class AppContext extends GlobalApplication { | ||
| 19 | 19 | ||
| 20 | public final static int LOCATION_CITYNAME=0x00; | 20 | public final static int LOCATION_CITYNAME=0x00; |
| 21 | 21 | ||
| 22 | - public String cityName=""; | 22 | + public String cityName="",district=""; |
| 23 | 23 | ||
| 24 | public static AppContext getInstance() { | 24 | public static AppContext getInstance() { |
| 25 | return appContext; | 25 | return appContext; |
| @@ -99,15 +99,15 @@ public class AppContext extends GlobalApplication { | @@ -99,15 +99,15 @@ public class AppContext extends GlobalApplication { | ||
| 99 | 99 | ||
| 100 | if (aMapLocation.getErrorCode()==0){ | 100 | if (aMapLocation.getErrorCode()==0){ |
| 101 | cityName=aMapLocation.getCity(); | 101 | cityName=aMapLocation.getCity(); |
| 102 | + district=aMapLocation.getDistrict(); | ||
| 102 | aMapLocation.getCityCode(); | 103 | aMapLocation.getCityCode(); |
| 103 | - Log.d("mlocation:","handler="+handler); | ||
| 104 | Intent intent=new Intent(); | 104 | Intent intent=new Intent(); |
| 105 | intent.setAction(LOCATION_CITYNAME+""); | 105 | intent.setAction(LOCATION_CITYNAME+""); |
| 106 | sendBroadcast(intent); | 106 | sendBroadcast(intent); |
| 107 | stopLocation(); | 107 | stopLocation(); |
| 108 | }else { | 108 | }else { |
| 109 | cityName="定位失败"; | 109 | cityName="定位失败"; |
| 110 | - Log.d("mlocation:","errorCode="+aMapLocation.getErrorCode()+"errorInfo="+aMapLocation.getErrorInfo()); | 110 | +// Log.d("mlocation:","errorCode="+aMapLocation.getErrorCode()+"errorInfo="+aMapLocation.getErrorInfo()); |
| 111 | } | 111 | } |
| 112 | 112 | ||
| 113 | } | 113 | } |
app/src/main/java/com/shunzhi/parent/contract/ceping/CepingContract.java
app/src/main/java/com/shunzhi/parent/presenter/ceping/CePingPresenter.java
| 1 | package com.shunzhi.parent.presenter.ceping; | 1 | package com.shunzhi.parent.presenter.ceping; |
| 2 | 2 | ||
| 3 | +import android.util.Log; | ||
| 3 | import android.view.View; | 4 | import android.view.View; |
| 4 | import android.widget.LinearLayout; | 5 | import android.widget.LinearLayout; |
| 5 | 6 | ||
| @@ -10,6 +11,7 @@ import com.shunzhi.parent.R; | @@ -10,6 +11,7 @@ import com.shunzhi.parent.R; | ||
| 10 | import com.shunzhi.parent.bean.ToolBean; | 11 | import com.shunzhi.parent.bean.ToolBean; |
| 11 | import com.shunzhi.parent.contract.ceping.CepingContract; | 12 | import com.shunzhi.parent.contract.ceping.CepingContract; |
| 12 | import com.shunzhi.parent.model.CePingModel; | 13 | import com.shunzhi.parent.model.CePingModel; |
| 14 | +import com.shunzhi.parent.ui.activity.WebViewActivity; | ||
| 13 | import com.shunzhi.parent.util.AttrsUtils; | 15 | import com.shunzhi.parent.util.AttrsUtils; |
| 14 | import com.shunzhi.parent.views.TextAndImgShowView; | 16 | import com.shunzhi.parent.views.TextAndImgShowView; |
| 15 | 17 | ||
| @@ -42,22 +44,26 @@ public class CePingPresenter extends CepingContract.CePingPresenter { | @@ -42,22 +44,26 @@ public class CePingPresenter extends CepingContract.CePingPresenter { | ||
| 42 | public void accept(JsonObject jsonObject) throws Exception { | 44 | public void accept(JsonObject jsonObject) throws Exception { |
| 43 | if (jsonObject.get("status").getAsString().equals("1")){ | 45 | if (jsonObject.get("status").getAsString().equals("1")){ |
| 44 | JsonArray jsonArray=jsonObject.getAsJsonArray("data"); | 46 | JsonArray jsonArray=jsonObject.getAsJsonArray("data"); |
| 47 | + layout_control.removeAllViews(); | ||
| 45 | for (int i = 0; i < jsonArray.size(); i++) { | 48 | for (int i = 0; i < jsonArray.size(); i++) { |
| 46 | ToolBean toolBean=new Gson().fromJson(jsonArray.get(i).getAsJsonObject(),ToolBean.class); | 49 | ToolBean toolBean=new Gson().fromJson(jsonArray.get(i).getAsJsonObject(),ToolBean.class); |
| 47 | TextAndImgShowView textAndImgShowView=new TextAndImgShowView(mIView.getBindActivity()); | 50 | TextAndImgShowView textAndImgShowView=new TextAndImgShowView(mIView.getBindActivity()); |
| 48 | textAndImgShowView.setTextColor(R.color.textColor); | 51 | textAndImgShowView.setTextColor(R.color.textColor); |
| 49 | textAndImgShowView.setText(toolBean.toolName); | 52 | textAndImgShowView.setText(toolBean.toolName); |
| 50 | - textAndImgShowView.setImgs(R.drawable.play, Integer.parseInt(toolBean.toolImage)); | 53 | + textAndImgShowView.addImgs(toolBean.toolImage); |
| 51 | textAndImgShowView.setSelect(true); | 54 | textAndImgShowView.setSelect(true); |
| 52 | textAndImgShowView.setWidth(mIView.getBindActivity(),layout_control); | 55 | textAndImgShowView.setWidth(mIView.getBindActivity(),layout_control); |
| 53 | textAndImgShowView.setBackground(AttrsUtils.getAttrs(mIView.getBindActivity()).getDrawable(0)); | 56 | textAndImgShowView.setBackground(AttrsUtils.getAttrs(mIView.getBindActivity()).getDrawable(0)); |
| 57 | + textAndImgShowView.setTag(toolBean); | ||
| 54 | textAndImgShowView.setOnClickListener(new View.OnClickListener() { | 58 | textAndImgShowView.setOnClickListener(new View.OnClickListener() { |
| 55 | @Override | 59 | @Override |
| 56 | public void onClick(View view) { | 60 | public void onClick(View view) { |
| 57 | - | 61 | + ToolBean toolBean1= (ToolBean) view.getTag(); |
| 62 | + WebViewActivity.getInstance(mIView.getBindActivity(),toolBean1.toolUrl); | ||
| 58 | } | 63 | } |
| 59 | }); | 64 | }); |
| 60 | layout_control.addView(textAndImgShowView); | 65 | layout_control.addView(textAndImgShowView); |
| 66 | + mIView.showTools(); | ||
| 61 | } | 67 | } |
| 62 | }else { | 68 | }else { |
| 63 | 69 | ||
| @@ -89,7 +95,7 @@ public class CePingPresenter extends CepingContract.CePingPresenter { | @@ -89,7 +95,7 @@ public class CePingPresenter extends CepingContract.CePingPresenter { | ||
| 89 | } | 95 | } |
| 90 | }); | 96 | }); |
| 91 | layout_control.addView(textAndImgShowView); | 97 | layout_control.addView(textAndImgShowView); |
| 92 | - } | ||
| 93 | - mIView.showTools(toolBeanList);*/ | 98 | + }*/ |
| 99 | +// mIView.showTools(toolBeanList); | ||
| 94 | } | 100 | } |
| 95 | } | 101 | } |
app/src/main/java/com/shunzhi/parent/presenter/consult/ConsultPresenter.java
| @@ -40,7 +40,7 @@ public class ConsultPresenter extends ConsultContract.ConsultPresenter { | @@ -40,7 +40,7 @@ public class ConsultPresenter extends ConsultContract.ConsultPresenter { | ||
| 40 | TextAndImgShowView textAndImgShowView=new TextAndImgShowView(mIView.getBindActivity()); | 40 | TextAndImgShowView textAndImgShowView=new TextAndImgShowView(mIView.getBindActivity()); |
| 41 | textAndImgShowView.setTextColor(R.color.textColor); | 41 | textAndImgShowView.setTextColor(R.color.textColor); |
| 42 | textAndImgShowView.setText(toolBeanList.get(i).toolName); | 42 | textAndImgShowView.setText(toolBeanList.get(i).toolName); |
| 43 | - textAndImgShowView.setImgs(R.drawable.play, Integer.parseInt(toolBeanList.get(i).toolImg)); | 43 | + textAndImgShowView.setImgs(R.drawable.play, Integer.parseInt(toolBeanList.get(i).toolImage)); |
| 44 | textAndImgShowView.setSelect(true); | 44 | textAndImgShowView.setSelect(true); |
| 45 | textAndImgShowView.setWidth(mIView.getBindActivity(),layout_control); | 45 | textAndImgShowView.setWidth(mIView.getBindActivity(),layout_control); |
| 46 | textAndImgShowView.setBackground(AttrsUtils.getAttrs(mIView.getBindActivity()).getDrawable(0)); | 46 | textAndImgShowView.setBackground(AttrsUtils.getAttrs(mIView.getBindActivity()).getDrawable(0)); |
app/src/main/java/com/shunzhi/parent/presenter/consult/consultone/ConsultOnePresenter.java
| @@ -38,7 +38,7 @@ public class ConsultOnePresenter extends ConsultOneContract.ConsultOnePresenter{ | @@ -38,7 +38,7 @@ public class ConsultOnePresenter extends ConsultOneContract.ConsultOnePresenter{ | ||
| 38 | TextAndImgShowView textAndImgShowView=new TextAndImgShowView(mIView.getBindActivity()); | 38 | TextAndImgShowView textAndImgShowView=new TextAndImgShowView(mIView.getBindActivity()); |
| 39 | textAndImgShowView.setTextColor(R.color.textColor); | 39 | textAndImgShowView.setTextColor(R.color.textColor); |
| 40 | textAndImgShowView.setText(toolBeanList.get(i).toolName); | 40 | textAndImgShowView.setText(toolBeanList.get(i).toolName); |
| 41 | - textAndImgShowView.setImgs(R.drawable.play, Integer.parseInt(toolBeanList.get(i).toolImg)); | 41 | + textAndImgShowView.setImgs(R.drawable.play, Integer.parseInt(toolBeanList.get(i).toolImage)); |
| 42 | textAndImgShowView.setSelect(true); | 42 | textAndImgShowView.setSelect(true); |
| 43 | textAndImgShowView.setWidth(mIView.getBindActivity(),layout_control); | 43 | textAndImgShowView.setWidth(mIView.getBindActivity(),layout_control); |
| 44 | textAndImgShowView.setBackground(AttrsUtils.getAttrs(mIView.getBindActivity()).getDrawable(0)); | 44 | textAndImgShowView.setBackground(AttrsUtils.getAttrs(mIView.getBindActivity()).getDrawable(0)); |
app/src/main/java/com/shunzhi/parent/ui/activity/StartActivity.java
| 1 | package com.shunzhi.parent.ui.activity; | 1 | package com.shunzhi.parent.ui.activity; |
| 2 | 2 | ||
| 3 | import android.os.Bundle; | 3 | import android.os.Bundle; |
| 4 | +import android.support.v4.app.FragmentTransaction; | ||
| 4 | import android.support.v4.view.ViewPager; | 5 | import android.support.v4.view.ViewPager; |
| 5 | import android.view.View; | 6 | import android.view.View; |
| 6 | import android.widget.ImageView; | 7 | import android.widget.ImageView; |
| @@ -8,6 +9,7 @@ import android.widget.ImageView; | @@ -8,6 +9,7 @@ import android.widget.ImageView; | ||
| 8 | import com.bumptech.glide.Glide; | 9 | import com.bumptech.glide.Glide; |
| 9 | import com.share.mvpsdk.base.activity.BaseCompatActivity; | 10 | import com.share.mvpsdk.base.activity.BaseCompatActivity; |
| 10 | import com.shunzhi.parent.R; | 11 | import com.shunzhi.parent.R; |
| 12 | +import com.shunzhi.parent.ui.fragment.StartFragment; | ||
| 11 | import com.stx.xhb.xbanner.XBanner; | 13 | import com.stx.xhb.xbanner.XBanner; |
| 12 | 14 | ||
| 13 | import java.util.ArrayList; | 15 | import java.util.ArrayList; |
| @@ -15,44 +17,19 @@ import java.util.List; | @@ -15,44 +17,19 @@ import java.util.List; | ||
| 15 | 17 | ||
| 16 | public class StartActivity extends BaseCompatActivity { | 18 | public class StartActivity extends BaseCompatActivity { |
| 17 | 19 | ||
| 18 | - XBanner xBanner; | ||
| 19 | - List<String> imgUrl=new ArrayList<>(); | ||
| 20 | - @Override | ||
| 21 | - protected void initView(Bundle savedInstanceState) { | ||
| 22 | - | ||
| 23 | - xBanner=findViewById(R.id.xBanner); | ||
| 24 | - | ||
| 25 | - imgUrl.add(getClass().getResource("/assets/yindao1.png").toString()); | ||
| 26 | - imgUrl.add(getClass().getResource("/assets/yindao2.png").toString()); | ||
| 27 | - imgUrl.add(getClass().getResource("/assets/yindao3.png").toString()); | ||
| 28 | - imgUrl.add(getClass().getResource("/assets/yindao4.png").toString()); | ||
| 29 | - xBanner.setData(imgUrl,null); | ||
| 30 | - xBanner.setmAutoPlayAble(false); | 20 | + FragmentTransaction fragmentTransaction=null; |
| 31 | 21 | ||
| 32 | - xBanner.setmAdapter(new XBanner.XBannerAdapter() { | ||
| 33 | - @Override | ||
| 34 | - public void loadBanner(XBanner banner, Object model, View view, int position) { | ||
| 35 | - Glide.with(StartActivity.this).load(imgUrl.get(position)).placeholder(R.drawable.ic_launcher_background) | ||
| 36 | - .into((ImageView) view); | ||
| 37 | - } | ||
| 38 | - }); | 22 | + StartFragment startFragment=null; |
| 39 | 23 | ||
| 40 | - xBanner.setOnPageChangeListener(new ViewPager.OnPageChangeListener() { | ||
| 41 | - @Override | ||
| 42 | - public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { | ||
| 43 | - | ||
| 44 | - } | 24 | + @Override |
| 25 | + protected void initView(Bundle savedInstanceState) { | ||
| 45 | 26 | ||
| 46 | - @Override | ||
| 47 | - public void onPageSelected(int position) { | 27 | + fragmentTransaction=getSupportFragmentManager().beginTransaction(); |
| 48 | 28 | ||
| 49 | - } | 29 | + startFragment=new StartFragment(); |
| 50 | 30 | ||
| 51 | - @Override | ||
| 52 | - public void onPageScrollStateChanged(int state) { | 31 | + fragmentTransaction.add(R.id.frame_start,startFragment).show(startFragment).commit(); |
| 53 | 32 | ||
| 54 | - } | ||
| 55 | - }); | ||
| 56 | } | 33 | } |
| 57 | 34 | ||
| 58 | @Override | 35 | @Override |
app/src/main/java/com/shunzhi/parent/ui/fragment/CePingFragment.java
| @@ -93,7 +93,7 @@ public class CePingFragment extends BaseMVPCompatFragment<CepingContract.CePingP | @@ -93,7 +93,7 @@ public class CePingFragment extends BaseMVPCompatFragment<CepingContract.CePingP | ||
| 93 | 93 | ||
| 94 | private void addTools() { | 94 | private void addTools() { |
| 95 | layout_control.measure(0,0); | 95 | layout_control.measure(0,0); |
| 96 | - mPresenter.getTools(layout_control,""); | 96 | + mPresenter.getTools(layout_control,AppContext.getInstance().district); |
| 97 | 97 | ||
| 98 | } | 98 | } |
| 99 | 99 | ||
| @@ -140,7 +140,7 @@ public class CePingFragment extends BaseMVPCompatFragment<CepingContract.CePingP | @@ -140,7 +140,7 @@ public class CePingFragment extends BaseMVPCompatFragment<CepingContract.CePingP | ||
| 140 | ToastUtils.showToast("remen3"); | 140 | ToastUtils.showToast("remen3"); |
| 141 | break; | 141 | break; |
| 142 | case R.id.tvLocalAddress: | 142 | case R.id.tvLocalAddress: |
| 143 | - AppContext.getInstance().startLocation(); | 143 | +// AppContext.getInstance().startLocation(); |
| 144 | if (null==cityPicker)cityPicker=new CityPicker(getActivity(),this); | 144 | if (null==cityPicker)cityPicker=new CityPicker(getActivity(),this); |
| 145 | if (cityPicker.isShow())cityPicker.close(); | 145 | if (cityPicker.isShow())cityPicker.close(); |
| 146 | else cityPicker.show(); | 146 | else cityPicker.show(); |
| @@ -169,6 +169,13 @@ public class CePingFragment extends BaseMVPCompatFragment<CepingContract.CePingP | @@ -169,6 +169,13 @@ public class CePingFragment extends BaseMVPCompatFragment<CepingContract.CePingP | ||
| 169 | 169 | ||
| 170 | @Override | 170 | @Override |
| 171 | public void getCity(String name) { | 171 | public void getCity(String name) { |
| 172 | - ToastUtils.showToast(name); | 172 | + tvLocalAddress.setText(name.split(" ")[1]); |
| 173 | + mPresenter.getTools(layout_control,name.split(" ")[2]); | ||
| 174 | + ToastUtils.showToast(name.split(" ")[2]); | ||
| 175 | + } | ||
| 176 | + | ||
| 177 | + @Override | ||
| 178 | + public void showTools() { | ||
| 179 | + | ||
| 173 | } | 180 | } |
| 174 | } | 181 | } |
app/src/main/java/com/shunzhi/parent/ui/fragment/ConsultFragment.java
| @@ -84,15 +84,6 @@ public class ConsultFragment extends BaseMVPCompatFragment<ConsultContract.Consu | @@ -84,15 +84,6 @@ public class ConsultFragment extends BaseMVPCompatFragment<ConsultContract.Consu | ||
| 84 | } | 84 | } |
| 85 | 85 | ||
| 86 | private void initBanners() { | 86 | private void initBanners() { |
| 87 | -// InputStream inputStream = getClass().getResourceAsStream("/assets/banners.png"); | ||
| 88 | -// try { | ||
| 89 | -// imgesUrl.add(new String(InputStreamToByte(inputStream))); | ||
| 90 | -// imgesUrl.add(new String(InputStreamToByte(inputStream))); | ||
| 91 | -// imgesUrl.add(new String(InputStreamToByte(inputStream))); | ||
| 92 | -// imgesUrl.add(new String(InputStreamToByte(inputStream))); | ||
| 93 | -// } catch (IOException e) { | ||
| 94 | -// e.printStackTrace(); | ||
| 95 | -// } | ||
| 96 | xBanner.setData(imgesUrl, describeList); | 87 | xBanner.setData(imgesUrl, describeList); |
| 97 | xBanner.setmAdapter(new XBanner.XBannerAdapter() { | 88 | xBanner.setmAdapter(new XBanner.XBannerAdapter() { |
| 98 | @Override | 89 | @Override |
| @@ -110,18 +101,6 @@ public class ConsultFragment extends BaseMVPCompatFragment<ConsultContract.Consu | @@ -110,18 +101,6 @@ public class ConsultFragment extends BaseMVPCompatFragment<ConsultContract.Consu | ||
| 110 | return new ConsultPresenter(); | 101 | return new ConsultPresenter(); |
| 111 | } | 102 | } |
| 112 | 103 | ||
| 113 | - private byte[] InputStreamToByte(InputStream is) throws IOException { | ||
| 114 | - ByteArrayOutputStream bytestream = new ByteArrayOutputStream(); | ||
| 115 | - int ch; | ||
| 116 | - while ((ch = is.read()) != -1) { | ||
| 117 | - bytestream.write(ch); | ||
| 118 | - } | ||
| 119 | - byte imgdata[] = bytestream.toByteArray(); | ||
| 120 | - bytestream.close(); | ||
| 121 | - return imgdata; | ||
| 122 | - | ||
| 123 | - } | ||
| 124 | - | ||
| 125 | @Override | 104 | @Override |
| 126 | public void onResume() { | 105 | public void onResume() { |
| 127 | super.onResume(); | 106 | super.onResume(); |
| @@ -138,7 +117,7 @@ public class ConsultFragment extends BaseMVPCompatFragment<ConsultContract.Consu | @@ -138,7 +117,7 @@ public class ConsultFragment extends BaseMVPCompatFragment<ConsultContract.Consu | ||
| 138 | public void onClick(View view) { | 117 | public void onClick(View view) { |
| 139 | switch (view.getId()) { | 118 | switch (view.getId()) { |
| 140 | case R.id.tvLocalAddress: | 119 | case R.id.tvLocalAddress: |
| 141 | - AppContext.getInstance().startLocation(); | 120 | +// AppContext.getInstance().startLocation(); |
| 142 | if (null==cityPicker)cityPicker=new CityPicker(getActivity(),this); | 121 | if (null==cityPicker)cityPicker=new CityPicker(getActivity(),this); |
| 143 | if (cityPicker.isShow())cityPicker.close(); | 122 | if (cityPicker.isShow())cityPicker.close(); |
| 144 | else cityPicker.show(); | 123 | else cityPicker.show(); |
| @@ -190,6 +169,6 @@ public class ConsultFragment extends BaseMVPCompatFragment<ConsultContract.Consu | @@ -190,6 +169,6 @@ public class ConsultFragment extends BaseMVPCompatFragment<ConsultContract.Consu | ||
| 190 | 169 | ||
| 191 | @Override | 170 | @Override |
| 192 | public void getCity(String name) { | 171 | public void getCity(String name) { |
| 193 | - | 172 | + tvLocalAddress.setText(name.split(" ")[1]); |
| 194 | } | 173 | } |
| 195 | } | 174 | } |
app/src/main/java/com/shunzhi/parent/ui/fragment/StartFragment.java
0 → 100644
| @@ -0,0 +1,99 @@ | @@ -0,0 +1,99 @@ | ||
| 1 | +package com.shunzhi.parent.ui.fragment; | ||
| 2 | + | ||
| 3 | +import android.os.Bundle; | ||
| 4 | +import android.support.annotation.NonNull; | ||
| 5 | +import android.support.annotation.Nullable; | ||
| 6 | +import android.support.v4.view.ViewPager; | ||
| 7 | +import android.text.TextUtils; | ||
| 8 | +import android.view.View; | ||
| 9 | +import android.widget.ImageView; | ||
| 10 | + | ||
| 11 | +import com.bumptech.glide.Glide; | ||
| 12 | +import com.share.mvpsdk.base.BasePresenter; | ||
| 13 | +import com.share.mvpsdk.base.fragment.BaseMVPCompatFragment; | ||
| 14 | +import com.shunzhi.parent.AppConfig; | ||
| 15 | +import com.shunzhi.parent.R; | ||
| 16 | +import com.shunzhi.parent.bean.GuangGaoBean; | ||
| 17 | +import com.shunzhi.parent.contract.consult.ConsultContract; | ||
| 18 | +import com.shunzhi.parent.presenter.consult.ConsultPresenter; | ||
| 19 | +import com.shunzhi.parent.ui.MainActivity; | ||
| 20 | +import com.stx.xhb.xbanner.XBanner; | ||
| 21 | + | ||
| 22 | +import java.util.ArrayList; | ||
| 23 | +import java.util.List; | ||
| 24 | + | ||
| 25 | +public class StartFragment extends BaseMVPCompatFragment<ConsultContract.ConsultPresenter, ConsultContract.IConsultModel> | ||
| 26 | + implements ConsultContract.IConsultView { | ||
| 27 | + | ||
| 28 | + XBanner xBanner; | ||
| 29 | + | ||
| 30 | + @Override | ||
| 31 | + public int getLayoutId() { | ||
| 32 | + return R.layout.fragment_start; | ||
| 33 | + } | ||
| 34 | + | ||
| 35 | + @Override | ||
| 36 | + public void initUI(View view, @Nullable Bundle savedInstanceState) { | ||
| 37 | + xBanner = view.findViewById(R.id.xBanner); | ||
| 38 | + if (!TextUtils.isEmpty(AppConfig.getAppConfig(getContext()).get(AppConfig.APP_IS_START))) { | ||
| 39 | + mPresenter.getBanners("0"); | ||
| 40 | + AppConfig.getAppConfig(getContext()).set(AppConfig.APP_IS_START, "1"); | ||
| 41 | + } else mPresenter.getBanners("1"); | ||
| 42 | + } | ||
| 43 | + | ||
| 44 | + @NonNull | ||
| 45 | + @Override | ||
| 46 | + public BasePresenter initPresenter() { | ||
| 47 | + return new ConsultPresenter(); | ||
| 48 | + } | ||
| 49 | + | ||
| 50 | + @Override | ||
| 51 | + public void showTools() { | ||
| 52 | + | ||
| 53 | + } | ||
| 54 | + | ||
| 55 | + @Override | ||
| 56 | + public void showBanners(List<GuangGaoBean> guangGaoBeanList) { | ||
| 57 | + initBannes(guangGaoBeanList); | ||
| 58 | + } | ||
| 59 | + | ||
| 60 | + private void initBannes(List<GuangGaoBean> guangGaoBeanList) { | ||
| 61 | + final List<String> imgUrl = new ArrayList<>(); | ||
| 62 | + List<String> describeList = new ArrayList<>(); | ||
| 63 | + for (int i = 0; i < guangGaoBeanList.size(); i++) { | ||
| 64 | + imgUrl.add(guangGaoBeanList.get(i).fileSrc); | ||
| 65 | + describeList.add(guangGaoBeanList.get(i).describe); | ||
| 66 | + } | ||
| 67 | + xBanner.setData(imgUrl, describeList); | ||
| 68 | + xBanner.setmAutoPlayAble(false); | ||
| 69 | + xBanner.setSlideScrollMode(View.OVER_SCROLL_NEVER); | ||
| 70 | + | ||
| 71 | + xBanner.setmAdapter(new XBanner.XBannerAdapter() { | ||
| 72 | + @Override | ||
| 73 | + public void loadBanner(XBanner banner, Object model, View view, int position) { | ||
| 74 | + Glide.with(getActivity()).load(imgUrl.get(position)).placeholder(R.drawable.ic_launcher_background) | ||
| 75 | + .into((ImageView) view); | ||
| 76 | + } | ||
| 77 | + }); | ||
| 78 | + | ||
| 79 | + xBanner.setOnPageChangeListener(new ViewPager.OnPageChangeListener() { | ||
| 80 | + @Override | ||
| 81 | + public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { | ||
| 82 | + if (position == imgUrl.size() - 1) { | ||
| 83 | + startNewActivity(MainActivity.class); | ||
| 84 | + } | ||
| 85 | + } | ||
| 86 | + | ||
| 87 | + @Override | ||
| 88 | + public void onPageSelected(int position) { | ||
| 89 | + | ||
| 90 | + } | ||
| 91 | + | ||
| 92 | + @Override | ||
| 93 | + public void onPageScrollStateChanged(int state) { | ||
| 94 | + | ||
| 95 | + } | ||
| 96 | + }); | ||
| 97 | + | ||
| 98 | + } | ||
| 99 | +} |
app/src/main/java/com/shunzhi/parent/views/TextAndImgShowView.java
| @@ -13,6 +13,7 @@ import android.widget.ImageView; | @@ -13,6 +13,7 @@ import android.widget.ImageView; | ||
| 13 | import android.widget.LinearLayout; | 13 | import android.widget.LinearLayout; |
| 14 | import android.widget.TextView; | 14 | import android.widget.TextView; |
| 15 | 15 | ||
| 16 | +import com.bumptech.glide.Glide; | ||
| 16 | import com.share.mvpsdk.utils.DisplayUtils; | 17 | import com.share.mvpsdk.utils.DisplayUtils; |
| 17 | import com.shunzhi.parent.R; | 18 | import com.shunzhi.parent.R; |
| 18 | 19 | ||
| @@ -54,6 +55,10 @@ public class TextAndImgShowView extends LinearLayout { | @@ -54,6 +55,10 @@ public class TextAndImgShowView extends LinearLayout { | ||
| 54 | imgs = new int[]{normalDrawable, selectDrawable}; | 55 | imgs = new int[]{normalDrawable, selectDrawable}; |
| 55 | } | 56 | } |
| 56 | 57 | ||
| 58 | + public void addImgs(String imgUrl){ | ||
| 59 | + Glide.with(getContext()).load(imgUrl).error(R.drawable.gxzt).into(image); | ||
| 60 | + } | ||
| 61 | + | ||
| 57 | public void setSelect(boolean isSelect) { | 62 | public void setSelect(boolean isSelect) { |
| 58 | if (isSelect) { | 63 | if (isSelect) { |
| 59 | if (imgs != null && imgs.length > 1) | 64 | if (imgs != null && imgs.length > 1) |
13 KB
| @@ -0,0 +1,9 @@ | @@ -0,0 +1,9 @@ | ||
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<shape xmlns:android="http://schemas.android.com/apk/res/android"> | ||
| 3 | + <solid android:color="@color/white" /> | ||
| 4 | + <corners android:topLeftRadius="3dp" | ||
| 5 | + android:topRightRadius="3dp" | ||
| 6 | + android:bottomRightRadius="3dp" | ||
| 7 | + android:bottomLeftRadius="3dp"/> | ||
| 8 | + <stroke android:width="1dp" android:color="@color/bg_gray" /> | ||
| 9 | +</shape> | ||
| 0 | \ No newline at end of file | 10 | \ No newline at end of file |
| @@ -0,0 +1,24 @@ | @@ -0,0 +1,24 @@ | ||
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<layer-list xmlns:android="http://schemas.android.com/apk/res/android" > | ||
| 3 | + <item android:id="@android:id/background"> | ||
| 4 | + <shape> | ||
| 5 | + <corners android:radius="2dp" /> | ||
| 6 | + <gradient | ||
| 7 | + android:angle="270" | ||
| 8 | + android:centerColor="#E3E3E3" | ||
| 9 | + android:endColor="#E6E6E6" | ||
| 10 | + android:startColor="#C8C8C8" /> | ||
| 11 | + </shape> | ||
| 12 | + </item> | ||
| 13 | + <item android:id="@android:id/progress"> | ||
| 14 | + <clip> | ||
| 15 | + <shape> | ||
| 16 | + <corners android:radius="2dp" /> | ||
| 17 | + <gradient | ||
| 18 | + android:centerColor="#03a9f4" | ||
| 19 | + android:endColor="#0288d1" | ||
| 20 | + android:startColor="#03a9f4" /> | ||
| 21 | + </shape> | ||
| 22 | + </clip> | ||
| 23 | + </item> | ||
| 24 | +</layer-list> | ||
| 0 | \ No newline at end of file | 25 | \ No newline at end of file |
app/src/main/res/layout/activity_start.xml
| @@ -4,12 +4,8 @@ | @@ -4,12 +4,8 @@ | ||
| 4 | xmlns:tools="http://schemas.android.com/tools" | 4 | xmlns:tools="http://schemas.android.com/tools" |
| 5 | android:layout_width="match_parent" | 5 | android:layout_width="match_parent" |
| 6 | android:layout_height="match_parent" | 6 | android:layout_height="match_parent" |
| 7 | + android:id="@+id/frame_start" | ||
| 7 | tools:context="com.shunzhi.parent.ui.activity.StartActivity"> | 8 | tools:context="com.shunzhi.parent.ui.activity.StartActivity"> |
| 8 | 9 | ||
| 9 | - <com.stx.xhb.xbanner.XBanner | ||
| 10 | - android:layout_width="match_parent" | ||
| 11 | - android:layout_height="match_parent" | ||
| 12 | - android:id="@+id/xBanner" | ||
| 13 | - ></com.stx.xhb.xbanner.XBanner> | ||
| 14 | 10 | ||
| 15 | </FrameLayout> | 11 | </FrameLayout> |
| @@ -0,0 +1,23 @@ | @@ -0,0 +1,23 @@ | ||
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 3 | + xmlns:app="http://schemas.android.com/apk/res-auto" | ||
| 4 | + xmlns:tools="http://schemas.android.com/tools" | ||
| 5 | + android:layout_width="match_parent" | ||
| 6 | + android:layout_height="match_parent" | ||
| 7 | + android:orientation="vertical" | ||
| 8 | + android:background="@color/bgColor" | ||
| 9 | + tools:context="com.shunzhi.parent.ui.activity.WebViewActivity"> | ||
| 10 | + <ProgressBar | ||
| 11 | + android:id="@+id/pb_web" | ||
| 12 | + style="?android:attr/progressBarStyleHorizontal" | ||
| 13 | + android:layout_width="match_parent" | ||
| 14 | + android:layout_height="3dp" | ||
| 15 | + android:progressDrawable="@drawable/web_progress_bar_bg" | ||
| 16 | + android:visibility="gone"/> | ||
| 17 | + <com.share.mvpsdk.widgets.NestedScrollWebView | ||
| 18 | + android:layout_width="match_parent" | ||
| 19 | + android:layout_height="match_parent" | ||
| 20 | + android:id="@+id/nesteScrollWebView" | ||
| 21 | + ></com.share.mvpsdk.widgets.NestedScrollWebView> | ||
| 22 | + | ||
| 23 | +</LinearLayout> |
| @@ -0,0 +1,12 @@ | @@ -0,0 +1,12 @@ | ||
| 1 | +<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 2 | + xmlns:tools="http://schemas.android.com/tools" | ||
| 3 | + android:layout_width="match_parent" | ||
| 4 | + android:layout_height="match_parent" | ||
| 5 | + tools:context="com.shunzhi.parent.ui.fragment.StartFragment"> | ||
| 6 | + | ||
| 7 | + <com.stx.xhb.xbanner.XBanner | ||
| 8 | + android:layout_width="match_parent" | ||
| 9 | + android:layout_height="match_parent" | ||
| 10 | + android:id="@+id/xBanner" | ||
| 11 | + ></com.stx.xhb.xbanner.XBanner> | ||
| 12 | +</FrameLayout> |
| @@ -0,0 +1,35 @@ | @@ -0,0 +1,35 @@ | ||
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 3 | + android:id="@+id/ll_popup_root" | ||
| 4 | + android:layout_width="match_parent" | ||
| 5 | + android:layout_height="wrap_content" | ||
| 6 | + android:background="@drawable/shape_corner_bg" | ||
| 7 | + android:layout_margin="10dp" | ||
| 8 | + android:orientation="vertical"> | ||
| 9 | + | ||
| 10 | + <TextView | ||
| 11 | + android:id="@+id/item_go_image_browse" | ||
| 12 | + android:layout_width="match_parent" | ||
| 13 | + android:layout_height="40dp" | ||
| 14 | + android:gravity="center" | ||
| 15 | + android:text="查看图片" | ||
| 16 | + android:textColor="@color/md_grey_700" | ||
| 17 | + android:textSize="16sp"/> | ||
| 18 | + | ||
| 19 | + <View | ||
| 20 | + android:layout_width="match_parent" | ||
| 21 | + android:layout_height="1dp" | ||
| 22 | + android:layout_marginRight="@dimen/size_dp_5" | ||
| 23 | + android:layout_marginLeft="@dimen/size_dp_5" | ||
| 24 | + android:background="@color/md_grey_500"/> | ||
| 25 | + | ||
| 26 | + <TextView | ||
| 27 | + android:id="@+id/item_save_image" | ||
| 28 | + android:layout_width="match_parent" | ||
| 29 | + android:layout_height="40dp" | ||
| 30 | + android:gravity="center" | ||
| 31 | + android:text="保存图片" | ||
| 32 | + android:textColor="@color/md_grey_700" | ||
| 33 | + android:textSize="16sp"/> | ||
| 34 | + | ||
| 35 | +</LinearLayout> | ||
| 0 | \ No newline at end of file | 36 | \ No newline at end of file |
| @@ -0,0 +1,26 @@ | @@ -0,0 +1,26 @@ | ||
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 2 | +<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||
| 3 | + android:layout_width="match_parent" | ||
| 4 | + android:layout_height="match_parent"> | ||
| 5 | + | ||
| 6 | + <include | ||
| 7 | + android:id="@+id/v_empty" | ||
| 8 | + layout="@layout/view_empty" | ||
| 9 | + android:layout_width="match_parent" | ||
| 10 | + android:layout_height="match_parent" | ||
| 11 | + android:visibility="gone"/> | ||
| 12 | + | ||
| 13 | + <include | ||
| 14 | + android:id="@+id/v_network_error" | ||
| 15 | + layout="@layout/view_network_error" | ||
| 16 | + android:layout_width="match_parent" | ||
| 17 | + android:layout_height="match_parent" | ||
| 18 | + android:visibility="gone"/> | ||
| 19 | + | ||
| 20 | + <include | ||
| 21 | + android:id="@+id/v_loading" | ||
| 22 | + layout="@layout/view_loading" | ||
| 23 | + android:layout_width="match_parent" | ||
| 24 | + android:layout_height="match_parent" | ||
| 25 | + android:visibility="gone"/> | ||
| 26 | +</FrameLayout> | ||
| 0 | \ No newline at end of file | 27 | \ No newline at end of file |
app/src/main/res/values/dimens.xml
| @@ -11,6 +11,7 @@ | @@ -11,6 +11,7 @@ | ||
| 11 | <dimen name="margin_large">32dp</dimen> | 11 | <dimen name="margin_large">32dp</dimen> |
| 12 | <dimen name="margin_huge">64dp</dimen> | 12 | <dimen name="margin_huge">64dp</dimen> |
| 13 | <dimen name="margin_only_txt">48dp</dimen> | 13 | <dimen name="margin_only_txt">48dp</dimen> |
| 14 | + <dimen name="detail_image_height">260dp</dimen> | ||
| 14 | 15 | ||
| 15 | <!-- txtsize --> | 16 | <!-- txtsize --> |
| 16 | <dimen name="txtsize_display1">34dp</dimen> | 17 | <dimen name="txtsize_display1">34dp</dimen> |
app/src/main/res/values/styles.xml
| @@ -41,4 +41,18 @@ | @@ -41,4 +41,18 @@ | ||
| 41 | <item name="android:backgroundDimEnabled">true</item> | 41 | <item name="android:backgroundDimEnabled">true</item> |
| 42 | </style> | 42 | </style> |
| 43 | 43 | ||
| 44 | + <style name="AppTheme.ToolbarPopupOverlay" parent="ThemeOverlay.AppCompat.Light"> | ||
| 45 | + <item name="overlapAnchor">false</item> | ||
| 46 | + </style> | ||
| 47 | + | ||
| 48 | + <style name="TextAppearance.ExpandedTitle" parent="TextAppearance.AppCompat.Widget.ActionBar.Title"> | ||
| 49 | + <item name="android:textSize">26sp</item> | ||
| 50 | + </style> | ||
| 51 | + | ||
| 52 | + <style name="AppTheme.AppBarOverlay" parent="ThemeOverlay.AppCompat.Dark.ActionBar"> | ||
| 53 | + <!--<item name="colorPrimary">@color/colorPrimary</item>--> | ||
| 54 | + <!--<item name="colorPrimaryDark">@color/colorPrimaryDark</item>--> | ||
| 55 | + <!--<item name="colorAccent">@color/colorAccent</item>--> | ||
| 56 | + </style> | ||
| 57 | + | ||
| 44 | </resources> | 58 | </resources> |
mvpsdk/build.gradle
| @@ -39,6 +39,7 @@ dependencies { | @@ -39,6 +39,7 @@ dependencies { | ||
| 39 | implementation fileTree(dir: 'libs', include: ['*.jar']) | 39 | implementation fileTree(dir: 'libs', include: ['*.jar']) |
| 40 | 40 | ||
| 41 | implementation 'com.android.support:appcompat-v7:26.1.0' | 41 | implementation 'com.android.support:appcompat-v7:26.1.0' |
| 42 | + implementation 'com.android.support.constraint:constraint-layout:1.0.2' | ||
| 42 | testImplementation 'junit:junit:4.12' | 43 | testImplementation 'junit:junit:4.12' |
| 43 | androidTestImplementation 'com.android.support.test:runner:1.0.1' | 44 | androidTestImplementation 'com.android.support.test:runner:1.0.1' |
| 44 | androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1' | 45 | androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.1' |
| @@ -103,7 +104,6 @@ dependencies { | @@ -103,7 +104,6 @@ dependencies { | ||
| 103 | compile 'cn.jzvd:jiaozivideoplayer:6.2.7' | 104 | compile 'cn.jzvd:jiaozivideoplayer:6.2.7' |
| 104 | // compile(name: 'jiaozivideoplayer-6.2.3', ext: 'aar') | 105 | // compile(name: 'jiaozivideoplayer-6.2.3', ext: 'aar') |
| 105 | 106 | ||
| 106 | - | ||
| 107 | //轮播图XBanner | 107 | //轮播图XBanner |
| 108 | compile 'com.xhb:xbanner:1.3.1' | 108 | compile 'com.xhb:xbanner:1.3.1' |
| 109 | 109 |
mvpsdk/src/main/AndroidManifest.xml
| 1 | +<?xml version="1.0" encoding="utf-8"?> | ||
| 1 | <manifest xmlns:android="http://schemas.android.com/apk/res/android" | 2 | <manifest xmlns:android="http://schemas.android.com/apk/res/android" |
| 2 | - package="com.share.mvpsdk" /> | 3 | + package="com.share.mvpsdk"> |
| 4 | + | ||
| 5 | + <application></application> | ||
| 6 | + | ||
| 7 | +</manifest> | ||
| 3 | \ No newline at end of file | 8 | \ No newline at end of file |
mvpsdk/src/main/res/values/strings.xml
| @@ -4,7 +4,7 @@ | @@ -4,7 +4,7 @@ | ||
| 4 | <string name="loading">Loading……</string> | 4 | <string name="loading">Loading……</string> |
| 5 | <string name="load_failed">Load failed. Please click me again</string> | 5 | <string name="load_failed">Load failed. Please click me again</string> |
| 6 | <string name="press_again">Press again to exit</string> | 6 | <string name="press_again">Press again to exit</string> |
| 7 | -<string name="report">报告</string> | 7 | + <string name="report">报告</string> |
| 8 | <!--历史数据界面--> | 8 | <!--历史数据界面--> |
| 9 | <string name="history_day">Day</string> | 9 | <string name="history_day">Day</string> |
| 10 | <string name="history_week">Week</string> | 10 | <string name="history_week">Week</string> |