Просмотр исходного кода

FX入库PDA优化【taskID=12144】

guilin месяцев назад: 3
Родитель
Сommit
10541531ab

+ 7 - 0
app/src/main/AndroidManifest.xml

@@ -140,6 +140,13 @@
             android:windowSoftInputMode="stateHidden|adjustPan"
             android:screenOrientation="portrait"
             tools:ignore="DuplicateActivity,LockedOrientationActivity"/>
+        <activity
+            android:name=".putIn.TallyPutInMainActivity"
+            android:windowSoftInputMode="stateHidden|adjustPan"
+            android:screenOrientation="portrait"
+            tools:ignore="DuplicateActivity,LockedOrientationActivity"/>
+
+
 
         <activity
             android:name=".tool.OrderToolMainActivity"

+ 5 - 1
app/src/main/java/com/fxy/common/AsyncPictureUpload.java

@@ -405,8 +405,10 @@ public class AsyncPictureUpload {
     }
 
     public void setStartUpload(){
+        if (awaitUploadList==null ||awaitUploadList.size()==0){
+            asyncUpload();
+        }
         allowUpload = true;
-        asyncUpload();
     }
     public void setIsAllRe(){
         isAllRe = true;
@@ -525,6 +527,8 @@ public class AsyncPictureUpload {
         if (allowUpload){
             //上传完,继续执行
             asyncUpload();
+        }else{
+            awaitUploadList.clear();
         }
 
     }

+ 8 - 6
app/src/main/java/com/fxy/main/fragment/HomePagerFragment.java

@@ -35,6 +35,7 @@ import com.fxy.putIn.PutinPalletMainActivity;
 import com.fxy.putIn.PutinPhotosMainActivity;
 import com.fxy.detection.ScanPhotosMainActivity;
 import com.fxy.putIn.TallyMainActivity;
+import com.fxy.putIn.TallyPutInMainActivity;
 import com.fxy.putOut.DeliveryGoodsMainActivity;
 import com.fxy.tool.OrderToolMainActivity;
 import com.fxy.utils.JobUtils;
@@ -176,7 +177,7 @@ public class HomePagerFragment extends BaseFragment implements View.OnClickListe
      * 绑定事件
      * @param v
      */
-    @OnClick({R.id.search_view, R.id.ivt_tally,R.id.ivt_cargo_storage,R.id.ivt_putin_photos,
+    @OnClick({R.id.search_view, R.id.ivt_tally,R.id.ivt_cargo_storage,
             R.id.ivt_order_tool,R.id.ivt_check,R.id.ivt_putin_pallet,R.id.ivt_hk_putin,
             R.id.ivt_handle_work_order,R.id.ivt_add_work_order,R.id.ivt_hk_tally,R.id.ivt_hk_outbound,
             R.id.ivt_hk_pallet_location,R.id.ivt_hk_pickup,
@@ -187,8 +188,9 @@ public class HomePagerFragment extends BaseFragment implements View.OnClickListe
         Bundle bundle = new Bundle();
         switch (v.getId()) {
             case R.id.ivt_tally:
-                bundle.putString("action","receive");
-                intent2Page(getActivity(), TallyMainActivity.class, false,bundle);;
+//                bundle.putString("action","receive");
+//                intent2Page(getActivity(), TallyMainActivity.class, false,bundle);;
+                intent2Page(getActivity(), TallyPutInMainActivity.class, false,bundle);;
                 break;
             case R.id.ivt_cargo_storage:
                 bundle.putString("action","storage");
@@ -208,9 +210,9 @@ public class HomePagerFragment extends BaseFragment implements View.OnClickListe
                 bundle.putString("action","add");
                 intent2Page(getActivity(), WorkOrderOptMainActivity.class, false,bundle);
                 break;
-            case R.id.ivt_putin_photos:
-                intent2Page(getActivity(), PutinPhotosMainActivity.class, false,bundle);
-                break;
+//            case R.id.ivt_putin_photos:
+//                intent2Page(getActivity(), PutinPhotosMainActivity.class, false,bundle);
+//                break;
             case R.id.ivt_putin_pallet:
                 intent2Page(getActivity(), PutinPalletMainActivity.class, false,bundle);
                 break;

+ 2 - 1
app/src/main/java/com/fxy/net/Urls.java

@@ -136,7 +136,8 @@ public class Urls {
     //托盘入库
     public static final String FXY_BATCH_PICTURE_INBOUND = "/pda/inbound/batchPictureInbound";
 
-
+    //快递入库
+    public static final String FXY_PALLET_INBOUND = "/pda/inbound/palletInbound";
 
     //获取批次列表
     public static final String FXY_GET_BATCH_LIST = "/pda/tool/getBatchData";

+ 0 - 546
app/src/main/java/com/fxy/putIn/PutinPalletMainActivity.java

@@ -1,546 +0,0 @@
-package com.fxy.putIn;
-
-import android.annotation.SuppressLint;
-import android.content.BroadcastReceiver;
-import android.content.Context;
-import android.content.Intent;
-import android.content.IntentFilter;
-import android.os.Bundle;
-import android.os.Handler;
-import android.os.Message;
-import android.support.v7.widget.RecyclerView;
-import android.text.Editable;
-import android.text.TextWatcher;
-import android.view.KeyEvent;
-import android.view.View;
-import android.view.inputmethod.EditorInfo;
-import android.widget.EditText;
-import android.widget.ImageButton;
-import android.widget.LinearLayout;
-import android.widget.TextView;
-import android.widget.Toast;
-
-import com.elvishew.xlog.XLog;
-import com.fxy.R;
-import com.fxy.baselibrary.base.BaseActivity;
-import com.fxy.baselibrary.bean.BaseEventBusBean;
-import com.fxy.baselibrary.interfaces.OnRxScanerListener;
-import com.fxy.baselibrary.qrcode.ActivityScanerCode;
-import com.fxy.baselibrary.util.JsonUtil;
-import com.fxy.baselibrary.util.StringUtils;
-import com.fxy.bean.ActionBean;
-import com.fxy.bean.ScanBean;
-import com.fxy.common.PictureSelectorUpload;
-import com.fxy.constant.BaseConfig;
-import com.fxy.constant.EventCode;
-import com.fxy.net.MyDialogCallback;
-import com.fxy.net.Urls;
-import com.fxy.view.FloatingImageView;
-import com.google.gson.Gson;
-import com.google.zxing.Result;
-import com.luck.picture.lib.config.PictureConfig;
-import com.lzy.okgo.OkGo;
-import com.lzy.okgo.model.Response;
-
-import org.json.JSONException;
-import org.json.JSONObject;
-
-import java.util.ArrayList;
-
-import butterknife.BindView;
-import butterknife.ButterKnife;
-import butterknife.OnClick;
-import butterknife.Unbinder;
-import sto.android.app.StoJNI;
-import sto.android.app.StoPdaKeyEvent;
-import sto.android.app.StoTongJNI;
-
-public class PutinPalletMainActivity extends  BaseActivity implements StoJNI.ScanCallBack{
-
-    /**
-     * 列表适配器
-     */
-    Context mContext = this;
-
-    //单号清除
-    @BindView(R.id.ib_order_no_clear)
-    ImageButton ibOrderNoClear;
-
-    //单号
-    @BindView(R.id.et_order_no)
-    EditText etOrderNo;
-
-
-    @BindView(R.id.ll_take_picture)
-    LinearLayout llTakePicture;
-
-
-    private ArrayList photoList =new ArrayList<>();
-
-    private PictureSelectorUpload pictureSelectorUpload;
-    //
-    //扫码扫码动作
-    private ScanBean scanBean;
-
-
-    //浮动按钮
-    @BindView(R.id.iv_drag)
-    FloatingImageView iv_drag;
-
-
-
-    protected String action;
-
-
-    private Unbinder unbinder;
-
-    private JSONObject postParam = new JSONObject();
-
-
-    @Override
-    public int getContentViewResId() {
-        return R.layout.activity_fxy_putin_pallet;
-    }
-
-    @Override
-    public boolean showToolBar() {
-        return true;
-    }
-
-    @Override
-    public boolean openEventBus() {
-        return true;
-    }
-
-    @Override
-    protected void getBundleExtras(Bundle bundle) {
-        //XLog.e("接收数据解析:",bundle);
-        action = bundle.getString("action","add");
-    }
-
-
-
-    //finish的返回监听
-    //这里的requestCode参数,就是上面设置的 1 ,当跳转的页面返回的时候,通过这个加以判断
-    //resultCode ,这个参数是在跳转的页面里面规定的,它也是一个int类型的标志
-    //第三个参数包含了返回的值
-    //如果不需要所跳转的页面返回值,也就不需要这个方法了
-    @Override
-    public void onActivityResult(int requestCode, int resultCode, Intent data) {
-        super.onActivityResult(requestCode, resultCode, data);
-
-        if (resultCode == RESULT_OK) {
-            if (requestCode == PictureConfig.CHOOSE_REQUEST) {// 图片选择结果回调
-                pictureSelectorUpload.getSelectImg(data);
-            }
-        }
-    }
-
-    /**
-     * EventBus接收信息的方法,开启后才会调用(非粘性事件)
-     *
-     * @param event
-     */
-    @Override
-    protected void EventBean(BaseEventBusBean event) {
-//        XLog.e("----------接收返回--------------");
-//        XLog.e("接收返回:"+event.getEventCode());
-        if (event != null && event.getEventCode() == EventCode.displacement_refresh){
-
-        }
-    }
-
-    @Override
-    public boolean isPlayMusic() {
-        return true;
-    }
-
-
-    @Override
-    protected void initView() {
-        unbinder = ButterKnife.bind(this);
-        setTitleName("托盘入库");
-
-        initEdit();
-        iniData();
-
-        RecyclerView rvShowImg = (RecyclerView)llTakePicture.findViewById(R.id.rv_show_img);
-        pictureSelectorUpload  = setItemPicture("photo",rvShowImg,9,PictureConfig.TYPE_IMAGE);
-
-
-        //监听浮动按钮
-        iv_drag.setOnClickListener(new View.OnClickListener() {
-            @Override
-            public void onClick(View v) {
-                if(!iv_drag.isDrag()){
-                    ActivityScanerCode.setScanerListener(mScanerListener);
-                    ActivityScanerCode.intent2Activity(mContext, BaseConfig.COMMON_SCANNER_ONLY);
-                }
-            }
-        });
-    }
-
-
-
-    /**
-     * 设置多个上传文件
-     * @param actionType String
-     * @param showImg RecyclerView
-     */
-    private PictureSelectorUpload setItemPicture(String actionType,RecyclerView showImg,int maxNum,int pictureType){
-        PictureSelectorUpload pictureUpload = new PictureSelectorUpload(PutinPalletMainActivity.this,showImg,"work",maxNum,pictureType);
-        pictureUpload.setActionType(actionType);
-        pictureUpload.setCompress(true,100,500);
-        pictureUpload.setOnlyCamera(true);
-        //showImg.onTouchEvent()
-
-        pictureUpload.setOnChangeListener(new PictureSelectorUpload.UploadChangeListener() {
-            @Override
-            public void uploadResult(boolean State,String actionType) {
-                if (State) {
-
-                }
-            }
-
-            @Override
-            public void uploadActionType(String actionType) {
-
-                System.out.println("actionType:"+actionType);
-
-            }
-        });
-        return  pictureUpload;
-    }
-
-
-    @Override
-    public boolean dispatchKeyEvent(KeyEvent event) {
-        //XLog.e("event:"+event.getKeyCode());
-        if ((event.getKeyCode()==KeyEvent.KEYCODE_DPAD_CENTER || event.getKeyCode()==KeyEvent.KEYCODE_ENTER )  && event.getAction() == KeyEvent.ACTION_DOWN){
-            //按确定键
-            if(this.validate()){
-               pictureSelectorUpload.authCamera();
-            }
-        }
-        return super.dispatchKeyEvent(event);
-    }
-
-    //监听按键
-    public boolean onKeyDown(int keyCode, KeyEvent event) {
-        XLog.e("监听按键:"+keyCode);XLog.e(event);
-        if (scanBean.getIsBroadcast()==0 && StoTongJNI.getIns(mContext).getEventFuction(keyCode)  == StoPdaKeyEvent.KEYCODE_SCAN
-                && event.getRepeatCount() == 0) {
-
-            if (StoTongJNI.getIns(mContext).GetScannerIsScanning()) {
-//
-            } else {
-                StoTongJNI.getIns(mContext).SetScannerStart();
-            }
-        }
-        return super.onKeyDown(keyCode, event);
-    }
-
-    @SuppressLint("HandlerLeak")
-    Handler scanHandler = new Handler() {
-
-        @Override
-        public void handleMessage(Message msg) {
-            // TODO Auto-generated method stub
-            if (msg.obj != null) {
-
-                String scanResult = msg.obj.toString().trim();
-                if (!scanResult.isEmpty()){
-                    setScanResult(scanResult);
-                }
-            }
-
-        }
-
-    };
-    @Override
-    public void onScanResults(String str) {
-        Message msg = new Message();
-        msg.obj = str;
-        scanHandler.sendMessage(msg);
-
-
-    }
-
-
-    @Override
-    public void onScanResults(String str, int type) {
-
-    }
-    /**
-     * 定义广播接受
-     */
-    BroadcastReceiver mReceiver = new BroadcastReceiver() {
-        @Override
-        public void onReceive(Context context, Intent intent) {
-            String scanResult = intent.getStringExtra(scanBean.getDataName());
-            if (scanResult==null){return; }
-            String scanStatus = "";
-            if (!scanBean.getStatusName().isEmpty()){
-                scanStatus = intent.getStringExtra(scanBean.getStatusName());
-            }else{
-                scanStatus = scanResult.isEmpty()? "" : "ok"; //有值 默认是扫码成功;
-            }
-
-            //新大陆(MT65,MT90) 需要手动关闭
-            if (!scanBean.getActionStop().isEmpty()){
-                Intent stopIntent = new Intent(scanBean.getActionStop());
-                mContext.sendBroadcast(stopIntent);
-            }
-
-            if ("ok".equals(scanStatus)){
-                setScanResult(scanResult);
-            }else{
-                showErrorToast(getString(R.string.scan_failed));
-            }
-        }
-    };
-
-    /**
-     * 注册广播
-     */
-    private void initReceiver(){
-
-        try {
-
-            String scanStr = getScanSetting();
-            scanBean = JsonUtil.getObject(scanStr, ScanBean.class);
-            Integer is_broadcast = scanBean.getIsBroadcast();//是否广播
-
-            if (is_broadcast ==1){
-                IntentFilter mFilter = new IntentFilter(scanBean.getAction());
-                this.registerReceiver(mReceiver, mFilter);
-            }else{
-                //不广播进行处理 jni模式
-                String pdaBrand = StoTongJNI.getmPdaBrand();
-                if (!pdaBrand.isEmpty()){
-                    StoTongJNI.getIns(this).setmScanCB(this);
-                    StoTongJNI.getIns(this).SetScannerOn();
-                }
-            }
-
-
-        }catch (Exception e) {
-            showErrorToast("获取扫码配置失败"+e.getMessage());
-            XLog.e("获取扫码配置失败:" + e.getMessage());
-        }
-    }
-
-    private void initEdit() {
-        //
-        etOrderNo.setOnEditorActionListener(new TextView.OnEditorActionListener() {
-            @Override
-            public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
-                if (actionId == EditorInfo.IME_ACTION_DONE) {
-                    String orderNo = etOrderNo.getText().toString().trim();
-                    if (StringUtils.isEmpty(orderNo)) {
-                        setEditTextFocused(v,true);
-                        showWarningToast(v.getHint().toString());
-                        return false;
-                    }
-                    pictureSelectorUpload.authCamera();
-                    return false;
-                }
-                return false;
-            }
-        });
-        etOrderNo.addTextChangedListener(new TextWatcher() {
-            public void onTextChanged(CharSequence s, int start, int before, int count) {
-                if (s.length() > 0 ) {
-                    if (etOrderNo.isEnabled()){
-                        ibOrderNoClear.setVisibility(View.VISIBLE);
-                    }
-                    setEditTextNormal(etOrderNo,true);
-                } else {
-                    ibOrderNoClear.setVisibility(View.INVISIBLE);
-                    setEditTextFocused(etOrderNo,true);
-                }
-            }
-
-            public void beforeTextChanged(CharSequence s, int start, int count, int after) {
-            }
-
-            public void afterTextChanged(Editable s) {
-
-            }
-        });
-        ibOrderNoClear.setOnClickListener(new View.OnClickListener() {
-            @Override
-            public void onClick(View view) {
-                etOrderNo.requestFocus();
-                etOrderNo.getText().clear();
-            }
-        });
-    }
-
-
-    private void iniData(){
-
-    }
-
-
-
-    private OnRxScanerListener mScanerListener = new OnRxScanerListener() {
-        @Override
-        public void onSuccess(String type, Result result) {
-            String scanResult = result.getText();
-            switch (type){
-                case BaseConfig.COMMON_SCANNER_ONLY:
-                    setScanResult(scanResult);
-
-                    break;
-            }
-        }
-        @Override
-        public void onFail(String type, String message) {
-
-        }
-    };
-
-    //把扫描结果赋值
-    private void setScanResult(String scanResult){
-        //获取焦点的view对象
-        View view=getWindow().getDecorView().findFocus();
-        //如果是EditText
-        if(view instanceof EditText)
-        {
-            ((EditText) view).setText(scanResult);
-
-            switch (view.getId()) {
-                case R.id.et_order_no:
-                    pictureSelectorUpload.authCamera();
-                    break;
-                default:
-            }
-
-
-        }
-    }
-
-
-    private void pictureInbound(){
-        if (!validate()){
-            return;
-        }
-
-
-        if (!checkRepeat(Urls.FXY_BATCH_PICTURE_INBOUND+(postParam.toString()))){
-            Toast.makeText(this, getString(R.string.error_data_processed), Toast.LENGTH_LONG).show();
-            return;
-        }
-
-
-
-        OkGo.<String>post(Urls.getServiceAddress(this) + Urls.FXY_BATCH_PICTURE_INBOUND).upJson(postParam)
-                .execute(new MyDialogCallback(this, true, true) {
-                    @Override
-                    public void onSuccess(Response<String> response) {
-                        super.onSuccess(response);
-                        try {
-                            ActionBean bean = JsonUtil.getObject(response.body(), ActionBean.class);
-                            if(bean.code == 1){
-                                showSuccessToast(bean.msg);
-                                pictureSelectorUpload.emptyRemake();//清空图片
-                                photoList.clear();
-                                etOrderNo.setText("");
-
-                            }else{
-                                showWarningToast(bean.msg);
-                            }
-                        } catch (Exception e) {
-                            e.printStackTrace();
-                            XLog.e("添加理货数据结果返回错误",e.getMessage());
-                        }
-                    }
-                });
-    }
-
-
-    /*
-     * 校验必录
-     */
-    private boolean validate(){
-        photoList = pictureSelectorUpload.getPhotoList();
-        //数据检查不通过
-        String orderNo = etOrderNo.getText().toString().trim();
-        if (orderNo.isEmpty()){
-            showWarningToast(etOrderNo.getHint().toString());
-            return false;
-        }
-        try {
-
-
-
-
-            postParam = new JSONObject();
-
-            //检查是否拍照  工单处理时拍照拍照非必传
-            if (photoList.size()==0){
-                showWarningToast("请拍照上传");
-                return false;
-            }
-            Gson gson = new Gson();
-            postParam.put("photo",gson.toJson(photoList));
-            postParam.put("tracking_number",orderNo);
-
-        } catch (JSONException e) {
-            showWarningToast("系统异常"+e.getMessage());
-            e.printStackTrace();
-            return false;
-        }
-
-
-
-        return true;
-    }
-
-    //sIsGoodinfoMatch,sIsBattery,sIsMagnetic,sIsWood,sIsExtra,sIsOther
-    @OnClick({R.id.btn_confirm,R.id.btn_photos})
-    public void onViewClicked(View view) {
-        Bundle bundle = new Bundle();
-        switch (view.getId()) {
-            case R.id.btn_photos:
-                pictureSelectorUpload.authCamera();
-                break;
-           case R.id.btn_confirm:
-                pictureInbound();
-                break;
-            default:
-                break;
-        }
-    }
-
-    @Override
-    protected void onDestroy() {
-        unbinder.unbind();
-        pictureSelectorUpload.removeHandler();
-        super.onDestroy();
-    }
-    @Override
-    protected void onResume() {
-        super.onResume();
-        initReceiver();
-    }
-    @Override
-    protected void onPause() {
-        super.onPause();
-        //销毁在onResume()方法中的广播
-        try {
-            //停止扫描
-            Integer is_broadcast = scanBean.getIsBroadcast();//是否广播
-            if (is_broadcast==0){
-                StoTongJNI.getIns(mContext).SetScannerStop();
-                StoTongJNI.getIns(mContext).SetScannerOff();
-            }else{
-                unregisterReceiver(mReceiver);
-            }
-        }catch (Exception e){
-            XLog.e("销毁广播失败:",e.getMessage());
-        }
-    }
-
-}

+ 0 - 2
app/src/main/java/com/fxy/putIn/PutinPhotosMainActivity.java

@@ -775,8 +775,6 @@ public class PutinPhotosMainActivity extends  BaseActivity implements StoJNI.Sca
             e.printStackTrace();
 
         }
-
-
     }
 
 

+ 672 - 0
app/src/main/java/com/fxy/putIn/TallyPutInMainActivity.java

@@ -0,0 +1,672 @@
+package com.fxy.putIn;
+
+import android.annotation.SuppressLint;
+import android.content.BroadcastReceiver;
+import android.content.Context;
+import android.content.Intent;
+import android.content.IntentFilter;
+import android.os.Bundle;
+import android.os.Handler;
+import android.os.Message;
+import android.support.v7.widget.RecyclerView;
+import android.text.Editable;
+import android.text.TextWatcher;
+import android.view.KeyEvent;
+import android.view.View;
+import android.view.inputmethod.EditorInfo;
+import android.widget.EditText;
+import android.widget.ImageButton;
+import android.widget.LinearLayout;
+import android.widget.TextView;
+
+import com.elvishew.xlog.XLog;
+import com.fxy.R;
+import com.fxy.baselibrary.base.BaseActivity;
+import com.fxy.baselibrary.bean.BaseEventBusBean;
+import com.fxy.baselibrary.interfaces.OnRxScanerListener;
+import com.fxy.baselibrary.util.JsonUtil;
+import com.fxy.bean.ActionBean;
+import com.fxy.bean.ScanBean;
+import com.fxy.common.AsyncPictureSelector;
+import com.fxy.common.AsyncPictureUpload;
+import com.fxy.constant.BaseConfig;
+import com.fxy.constant.EventCode;
+import com.fxy.net.MyDialogCallback;
+import com.fxy.net.Urls;
+import com.fxy.putIn.bean.TallyPutInBean;
+import com.fxy.utils.UploadUtils;
+import com.google.gson.Gson;
+import com.google.zxing.Result;
+import com.luck.picture.lib.config.PictureConfig;
+import com.lzy.okgo.OkGo;
+import com.lzy.okgo.model.Response;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import butterknife.BindView;
+import butterknife.ButterKnife;
+import butterknife.OnClick;
+import butterknife.Unbinder;
+import sto.android.app.StoJNI;
+import sto.android.app.StoPdaKeyEvent;
+import sto.android.app.StoTongJNI;
+
+public class TallyPutInMainActivity extends  BaseActivity implements StoJNI.ScanCallBack{
+
+    /**
+     * 列表适配器
+     */
+    Context mContext = this;
+
+    @BindView(R.id.et_order_number)
+    EditText etOrderNumber;
+
+    @BindView(R.id.tv_qty)
+    TextView tvQty;
+
+    @BindView(R.id.tv_await_num)
+    TextView tvAwaitNum;
+
+
+    @BindView(R.id.ll_label_picture)
+    LinearLayout llLabelPicture;
+
+    @BindView(R.id.ll_order_number)
+    LinearLayout llOrderNumber;
+
+
+    //
+    //扫码扫码动作
+    private ScanBean scanBean;
+
+    private  ArrayList<String> baseImgList = new ArrayList<>();
+    protected String action;
+
+
+    private HashMap<String, AsyncPictureSelector> mapPictureSelector = new HashMap<>();
+    
+    private boolean isRequiredShow = false;
+
+    private String currentPictureType= "label_img";
+
+    private Unbinder unbinder;
+
+    private AsyncPictureUpload asyncPictureUpload;
+
+    private TallyPutInBean tallyPutInBean;
+
+
+
+    @Override
+    public int getContentViewResId() {
+        return R.layout.activity_fxy_tray_putin;
+    }
+
+    @Override
+    public boolean showToolBar() {
+        return true;
+    }
+
+    @Override
+    public boolean openEventBus() {
+        return true;
+    }
+
+    @Override
+    protected void getBundleExtras(Bundle bundle) {
+        //XLog.e("接收数据解析:",bundle);
+    }
+
+
+
+    //finish的返回监听
+    //这里的requestCode参数,就是上面设置的 1 ,当跳转的页面返回的时候,通过这个加以判断
+    //resultCode ,这个参数是在跳转的页面里面规定的,它也是一个int类型的标志
+    //第三个参数包含了返回的值
+    //如果不需要所跳转的页面返回值,也就不需要这个方法了
+    @Override
+    public void onActivityResult(int requestCode, int resultCode, Intent data) {
+        super.onActivityResult(requestCode, resultCode, data);
+        if (resultCode == RESULT_OK) {
+            // 图片选择结果回调
+            if (requestCode == PictureConfig.CHOOSE_REQUEST) {
+                if (mapPictureSelector.containsKey(currentPictureType)){
+                    mapPictureSelector.get(currentPictureType).getSelectImg(data);
+                }
+                totalAwaitNum();
+//                asyncPictureUpload.setStartUpload();
+                submitLabelImg();
+            }
+        }
+
+
+
+    }
+
+    /**
+     * EventBus接收信息的方法,开启后才会调用(非粘性事件)
+     *
+     * @param event
+     */
+    @Override
+    protected void EventBean(BaseEventBusBean event) {
+//        XLog.e("----------接收返回--------------");
+//        XLog.e("接收返回:"+event.getEventCode());
+        assert event != null;
+        switch (event.getEventCode()){
+            case EventCode.file_upload_lister:
+                totalAwaitNum();
+                break;
+        }
+
+
+    }
+
+    @Override
+    public boolean isPlayMusic() {
+        return true;
+    }
+
+
+    @Override
+    protected void initView() {
+        unbinder = ButterKnife.bind(this);
+        setTitleName("快递打板");
+
+        asyncPictureUpload = new AsyncPictureUpload(this);
+        initEdit();
+        iniData();
+        RecyclerView rvLabelShowImg = (RecyclerView)llLabelPicture.findViewById(R.id.rv_show_img);
+        mapPictureSelector.put("label_img",setItemPicture("label_img",rvLabelShowImg,9999));
+
+
+        totalAwaitNum();
+
+    }
+
+
+    /**
+     * 设置多个上传文件
+     * @param uploadType String
+     * @param showImg RecyclerView
+     */
+    private AsyncPictureSelector setItemPicture(String uploadType,RecyclerView showImg,int num){
+
+        String notifyUrl = Urls.getServiceAddress(this) + Urls.FXY_DETECTION_PUTIN;
+        AsyncPictureSelector pictureUpload = new AsyncPictureSelector(TallyPutInMainActivity.this,showImg,"tally",uploadType,notifyUrl,false);
+        pictureUpload.setUploadType(uploadType);
+        pictureUpload.setCompress(true,100,100);
+        pictureUpload.setOnlyCamera(true);
+        pictureUpload.setMaxSelectNum(num);
+
+        return  pictureUpload;
+    }
+
+
+
+
+    @Override
+    public boolean dispatchKeyEvent(KeyEvent event) {
+        //XLog.e("event:"+event.getKeyCode());
+        if ((event.getKeyCode()==KeyEvent.KEYCODE_DPAD_CENTER || event.getKeyCode()==KeyEvent.KEYCODE_ENTER )  && event.getAction() == KeyEvent.ACTION_DOWN){
+            //按确定键
+            getPallet();
+        }
+        return super.dispatchKeyEvent(event);
+    }
+
+
+
+    //监听按键
+    public boolean onKeyDown(int keyCode, KeyEvent event) {
+        XLog.e("监听按键:"+keyCode);XLog.e(event);
+        if (scanBean.getIsBroadcast()==0 && StoTongJNI.getIns(mContext).getEventFuction(keyCode)  == StoPdaKeyEvent.KEYCODE_SCAN
+                && event.getRepeatCount() == 0) {
+
+            if (StoTongJNI.getIns(mContext).GetScannerIsScanning()) {
+//
+            } else {
+                StoTongJNI.getIns(mContext).SetScannerStart();
+            }
+        }
+        return super.onKeyDown(keyCode, event);
+    }
+
+    @SuppressLint("HandlerLeak")
+    Handler scanHandler = new Handler() {
+
+        @Override
+        public void handleMessage(Message msg) {
+            // TODO Auto-generated method stub
+            if (msg.obj != null) {
+
+                String scanResult = msg.obj.toString().trim();
+                if (!scanResult.isEmpty()){
+                    setScanResult(scanResult);
+                }
+            }
+
+        }
+
+    };
+    @Override
+    public void onScanResults(String str) {
+        Message msg = new Message();
+        msg.obj = str;
+        scanHandler.sendMessage(msg);
+
+
+    }
+
+
+    @Override
+    public void onScanResults(String str, int type) {
+
+    }
+    /**
+     * 定义广播接受
+     */
+    BroadcastReceiver mReceiver = new BroadcastReceiver() {
+        @Override
+        public void onReceive(Context context, Intent intent) {
+            String scanResult = intent.getStringExtra(scanBean.getDataName());
+            if (scanResult==null){return; }
+            String scanStatus = "";
+            if (!scanBean.getStatusName().isEmpty()){
+                scanStatus = intent.getStringExtra(scanBean.getStatusName());
+            }else{
+                scanStatus = scanResult.isEmpty()? "" : "ok"; //有值 默认是扫码成功;
+            }
+
+            //新大陆(MT65,MT90) 需要手动关闭
+            if (!scanBean.getActionStop().isEmpty()){
+                Intent stopIntent = new Intent(scanBean.getActionStop());
+                mContext.sendBroadcast(stopIntent);
+            }
+
+            if ("ok".equals(scanStatus)){
+                setScanResult(scanResult);
+            }else{
+                showErrorToast(getString(R.string.scan_failed));
+            }
+        }
+    };
+
+    /**
+     * 注册广播
+     */
+    private void initReceiver(){
+
+        try {
+
+            String scanStr = getScanSetting();
+            scanBean = JsonUtil.getObject(scanStr, ScanBean.class);
+            Integer is_broadcast = scanBean.getIsBroadcast();//是否广播
+
+            if (is_broadcast ==1){
+                IntentFilter mFilter = new IntentFilter(scanBean.getAction());
+                this.registerReceiver(mReceiver, mFilter);
+            }else{
+                //不广播进行处理 jni模式
+                String pdaBrand = StoTongJNI.getmPdaBrand();
+                if (!pdaBrand.isEmpty()){
+                    StoTongJNI.getIns(this).setmScanCB(this);
+                    StoTongJNI.getIns(this).SetScannerOn();
+                }
+            }
+
+
+        }catch (Exception e) {
+            showErrorToast("获取扫码配置失败"+e.getMessage());
+            XLog.e("获取扫码配置失败:" + e.getMessage());
+        }
+    }
+
+    private void initEdit() {
+        List<EditText> list = new ArrayList<>();
+        list.add(etOrderNumber);
+        unifyEdit(list);
+    }
+
+
+    private void iniData(){
+        baseImgList.add("label_img");
+    }
+
+    //getAwaitNum
+    private void totalAwaitNum(){
+        int awaitNum = UploadUtils.getAwaitNum(mRealm,getClass().getSimpleName());
+        tvAwaitNum.setText(String.valueOf(awaitNum));
+    }
+
+    //统一按钮回调
+    @SuppressLint("NonConstantResourceId")
+    public void callbackEditor(View v){
+
+        switch (v.getId()) {
+
+            case R.id.et_order_number:
+
+                getPallet();
+
+                break;
+            default:
+        }
+
+    }
+
+    /**
+     * 统一设置Edit监听
+     * @param  list
+     */
+    public void unifyEdit(List<EditText> list){
+        for (int i=0;i<list.size();i++){
+            EditText editText = list.get(i);
+
+            LinearLayout linearLayout = (LinearLayout)editText.getParent();
+            ImageButton imageButton = getChildImageButton(linearLayout);
+
+
+            //监听按确定
+            editText.setOnEditorActionListener(new TextView.OnEditorActionListener() {
+                @Override
+                public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
+                    //XLog.e("actionId:"+actionId);
+                    if (actionId == EditorInfo.IME_ACTION_SEND || actionId == EditorInfo.IME_ACTION_DONE   ) {
+                        if (v.getText().toString().trim().isEmpty()) {
+                            setEditTextFocused(v,true);
+                            showWarningToast(v.getHint().toString());
+                            return false;
+                        }else{
+                            setEditTextNormal(v,true);
+                        }
+
+                        callbackEditor(v);
+
+                        return false;
+                    }
+                    return false;
+                }
+            });
+            editText.addTextChangedListener(new TextWatcher() {
+                public void onTextChanged(CharSequence s, int start, int before, int count) {
+                    EditText currentEditText = null;
+                    ImageButton currentImage = null;
+                    //获取焦点的view对象
+                    View view=getWindow().getDecorView().findFocus();
+                    //如果是EditText
+                    if(view instanceof EditText){
+                        currentEditText = (EditText) view;
+                        currentImage = getChildImageButton((LinearLayout)currentEditText.getParent());
+                    }
+
+                    if (s.length() > 0  ) {
+
+                        if (currentImage !=null ){
+                            currentImage.setVisibility(View.VISIBLE);
+                        }
+                        if (currentEditText!=null){
+                            setEditTextNormal(currentEditText,true);
+                        }
+
+                    } else {
+                        if (currentImage !=null ){
+                            currentImage.setVisibility(View.INVISIBLE);
+                        }
+                        if (currentEditText!=null && isRequiredShow){
+                            setEditTextFocused(currentEditText,true);
+                        }
+                    }
+                }
+
+                public void beforeTextChanged(CharSequence s, int start, int count, int after) {
+                }
+
+                public void afterTextChanged(Editable s) {
+
+                }
+            });
+
+            if (imageButton !=null ){
+                unifyClearEdit(imageButton);
+            }
+        }
+    }
+
+
+    private OnRxScanerListener mScanerListener = new OnRxScanerListener() {
+        @Override
+        public void onSuccess(String type, Result result) {
+            String scanResult = result.getText();
+            switch (type){
+                case BaseConfig.COMMON_SCANNER_ONLY:
+                    setScanResult(scanResult);
+
+                    break;
+            }
+        }
+        @Override
+        public void onFail(String type, String message) {
+
+        }
+    };
+
+    //把扫描结果赋值
+    private void setScanResult(String scanResult){
+        //获取焦点的view对象
+        View view=getWindow().getDecorView().findFocus();
+        //如果是EditText
+        if(view instanceof EditText)
+        {
+            ((EditText) view).setText(scanResult);
+            showSuccessToast("扫描成功");
+            callbackEditor(view);
+        }
+    }
+
+
+    //检查是否存在上传
+    private void checkIsUpload(){
+
+    }
+
+
+
+
+    //获取跟踪单号
+    private void getPallet(){
+
+        checkIsUpload();
+        if (etOrderNumber.getText().toString().isEmpty()){
+            showErrorToast(etOrderNumber.getHint().toString());
+            return;
+        }
+        Map<String,Object> math = new HashMap<>();
+        math.put("pallet_code",etOrderNumber.getText().toString().trim());
+
+        String mathJson = (new Gson()).toJson(math);
+         OkGo.<String>post(Urls.getServiceAddress(this) + Urls.FXY_CHECK_PALLET).upJson(mathJson)
+                .execute(new MyDialogCallback(this, true, true) {
+                    @Override
+                    public void onSuccess(Response<String> response) {
+                        super.onSuccess(response);
+
+                        try {
+
+                            ActionBean bean = JsonUtil.getObject(response.body(), ActionBean.class);
+                            if (bean.data!=null && !bean.data.isEmpty() && !bean.data.equals("[]")){
+                                tallyPutInBean =  JsonUtil.jsonString2Bean(bean.data,TallyPutInBean.class);
+                            }else{
+                                tallyPutInBean = new TallyPutInBean();
+                            }
+
+                            String voiceName = tallyPutInBean.getVoiceName();
+
+                            tvQty.setText(String.valueOf(tallyPutInBean.getQty()));
+                            if(bean.code == 1){
+                                showSuccessToast(bean.msg,voiceName);
+                                mapPictureSelector.get(currentPictureType).authCamera();
+                            }else{
+                                showWarningToast(bean.msg,voiceName);
+                            }
+                        }catch (Exception e) {
+                            e.printStackTrace();
+                            XLog.e("确认错误",e.getMessage());
+                        }
+
+                    }
+                });
+    }
+
+
+    //提交面单信息
+    private void submitLabelImg(){
+        checkIsUpload();
+        if (etOrderNumber.getText().toString().isEmpty()){
+            showErrorToast(etOrderNumber.getHint().toString());
+            return;
+        }
+
+        Gson gson = new Gson();
+        Map<String,Object> math = new HashMap<>();
+        math.put("pallet_code",tallyPutInBean.getPalletCode().trim());
+
+        //面单
+        List<String> stringList = mapPictureSelector.get("label_img").getOssPhotoList();
+        if (stringList.size()==0){
+            showWarningToast("面单照片不能为空");
+            return;
+        }
+        math.put("label_img_tag",mapPictureSelector.get("label_img").getUniqueTag());
+        math.put("label_img",gson.toJson(stringList));
+
+
+        OkGo.<String>post(Urls.getServiceAddress(this) + Urls.FXY_PICTURE_INBOUND).upJson(gson.toJson(math))
+                .execute(new MyDialogCallback(this, true, true) {
+                    @Override
+                    public void onSuccess(Response<String> response) {
+                        super.onSuccess(response);
+                        try {
+
+                            ActionBean bean = JsonUtil.getObject(response.body(), ActionBean.class);
+                            if (bean.data!=null && !bean.data.isEmpty() && !bean.data.equals("[]")){
+                                tallyPutInBean =  JsonUtil.jsonString2Bean(bean.data,TallyPutInBean.class);
+                            }
+
+                            tvQty.setText(String.valueOf(tallyPutInBean.getQty()));
+                            String voiceName = tallyPutInBean.getVoiceName();
+                            if(bean.code == 1){
+                                showSuccessToast(bean.msg,voiceName);
+                                mapPictureSelector.get(currentPictureType).authCamera();
+                            }else{
+                                showWarningToast(bean.msg,voiceName);
+                            }
+
+                        }catch (Exception e) {
+                            e.printStackTrace();
+                            XLog.e("错误",e.getMessage());
+                        }
+                    }
+                });
+
+    }
+
+
+
+    private void closePallet(){
+
+        if (etOrderNumber.getText().toString().isEmpty()){
+            showErrorToast(etOrderNumber.getHint().toString());
+            return;
+        }
+        Map<String,Object> math = new HashMap<>();
+        math.put("pallet_code",etOrderNumber.getText().toString().trim());
+
+        String mathJson = (new Gson()).toJson(math);
+        OkGo.<String>post(Urls.getServiceAddress(this) + Urls.FXY_CLOSE_PALLET).upJson(mathJson)
+                .execute(new MyDialogCallback(this, true, true) {
+                    @Override
+                    public void onSuccess(Response<String> response) {
+                        super.onSuccess(response);
+
+                        try {
+
+                            ActionBean bean = JsonUtil.getObject(response.body(), ActionBean.class);
+                            if(bean.code == 1){
+                                showSuccessToast(bean.msg);
+                                etOrderNumber.setText("");
+                                etOrderNumber.setEnabled(true);
+                                for (int i=0;i<baseImgList.size();i++){
+                                    if (mapPictureSelector.containsKey(baseImgList.get(i))){
+                                        mapPictureSelector.get(baseImgList.get(i)).emptyRemake();
+                                    }
+                                }
+                                etOrderNumber.requestFocus();
+                                tvQty.setText("0");
+                            }else{
+                                showWarningToast(bean.msg);
+                            }
+                        }catch (Exception e) {
+                            e.printStackTrace();
+                            XLog.e("关闭托盘错误",e.getMessage());
+                        }
+
+                    }
+                });
+        
+    }
+
+
+
+    //sIsGoodinfoMatch,sIsBattery,sIsMagnetic,sIsWood,sIsExtra,sIsOther
+    @OnClick({R.id.btn_confirm})
+    public void onViewClicked(View view) {
+        Bundle bundle = new Bundle();
+        switch (view.getId()) {
+            case R.id.btn_confirm:
+                closePallet();
+                break;
+            default:
+                break;
+        }
+    }
+
+
+
+
+
+
+
+    @Override
+    protected void onDestroy() {
+        unbinder.unbind();
+        super.onDestroy();
+        asyncPictureUpload.removeHandler();
+    }
+    @Override
+    protected void onResume() {
+        super.onResume();
+        initReceiver();
+    }
+    @Override
+    protected void onPause() {
+        super.onPause();
+        //销毁在onResume()方法中的广播
+        try {
+            //停止扫描
+            Integer is_broadcast = scanBean.getIsBroadcast();//是否广播
+            if (is_broadcast==0){
+                StoTongJNI.getIns(mContext).SetScannerStop();
+                StoTongJNI.getIns(mContext).SetScannerOff();
+            }else{
+                unregisterReceiver(mReceiver);
+            }
+        }catch (Exception e){
+            XLog.e("销毁广播失败:",e.getMessage());
+        }
+    }
+
+}

+ 66 - 0
app/src/main/java/com/fxy/putIn/bean/TallyPutInBean.java

@@ -0,0 +1,66 @@
+package com.fxy.putIn.bean;
+
+import android.os.Parcel;
+import android.os.Parcelable;
+
+public class TallyPutInBean implements Parcelable {
+    private int qty = 0;//
+    public String pallet_code = "";
+    private String voice_name= "";
+    public TallyPutInBean(){
+    }
+
+    protected TallyPutInBean(Parcel in) {
+        qty = in.readInt();
+        pallet_code = in.readString();
+        voice_name = in.readString();
+    }
+
+    @Override
+    public void writeToParcel(Parcel dest, int flags) {
+        dest.writeInt(qty);
+        dest.writeString(pallet_code);
+        dest.writeString(voice_name);
+    }
+
+    @Override
+    public int describeContents() {
+        return 0;
+    }
+
+    public static final Creator<TallyPutInBean> CREATOR = new Creator<TallyPutInBean>() {
+        @Override
+        public TallyPutInBean createFromParcel(Parcel in) {
+            return new TallyPutInBean(in);
+        }
+
+        @Override
+        public TallyPutInBean[] newArray(int size) {
+            return new TallyPutInBean[size];
+        }
+    };
+
+    public int getQty() {
+        return qty;
+    }
+
+    public void setQty(int qty) {
+        this.qty = qty;
+    }
+
+    public String getPalletCode() {
+        return pallet_code;
+    }
+
+    public void setPalletCode(String pallet_code) {
+        this.pallet_code = pallet_code;
+    }
+
+    public String getVoiceName() {
+        return voice_name;
+    }
+
+    public void setVoiceName(String voice_name) {
+        this.voice_name = voice_name;
+    }
+}

+ 52 - 44
app/src/main/res/layout/activity_fxy_putin_pallet.xml

@@ -19,24 +19,65 @@
             android:orientation="vertical">
 
             <LinearLayout
+                android:id="@+id/ll_order_number"
                 style="@style/FromLinearLayoutItem"
                 android:orientation="horizontal">
                 <EditText
                     style="@style/EditTextStyle"
-                    android:id="@+id/et_order_no"
-                    android:hint="@string/hint_please_scan_no"
+                    android:id="@+id/et_order_number"
+                    android:hint="扫描或者输FX单号"
                     android:text=""/>
-                <ImageButton
-                    style="@style/ClearImg"
-                    android:id="@+id/ib_order_no_clear"/>
+                <include layout="@layout/item_image_close" />
 
             </LinearLayout>
 
             <LinearLayout
-                android:id="@+id/ll_take_picture"
+                android:id="@+id/ll_extend_info"
+                android:layout_width="match_parent"
+                android:layout_height="wrap_content"
+                android:layout_marginLeft="@dimen/dp_10"
+                android:layout_marginRight="@dimen/dp_10"
+                android:layout_marginTop="@dimen/dp_10"
+                android:background="@drawable/bg_white_et"
+                android:gravity="center_vertical"
+                android:orientation="vertical"
+                android:paddingLeft="10dp"
+                android:visibility="gone"
+                android:paddingRight="10dp">
+                <LinearLayout
+                    android:id="@+id/ll_customer_code"
+                    android:layout_width="match_parent"
+                    android:layout_height="wrap_content"
+                    android:paddingBottom="5dp"
+                    android:paddingTop="5dp"
+
+                    android:orientation="horizontal">
+
+                    <TextView
+                        style="@style/tvLeftStyle"
+                        android:text="托数" />
+                    <TextView
+                        style="@style/tvLeftStyle"
+                        android:text=":" />
+
+                    <com.fxy.baselibrary.views.MarqueeTextView
+                        style="@style/mtRightStyle"
+                        android:id="@+id/mt_customer_code"
+
+                        />
+
+                    <TextView
+                        android:id="@+id/tv_edit_customer"
+                        style="@style/tvLeftStyle"
+                        android:text="修改"
+                        android:textColor="@color/actionsheet_blue" />
+                </LinearLayout>
+            </LinearLayout>
+
+            <LinearLayout
+                android:id="@+id/ll_label_picture"
                 android:layout_width="match_parent"
                 android:layout_height="wrap_content"
-                android:visibility="visible"
                 android:orientation="vertical">
                 <LinearLayout
                     android:layout_width="match_parent"
@@ -46,7 +87,7 @@
                     android:background="@null"
                     android:padding="@dimen/dp_10"
                     android:gravity="center_vertical"
-                    android:orientation="vertical">
+                    android:orientation="horizontal">
                     <TextView
                         style="@style/fontSize"
                         android:layout_width="wrap_content"
@@ -54,42 +95,10 @@
                         android:textStyle="bold"
                         android:text="拍照">
                     </TextView>
+
                 </LinearLayout>
                 <include layout="@layout/fragment_show_img"/>
             </LinearLayout>
-
-
-
-
-            <LinearLayout
-                android:layout_width="match_parent"
-                android:layout_height="wrap_content"
-                android:layout_marginLeft="@dimen/dp_10"
-                android:layout_marginTop="@dimen/dp_10"
-                android:layout_marginRight="@dimen/dp_10"
-                android:layout_marginBottom="@dimen/dp_4"
-                android:background="@drawable/bg_white_et"
-                android:gravity="center_vertical"
-                android:orientation="horizontal"
-                android:layout_gravity="bottom"
-                android:visibility="gone"
-                android:padding="10dp">
-                <TextView
-                    style="@style/fontSize"
-                    android:id="@+id/btn_photos"
-                    android:layout_width="match_parent"
-                    android:layout_height="wrap_content"
-                    android:layout_marginLeft="@dimen/dp_10"
-                    android:layout_marginRight="@dimen/dp_10"
-                    android:background="@drawable/bg_orange_item"
-                    android:gravity="center"
-                    android:text="快递入库"
-                    android:padding="10dp"
-                    android:textColor="@color/white"
-                    android:visibility="visible" />
-            </LinearLayout>
-
-
             <LinearLayout
                 android:layout_width="match_parent"
                 android:layout_height="wrap_content"
@@ -100,7 +109,6 @@
                 android:background="@drawable/bg_white_et"
                 android:gravity="center_vertical"
                 android:orientation="horizontal"
-                android:layout_gravity="bottom"
                 android:padding="10dp">
                 <TextView
                     style="@style/fontSize"
@@ -111,12 +119,12 @@
                     android:layout_marginRight="@dimen/dp_10"
                     android:background="@drawable/bg_orange_item"
                     android:gravity="center"
-                    android:text="确认提交"
+                    android:text="确认入库"
                     android:padding="10dp"
                     android:textColor="@color/white"
                     android:visibility="visible" />
             </LinearLayout>
-            <include layout="@layout/item_float_image" />
+            <include layout="@layout/item_upload_await_number" />
         </LinearLayout>
 
 

+ 114 - 0
app/src/main/res/layout/activity_fxy_tray_putin.xml

@@ -0,0 +1,114 @@
+<?xml version="1.0" encoding="utf-8"?>
+<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
+    xmlns:tools="http://schemas.android.com/tools"
+    android:layout_width="match_parent"
+    android:layout_height="match_parent"
+    xmlns:app="http://schemas.android.com/apk/res-auto"
+    android:background="@color/md_grey_100"
+    android:orientation="vertical">
+    <ScrollView
+        android:id="@+id/ll_scroll_view"
+        android:layout_width="match_parent"
+        android:layout_height="match_parent"
+        android:fitsSystemWindows="true"
+        android:scrollbars="none">
+
+        <LinearLayout
+            android:layout_width="match_parent"
+            android:layout_height="wrap_content"
+            android:orientation="vertical">
+
+            <LinearLayout
+                android:id="@+id/ll_order_number"
+                style="@style/FromLinearLayoutItem"
+                android:orientation="horizontal">
+                <EditText
+                    style="@style/EditTextStyle"
+                    android:id="@+id/et_order_number"
+                    android:hint="扫描或者输托盘码"
+                    android:text=""/>
+                <include layout="@layout/item_image_close" />
+
+            </LinearLayout>
+
+
+
+            <LinearLayout
+                android:id="@+id/ll_label_picture"
+                android:layout_width="match_parent"
+                android:layout_height="wrap_content"
+                android:orientation="vertical">
+                <LinearLayout
+                    android:layout_width="match_parent"
+                    android:layout_height="wrap_content"
+                    android:layout_marginLeft="@dimen/dp_10"
+                    android:layout_marginRight="@dimen/dp_10"
+                    android:background="@null"
+                    android:padding="@dimen/dp_10"
+                    android:gravity="center_vertical"
+                    android:orientation="horizontal">
+                    <TextView
+                        style="@style/fontSize"
+                        android:layout_width="wrap_content"
+                        android:layout_height="wrap_content"
+                        android:textStyle="bold"
+                        android:text="拍照">
+                    </TextView>
+                    <TextView
+                        android:layout_width="0dp"
+                        android:layout_height="wrap_content"
+                        android:layout_weight="1"
+                        android:singleLine="true"
+                        android:gravity="right"
+                        android:textSize="@dimen/t24"
+                        android:textColor="@color/actionsheet_red"
+                        android:text="已拍照数量:"
+                        tools:ignore="RtlHardcoded">
+
+                    </TextView>
+                    <TextView
+                        android:id="@+id/tv_qty"
+                        android:layout_width="wrap_content"
+                        android:layout_height="wrap_content"
+                        android:textSize="@dimen/t24"
+                        android:layout_marginRight="10dp"
+                        android:textColor="@color/actionsheet_red"
+                        android:text="0">
+
+                    </TextView>
+                </LinearLayout>
+                <include layout="@layout/fragment_show_img"/>
+            </LinearLayout>
+            <LinearLayout
+                android:layout_width="match_parent"
+                android:layout_height="wrap_content"
+                android:layout_marginLeft="@dimen/dp_10"
+                android:layout_marginTop="@dimen/dp_10"
+                android:layout_marginRight="@dimen/dp_10"
+                android:layout_marginBottom="@dimen/dp_4"
+                android:background="@drawable/bg_white_et"
+                android:gravity="center_vertical"
+                android:orientation="horizontal"
+                android:padding="10dp">
+                <TextView
+                    style="@style/fontSize"
+                    android:id="@+id/btn_confirm"
+                    android:layout_width="match_parent"
+                    android:layout_height="wrap_content"
+                    android:layout_marginLeft="@dimen/dp_10"
+                    android:layout_marginRight="@dimen/dp_10"
+                    android:background="@drawable/bg_orange_item"
+                    android:gravity="center"
+                    android:text="关闭托盘"
+                    android:padding="10dp"
+                    android:textColor="@color/white"
+                    android:visibility="visible" />
+            </LinearLayout>
+            <include layout="@layout/item_upload_await_number" />
+        </LinearLayout>
+
+
+    </ScrollView>
+
+
+</LinearLayout>

+ 11 - 11
app/src/main/res/layout/fragment_homepager.xml

@@ -81,7 +81,7 @@
                         android:layout_width="wrap_content"
                         android:layout_height="wrap_content"
                         android:layout_gravity="center"
-                        android:text="@string/index_put_in"
+                        android:text="返修"
                         android:textColor="@color/black_3d3d3d"
                         android:textSize="@dimen/t14"
                         android:textStyle="bold" />
@@ -92,13 +92,18 @@
                         android:layout_marginTop="@dimen/t12"
                         android:weightSum="2">
 
-                        <TextView
+                        <!--<TextView
                             android:id="@+id/ivt_putin_photos"
                             style="@style/ImageViewWithTextStyle.FontSize"
                             android:drawableTop="@drawable/ic_putin_photos"
                             android:drawablePadding="5dp"
-                            android:text="快递入库" />
-
+                            android:text="快递入库" />-->
+                        <TextView
+                            android:id="@+id/ivt_tally"
+                            style="@style/ImageViewWithTextStyle.FontSize"
+                            android:drawableTop="@drawable/ic_mapan"
+                            android:drawablePadding="5dp"
+                            android:text="打板操作" />
                         <TextView
                             android:id="@+id/ivt_putin_pallet"
                             style="@style/ImageViewWithTextStyle.FontSize"
@@ -114,12 +119,7 @@
                         android:layout_marginTop="@dimen/t12"
                         android:weightSum="2">
 
-                        <TextView
-                            android:id="@+id/ivt_tally"
-                            style="@style/ImageViewWithTextStyle.FontSize"
-                            android:drawableTop="@drawable/ic_mapan"
-                            android:drawablePadding="5dp"
-                            android:text="打板操作" />
+
 
                         <TextView
                             android:id="@+id/ivt_check"
@@ -250,7 +250,7 @@
                         android:layout_width="wrap_content"
                         android:layout_height="wrap_content"
                         android:layout_gravity="center"
-                        android:text="检测"
+                        android:text="售后"
                         android:textColor="@color/black_3d3d3d"
                         android:textSize="@dimen/t14"
                         android:textStyle="bold" />