关于TextView的setText()方法报resource not found exception的问题

本文详细解析了在Android开发中,使用TextView的setText()方法时出现资源找不到异常的原因。问题核心在于setText()方法期望接收String类型参数,若传入int类型则会触发异常。文章通过一个具体的例子说明了如何正确地将数值转换为字符串并设置给TextView。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public void onClick(View v) {
                    int last = Integer.parseInt(((BottomViewHolder) holder).et_num.getText().toString());
                    Log.i("haha","num:"+last);
                    ((BottomViewHolder)holder).et_num.setText((last+1)+"");//注意这行
                }


这个问题是  上边textview的getText()方法取到值了,但是下边同一个textview却报了资源找不到的异常

这是因为

setText()里边的value值必须是String类型的

如果是int类型,会报资源找不到的异常。

FanHui.java:package com.videogo.ui.login; import android.app.AlertDialog; import android.content.Intent; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.util.Log; import android.view.SurfaceHolder; import android.view.SurfaceView; import android.view.View; import android.view.ViewGroup; import android.view.Window; import android.view.WindowManager; import android.widget.AdapterView; import android.widget.BaseAdapter; import android.widget.DatePicker; import android.widget.ImageButton; import android.widget.ListView; import android.widget.RelativeLayout; import android.widget.TextView; import android.widget.Toast; import com.videogo.exception.BaseException; import com.videogo.exception.ErrorCode; import com.videogo.openapi.EZConstants; import com.videogo.openapi.EZPlayer; import androidx.appcompat.app.AppCompatActivity; import com.videogo.openapi.EZOpenSDK; import ezviz.ezopensdk.R; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import java.io.OutputStream; import java.net.HttpURLConnection; import java.net.URL; import java.net.URLEncoder; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Calendar; import java.util.Date; import java.util.List; import java.util.Locale; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; public class FanHui extends AppCompatActivity implements SurfaceHolder.Callback { private static final String TAG = "EZPlayback"; private String mAppKey; private String mDeviceSerial; private String mVerifyCode; private String mAccessToken; private int mCameraNo; private TextView mDateTextView; private int mSelectedYear, mSelectedMonth, mSelectedDay; private static final String KEY_APPKEY = "appkey"; private static final String KEY_SERIAL = "serial"; private static final String KEY_VERIFYCODE = "VerifyCode"; private static final String KEY_ACCESSTOKEN = "accessToken"; private static final String KEY_CAMERANO = "cameraNo"; // 回放录像相关 private static final String VIDEO_BY_TIME_URL = "https://open.ys7.com/api/lapp/video/by/time"; private ExecutorService mExecutorService; private ListView mListView; private PlaybackAdapter mAdapter; private List<VideoInfo> mVideoList = new ArrayList<>(); // 播放器相关 private EZPlayer mEZPlayer; private SurfaceView mPlaybackSurfaceView; private SurfaceHolder mSurfaceHolder; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.ez_playback_list_page); // 创建线程池 mExecutorService = Executors.newFixedThreadPool(2); extractParametersFromIntent(); final Calendar calendar = Calendar.getInstance(); mSelectedYear = calendar.get(Calendar.YEAR); mSelectedMonth = calendar.get(Calendar.MONTH); mSelectedDay = calendar.get(Calendar.DAY_OF_MONTH); // 初始化视图 initViews(); // 设置日期显示模块 setupDatePicker(); // 默认加载当天的录像 loadVideosForSelectedDate(); // 初始化SDK initSDK(); } private void initSDK() { try { // 初始化萤石云SDK EZOpenSDK.initLib(getApplication(), mAppKey); EZOpenSDK.getInstance().setAccessToken(mAccessToken); } catch (Exception e) { Log.e(TAG, "SDK初始化失败", e); Toast.makeText(this, "SDK初始化失败", Toast.LENGTH_SHORT).show(); } } private void initViews() { // 查找ListView mListView = findViewById(R.id.listView); if (mListView == null) { Log.e(TAG, "ListView not found with ID listView"); return; } // 初始化适配器 mAdapter = new PlaybackAdapter(); mListView.setAdapter(mAdapter); // 设置点击事件 mListView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { VideoInfo video = mVideoList.get(position); playVideo(video); } }); // 获取播放器视图 - 使用SurfaceView mPlaybackSurfaceView = findViewById(R.id.remote_playback_wnd_sv); if (mPlaybackSurfaceView != null) { // 设置SurfaceHolder回调 mSurfaceHolder = mPlaybackSurfaceView.getHolder(); mSurfaceHolder.addCallback(this); } else { Log.e(TAG, "SurfaceView not found with ID remote_playback_wnd_sv"); } } // SurfaceHolder回调方法 @Override public void surfaceCreated(SurfaceHolder holder) { Log.d(TAG, "Surface created"); // 当Surface创建时,如果有播放器实例,设置SurfaceHolder if (mEZPlayer != null) { mEZPlayer.setSurfaceHold(holder); } } @Override public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) { Log.d(TAG, "Surface changed: " + width + "x" + height); } @Override public void surfaceDestroyed(SurfaceHolder holder) { Log.d(TAG, "Surface destroyed"); // 当Surface销毁时,释放播放器资源 stopPlayback(); } private void setupDatePicker() { mDateTextView = findViewById(R.id.date_text); ImageButton datePickerButton = findViewById(R.id.date_picker_button); updateDateDisplay(); datePickerButton.setOnClickListener(v -> showDatePickerDialog()); } private void updateDateDisplay() { String formattedDate = String.format(Locale.getDefault(), "%d年%02d月%02d日", mSelectedYear, mSelectedMonth + 1, // 月份需要+1 mSelectedDay); mDateTextView.setText(formattedDate); } private void showDatePickerDialog() { final AlertDialog dlg = new AlertDialog.Builder(this, R.style.Theme_AppCompat_Dialog).create(); dlg.show(); Window window = dlg.getWindow(); window.setContentView(R.layout.datepicker_layout); // 设置对话框宽度 WindowManager.LayoutParams lp = window.getAttributes(); lp.width = WindowManager.LayoutParams.MATCH_PARENT; window.setAttributes(lp); // 获取并初始化 DatePicker DatePicker dpPicker = window.findViewById(R.id.dpPicker); // 隐藏不需要的视图 ViewGroup rootView = (ViewGroup) dpPicker.getChildAt(0); if (rootView != null) { ViewGroup childView = (ViewGroup) rootView.getChildAt(0); if (childView != null) { childView.getChildAt(2).setVisibility(View.VISIBLE); // 确保月选择器可见 childView.getChildAt(1).setVisibility(View.VISIBLE); } } dpPicker.init(mSelectedYear, mSelectedMonth, mSelectedDay, null); // 设置按钮事件 RelativeLayout yesButton = window.findViewById(R.id.YES); RelativeLayout noButton = window.findViewById(R.id.NO); yesButton.setOnClickListener(v -> { mSelectedYear = dpPicker.getYear(); mSelectedMonth = dpPicker.getMonth(); mSelectedDay = dpPicker.getDayOfMonth(); updateDateDisplay(); dlg.dismiss(); // 加载新选择的日期的录像 loadVideosForSelectedDate(); }); noButton.setOnClickListener(v -> dlg.dismiss()); } private void extractParametersFromIntent() { Bundle extras = getIntent().getExtras(); if (extras != null) { mAppKey = extras.getString(KEY_APPKEY, ""); mDeviceSerial = extras.getString(KEY_SERIAL, ""); mVerifyCode = extras.getString(KEY_VERIFYCODE, ""); mAccessToken = extras.getString(KEY_ACCESSTOKEN, ""); mCameraNo = extras.getInt(KEY_CAMERANO, 0); Log.d(TAG, "Received parameters:"); Log.d(TAG, "AppKey: " + mAppKey); Log.d(TAG, "DeviceSerial: " + mDeviceSerial); Log.d(TAG, "VerifyCode: " + mVerifyCode); Log.d(TAG, "AccessToken: " + mAccessToken); Log.d(TAG, "CameraNo: " + mCameraNo); } else { Log.e(TAG, "No parameters received from intent"); } } private void loadVideosForSelectedDate() { // 计算开始和结束时间戳 Calendar cal = Calendar.getInstance(); cal.set(mSelectedYear, mSelectedMonth, mSelectedDay, 0, 0, 0); long startTime = cal.getTimeInMillis(); cal.set(mSelectedYear, mSelectedMonth, mSelectedDay, 23, 59, 59); long endTime = cal.getTimeInMillis(); // 发起网络请求获取录像 fetchVideosByTime(startTime, endTime); } private void fetchVideosByTime(long startTime, long endTime) { mExecutorService.execute(() -> { try { URL url = new URL(VIDEO_BY_TIME_URL); HttpURLConnection conn = (HttpURLConnection) url.openConnection(); conn.setRequestMethod("POST"); conn.setRequestProperty("Content-Type", "application/x-www-form-urlencoded"); conn.setDoOutput(true); conn.setConnectTimeout(10000); conn.setReadTimeout(10000); // 构建POST数据(添加分页参数) StringBuilder postData = new StringBuilder(); postData.append("accessToken=").append(URLEncoder.encode(mAccessToken, "UTF-8")); postData.append("&deviceSerial=").append(URLEncoder.encode(mDeviceSerial, "UTF-8")); postData.append("&channelNo=").append(mCameraNo); postData.append("&startTime=").append(startTime); postData.append("&endTime=").append(endTime); postData.append("&recType=").append(0); // 系统自动选择 postData.append("&version=2.0"); // 添加分页版本 postData.append("&pageSize=100"); // 添加分页大小 // 发送请求 OutputStream os = conn.getOutputStream(); os.write(postData.toString().getBytes("UTF-8")); os.flush(); os.close(); // 处理响应 int responseCode = conn.getResponseCode(); if (responseCode == HttpURLConnection.HTTP_OK) { // 读取响应内容 InputStream is = conn.getInputStream(); BufferedReader reader = new BufferedReader(new InputStreamReader(is)); StringBuilder response = new StringBuilder(); String line; while ((line = reader.readLine()) != null) { response.append(line); } reader.close(); // 解析JSON响应 JSONObject json = new JSONObject(response.toString()); String code = json.optString("code", "0"); if ("200".equals(code)) { JSONArray data = json.getJSONArray("data"); List<VideoInfo> videos = parseVideoData(data); runOnUiThread(() -> { mVideoList.clear(); mVideoList.addAll(videos); mAdapter.notifyDataSetChanged(); }); } else { String msg = json.optString("msg", "未知错误"); Log.e(TAG, "获取录像失败: " + msg); runOnUiThread(() -> Toast.makeText(FanHui.this, "获取录像失败: " + msg, Toast.LENGTH_SHORT).show()); } } else { Log.e(TAG, "HTTP错误: " + responseCode); runOnUiThread(() -> Toast.makeText(FanHui.this, "网络请求失败: " + responseCode, Toast.LENGTH_SHORT).show()); } conn.disconnect(); } catch (Exception e) { Log.e(TAG, "获取录像异常", e); runOnUiThread(() -> Toast.makeText(FanHui.this, "获取录像出错: " + e.getMessage(), Toast.LENGTH_SHORT).show()); } }); } private List<VideoInfo> parseVideoData(JSONArray data) throws JSONException { List<VideoInfo> videos = new ArrayList<>(); SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss", Locale.getDefault()); for (int i = 0; i < data.length(); i++) { JSONObject videoObj = data.getJSONObject(i); VideoInfo video = new VideoInfo(); video.id = videoObj.optString("id"); video.startTime = videoObj.optLong("startTime"); video.endTime = videoObj.optLong("endTime"); video.recType = videoObj.optInt("recType"); // 格式化时间显示 Date startDate = new Date(video.startTime); Date endDate = new Date(video.endTime); video.timeRange = sdf.format(startDate) + " - " + sdf.format(endDate); videos.add(video); } return videos; } private void playVideo(VideoInfo video) { // 停止当前播放 stopPlayback(); try { // 创建播放器实例 mEZPlayer = EZOpenSDK.getInstance().createPlayer(mDeviceSerial, mCameraNo); // 配置播放器 - 设置回调处理器 mEZPlayer.setHandler(mHandler); // 设置验证码 mEZPlayer.setPlayVerifyCode(mVerifyCode); // 关联播放视图 - 使用SurfaceHolder(修复方法名) if (mSurfaceHolder != null) { mEZPlayer.setSurfaceHold(mSurfaceHolder); } else { Log.e(TAG, "无法关联播放视图"); Toast.makeText(this, "播放视图未初始化", Toast.LENGTH_SHORT).show(); } // 创建Calendar对象作为参数 Calendar startCal = Calendar.getInstance(); startCal.setTimeInMillis(video.startTime); Calendar endCal = Calendar.getInstance(); endCal.setTimeInMillis(video.endTime); // 开始回放 mEZPlayer.startPlayback(startCal, endCal); Toast.makeText(this, "开始播放录像: " + video.timeRange, Toast.LENGTH_SHORT).show(); } catch (Exception e) { Log.e(TAG, "播放录像失败", e); Toast.makeText(this, "播放录像失败: " + e.getMessage(), Toast.LENGTH_SHORT).show(); } } private void stopPlayback() { if (mEZPlayer != null) { mEZPlayer.stopPlayback(); mEZPlayer.release(); mEZPlayer = null; } } // 播放器回调处理器 private Handler mHandler = new Handler() { @Override public void handleMessage(Message msg) { switch (msg.what) { case EZConstants.EZRealPlayConstants.MSG_REALPLAY_PLAY_SUCCESS: Log.i(TAG, "回放播放成功"); break; case EZConstants.EZRealPlayConstants.MSG_REALPLAY_PLAY_FAIL: Log.e(TAG, "回放播放失败"); BaseException error = (BaseException) msg.obj; int errorCode = error.getErrorCode(); String errorMsg = "播放失败: " + errorCode; // 根据错误码提供更具体的错误信息 if (errorCode == ErrorCode.ERROR_INNER_VERIFYCODE_NEED) { errorMsg = "需要验证码"; } else if (errorCode == ErrorCode.ERROR_INNER_VERIFYCODE_ERROR) { errorMsg = "验证码错误"; } else if (errorCode == ErrorCode.ERROR_TRANSF_ACCESSTOKEN_ERROR) { errorMsg = "accessToken无效"; } Toast.makeText(FanHui.this, errorMsg, Toast.LENGTH_LONG).show(); break; } } }; @Override protected void onPause() { super.onPause(); if (mEZPlayer != null) { mEZPlayer.stopRealPlay(); mEZPlayer.release(); mEZPlayer = null; } } @Override protected void onDestroy() { super.onDestroy(); stopPlayback(); if (mExecutorService != null) { mExecutorService.shutdown(); } } // 录像信息数据结构 private static class VideoInfo { String id; long startTime; long endTime; int recType; String timeRange; } // 列表适配器 private class PlaybackAdapter extends BaseAdapter { @Override public int getCount() { return mVideoList.size(); } @Override public Object getItem(int position) { return mVideoList.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder; if (convertView == null) { convertView = getLayoutInflater().inflate(R.layout.video_item_layout, parent, false); holder = new ViewHolder(); holder.timeTextView = convertView.findViewById(R.id.time_text); holder.durationTextView = convertView.findViewById(R.id.duration_text); convertView.setTag(holder); } else { holder = (ViewHolder) convertView.getTag(); } VideoInfo video = mVideoList.get(position); // 计算持续时间(分钟) long durationMinutes = (video.endTime - video.startTime) / (1000 * 60); holder.timeTextView.setText(video.timeRange); holder.durationTextView.setText(durationMinutes + "分钟"); return convertView; } class ViewHolder { TextView timeTextView; TextView durationTextView; } } } 开发文档:OPEN API/云直播/播放地址/播放地址接口(新)/获取播放地址 获取播放地址 接口功能: 该接口用于通过设备序列号、通道号获取单台设备的播放地址信息,无法获取永久有效期播放地址。 请求地址 https://open.ys7.com/api/lapp/v2/live/address/get 子账户token请求所需最小权限 "Permission":"Get" "Resource":"dev:序列号" 请求方式 POST 请求参数 参数名 类型 描述 是否必选 accessToken String 授权过程获取的access_token Y deviceSerial String 设备序列号例如427734222,均采用英文符号,限制最多50个字符 Y channelNo Integer 通道号,非必选,默认为1 N protocol Integer 流播放协议,1-ezopen、2-hls、3-rtmp、4-flv,默认为1 N code String ezopen协议地址的设备的视频加密密码 N expireTime Integer 过期时长,单位秒;针对hls/rtmp/flv设置有效期,相对时间;30秒-720天 N type String 地址的类型,1-预览,2-本地录像回放,3-云存储录像回放,非必选,默认为1;回放仅支持rtmp、ezopen、flv协议 N quality Integer 视频清晰度,1-高清(主码流)、2-流畅(子码流) N startTime String 本地录像/云存储录像回放开始时间,云存储开始结束时间必须在同一天,示例:2019-12-01 00:00:00 N stopTime String 本地录像/云存储录像回放结束时间,云存储开始结束时间必须在同一天,示例:2019-12-01 23:59:59 N supportH265 Integer 请判断播放端是否要求播放视频为H265编码格式,1表示需要,0表示不要求 N playbackSpeed String 回放倍速。倍速为 -1( 支持的最大倍速)、0.5、1、2、4、8、16; 仅支持protocol为4-flv 且 type为2-本地录像回放( 部分设备可能不支持16倍速) 或者 3-云存储录像回放 N gbchannel String 国标设备的通道编号,视频通道编号ID N HTTP请求文 POST /api/lapp/v2/live/address/get HTTP/1.1 Host: open.ys7.com Content-Type: application/x-www-form-urlencoded accessToken=at.dunwhxt2azk02hcn7phqygsybbw0wv6p&deviceSerial=C78957921&channelNo=1 返回数据 { "msg": "Operation succeeded", "code": "200", "data": { "id": "254708522214232064", "url": "https://open.ys7.com/v3/openlive/C78957921_1_1.m3u8?expire=1606999273&id=254708522214232064&t=093e5c6668d981e0f0b8d2593d69bdc98060407d1b2f42eaaa17a62b15ee4f99&ev=100", "expireTime": "2020-12-03 20:41:13" } } 返回字段: 字段名 类型 描述 code String 状态码,参考下方返回码。优先判断该错误码,返回200即表示成功。 msg String 状态描述 id String 状态描述 url String 直播地址 expireTime long 直播地址有效期。expireTime参数为空时该字段无效 注意:该接口请求时先解析code属性,如果返回200即表示成功,可继续解析data属性的内容,每一个地址对象中先解析ret属性,如果返回200表示成功,再根据status属性和exception属性判断是否存在异常。 返回码 返回码 返回消息 备注 200 操作成功,获取指定有效期的直播地址 请求成功 201 Created 401 Unauthorized 403 Forbidden 404 Not Found 403 用户不存在 。依据上述开发文档在FanHui.java里添加获取播放地址的功能来实现通过回访地址回放视频。
06-26
package com.jd.projects.wlw.shuhai; import android.app.AlertDialog; import android.content.Intent; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.widget.ArrayAdapter; import android.widget.Button; import android.widget.FrameLayout; import android.widget.GridLayout; import android.widget.ImageView; import android.widget.ListView; import android.widget.ProgressBar; import android.widget.TextView; import android.widget.Toast; import com.android.volley.AuthFailureError; import com.android.volley.DefaultRetryPolicy; import com.android.volley.NoConnectionError; import com.android.volley.ParseError; import com.android.volley.Request; import com.android.volley.RequestQueue; import com.android.volley.ServerError; import com.android.volley.TimeoutError; import com.android.volley.VolleyError; import com.android.volley.toolbox.JsonObjectRequest; import com.android.volley.toolbox.Volley; import com.bumptech.glide.Glide; import com.bumptech.glide.load.resource.drawable.GlideDrawable; import com.bumptech.glide.request.RequestListener; import com.bumptech.glide.request.target.Target; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; import java.io.UnsupportedEncodingException; import java.net.URLEncoder; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Calendar; import java.util.Collections; import java.util.HashSet; import java.util.List; import java.util.Set; import com.jd.projects.wlw.R; public class Shuhai extends AppCompatActivity { private TextView nAme; private ListView dateList; private String currentStationId; private String stationName; // private static final boolean TEST_MODE = false; // private static final String TEST_STATION_ID = "20220811001"; // private static final String TEST_STATION_NAME = "测试监测点"; private GridLayout imageGrid; private ProgressBar progressBar; private RequestQueue requestQueue; private static final String REQUEST_TAG = "ShuhaiRequest"; private String currentDate; private Button btnYear, btnMonth; private int currentYear; private int currentMonth; private Button deviceLocationBtn; private Button spButton; private ZoomImageView1 fullImageView; // 用于全屏显示 private FrameLayout fullscreenContainer; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); try { setContentView(R.layout.shuhai); imageGrid = (GridLayout) findViewById(R.id.image_grid); fullscreenContainer = (FrameLayout) findViewById(R.id.fullscreen_container); fullImageView = (ZoomImageView1) findViewById(R.id.fullscreen_imageview); // Log.d("GkdActivity", "Activity created"); } catch (Exception e) { // Log.e("GkdActivity", "Error setting content view", e); Toast.makeText(this, "加载界面失败", Toast.LENGTH_SHORT).show(); finish(); return; } // 初始化WebView initFullscreenContainer(); // 控件初始化区域 View fanHui = findViewById(R.id.fanHui); fanHui.setOnClickListener(v -> finish()); nAme = (TextView) findViewById(R.id.nAme); dateList = (ListView) findViewById(R.id.date_list); imageGrid = (GridLayout) findViewById(R.id.image_grid); progressBar = (ProgressBar) findViewById(R.id.progressBar); // 新增设备定位按钮初始化 Button deviceLocationBtn = (Button) findViewById(R.id.device_location); deviceLocationBtn.setOnClickListener(v -> { Intent resultIntent = new Intent(); resultIntent.putExtra("action", "show_location"); resultIntent.putExtra("site_id", currentStationId); setResult(RESULT_OK, resultIntent); finish(); }); // Volley请求队列初始化 requestQueue = Volley.newRequestQueue(this); // 年月选择初始化 btnYear = (Button) findViewById(R.id.btn_year); btnMonth = (Button) findViewById(R.id.btn_month); initYearMonthSelection(); // 数据处理 handleIntentData(); // Log.d("GkdActivity", "Station ID: " + currentStationId); // Log.d("GkdActivity", "Station Name: " + stationName); // 名称显示处理 if (stationName != null) { nAme.setText(stationName); } else { nAme.setText("监测点信息"); } // 加载初始数据 loadDatesForCurrentMonth(); spButton = findViewById(R.id.Sp); spButton.setOnClickListener(v -> { // 创建跳转到ShuhaiSPActivity的Intent Intent intent = new Intent(Shuhai.this, ShuhaiSp.class); // 传递当前监测点信息 if (currentStationId != null) { intent.putExtra("nsiteid", currentStationId); } if (stationName != null) { intent.putExtra("sitealiasname", stationName); } // 添加额外数据(如果需要) intent.putExtra("currentDate", currentDate); intent.putExtra("currentYear", currentYear); intent.putExtra("currentMonth", currentMonth); // 启动新Activity startActivity(intent); }); } private void initFullscreenContainer() { // 设置关闭全屏的按钮事件 findViewById(R.id.close_fullscreen).setOnClickListener(v -> { fullscreenContainer.setVisibility(View.GONE); }); } private void initYearMonthSelection() { Calendar calendar = Calendar.getInstance(); currentYear = calendar.get(Calendar.YEAR); currentMonth = calendar.get(Calendar.MONTH) + 1; // 转换为1-12格式 updateYearMonthButtons(); btnYear.setOnClickListener(v -> showYearPicker()); btnMonth.setOnClickListener(v -> showMonthPicker()); } private void updateYearMonthButtons() { btnYear.setText(String.valueOf(currentYear)); btnMonth.setText(String.format("%02d", currentMonth)); } private void showYearPicker() { final List<Integer> years = new ArrayList<>(); int startYear = currentYear - 9; int endYear = currentYear + 9; for (int i = startYear; i <= endYear; i++) years.add(i); new AlertDialog.Builder(this) .setTitle("选择年份") .setAdapter(new ArrayAdapter<>(this, android.R.layout.simple_list_item_1, years), (dialog, which) -> { currentYear = years.get(which); updateYearMonthButtons(); loadDatesForCurrentMonth(); }) .show(); } private void showMonthPicker() { new AlertDialog.Builder(this) .setTitle("选择月份") .setItems(new String[]{"01", "02", "03", "04", "05", "06", "07", "08", "09", "10", "11", "12"}, (dialog, which) -> { currentMonth = which + 1; updateYearMonthButtons(); loadDatesForCurrentMonth(); }) .show(); } private void loadDatesForCurrentMonth() { try { // 使用动态获取的站点ID String deviceCode = URLEncoder.encode(currentStationId, "UTF-8"); Calendar cal = Calendar.getInstance(); cal.set(currentYear, currentMonth - 1, 1, 0, 0, 0); String startTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(cal.getTime()); cal.set(Calendar.DAY_OF_MONTH, cal.getActualMaximum(Calendar.DAY_OF_MONTH)); cal.set(Calendar.HOUR_OF_DAY, 23); cal.set(Calendar.MINUTE, 59); cal.set(Calendar.SECOND, 59); String endTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(cal.getTime()); String url = "http://nyzbwlw.com/situation/http/device/mouse/getMouseList" + "?deviceCode=" + deviceCode + "&startTime=" + URLEncoder.encode(startTime, "UTF-8") + "&endTime=" + URLEncoder.encode(endTime, "UTF-8") + "&size=10000"; progressBar.setVisibility(View.VISIBLE); JsonObjectRequest request = new JsonObjectRequest( Request.Method.GET, url, null, this::handleDateResponse, this::handleDateError); request.setRetryPolicy(new DefaultRetryPolicy(15000, 3, 1.5f)); requestQueue.add(request); } catch (Exception e) { progressBar.setVisibility(View.GONE); Toast.makeText(this, "时间参数错误", Toast.LENGTH_SHORT).show(); } } private void handleIntentData() { Intent intent = getIntent(); if (intent != null) { currentStationId = intent.getStringExtra("nsiteid"); stationName = intent.getStringExtra("sitealiasname"); // Log.d("GkdActivity", "Received nsiteid: " + currentStationId); // Log.d("GkdActivity", "Received sitealiasname: " + stationName); if (currentStationId == null || currentStationId.isEmpty()) { Toast.makeText(this, "未获取到监测点ID", Toast.LENGTH_SHORT).show(); setResult(RESULT_CANCELED); supportFinishAfterTransition(); return; } } else { Toast.makeText(this, "未获取到启动参数", Toast.LENGTH_SHORT).show(); finish(); } } private void handleDateResponse(JSONObject response) { progressBar.setVisibility(View.GONE); try { if (!response.has("code") || response.getInt("code") != 100) { handleDataError("服务器响应异常"); return; } JSONObject data = response.optJSONObject("data"); if (data == null || !data.has("list")) { handleDataError("数据结构异常"); return; } Set<String> dateSet = new HashSet<>(); JSONArray list = data.getJSONArray("list"); for (int i = 0; i < list.length(); i++) { String time = list.getJSONObject(i).optString("collectionTime", "") .replace("T", " "); // 处理可能存在的ISO格式时间 if (time.length() >= 10) { dateSet.add(time.substring(0, 10)); } } List<String> dates = new ArrayList<>(dateSet); Collections.sort(dates, Collections.reverseOrder()); dateList.setAdapter(new ArrayAdapter<>(this, android.R.layout.simple_list_item_1, dates)); dateList.setOnItemClickListener((parent, view, position, id) -> { currentDate = dates.get(position); loadImages(); }); if (!dates.isEmpty()) { currentDate = dates.get(0); loadImages(); } } catch (JSONException e) { handleDataError("数据格式错误"); } } private void loadImages() { progressBar.setVisibility(View.VISIBLE); try { String startTime = currentDate + " 00:00:00"; String endTime = currentDate + " 23:59:59"; String url = "http://nyzbwlw.com/situation/http/device/mouse/getMouseList" + "?deviceCode=" + URLEncoder.encode(currentStationId, "UTF-8") + "&startTime=" + URLEncoder.encode(startTime, "UTF-8") + "&endTime=" + URLEncoder.encode(endTime, "UTF-8"); JsonObjectRequest request = new JsonObjectRequest( Request.Method.GET, url, null, this::handleImageResponse, this::handleImageError); request.setRetryPolicy(new DefaultRetryPolicy(15000, 3, 1.5f)); requestQueue.add(request); } catch (UnsupportedEncodingException e) { progressBar.setVisibility(View.GONE); Toast.makeText(this, "时间参数错误", Toast.LENGTH_SHORT).show(); } } private void handleImageResponse(JSONObject response) { progressBar.setVisibility(View.GONE); try { if (response.getInt("code") == 100) { JSONArray list = response.getJSONObject("data").getJSONArray("list"); List<String> imageUrls = new ArrayList<>(); List<String> imageTimes = new ArrayList<>(); for (int i = 0; i < list.length(); i++) { JSONObject item = list.getJSONObject(i); imageUrls.add(item.getString("pictureUrl")); String rawTime = item.optString("collectionTime", ""); imageTimes.add(rawTime.substring(11, 19)); } // 使用新的适配器方式 updateImageGrid(imageUrls, imageTimes); } } catch (JSONException e) { handleDataError("图片数据解析失败"); } } // 替换RecyclerView为动态添加视图 private void updateImageGrid(List<String> imageUrls, List<String> imageTimes) { imageGrid.removeAllViews(); // 清除旧视图 imageGrid.setColumnCount(2); // 2列网格 int spacing = getResources().getDimensionPixelSize(R.dimen.grid_spacing); int availableWidth = getResources().getDisplayMetrics().widthPixels - getResources().getDimensionPixelSize(R.dimen.left_nav_width); // 新计算公式:总可用宽度 - 4个间隔(左右各1 + 中间2) int imageSize = (availableWidth - spacing * 4) / 2; int textHeight = (int) (30 * getResources().getDisplayMetrics().density); for (int i = 0; i < imageUrls.size(); i++) { View itemView = LayoutInflater.from(this).inflate(R.layout.grid_item_image, null); ImageView imageView = (ImageView) itemView.findViewById(R.id.image_view); TextView fileNameText = (TextView) itemView.findViewById(R.id.file_name); String displayTime = imageTimes.get(i) != null ? imageTimes.get(i) : "--:--:--"; fileNameText.setText(displayTime); // 设置图片大小 imageView.getLayoutParams().width = imageSize; imageView.getLayoutParams().height = imageSize; // 使用Glide加载图片并添加错误处理 final String url = imageUrls.get(i); Glide.with(this) .load(url) .override(imageSize, imageSize) .centerCrop() .placeholder(R.drawable.placeholder) .error(R.drawable.error_image) .into(imageView); // 设置点击事件 itemView.setOnClickListener(v -> showFullscreenImage(url)); // 添加视图到网格 // GridLayout.Spec rowSpec = GridLayout.spec(i / 2); // GridLayout.Spec colSpec = GridLayout.spec(i % 2); GridLayout.LayoutParams params = new GridLayout.LayoutParams( GridLayout.spec(i / 2), GridLayout.spec(i % 2) ); params.width = imageSize; params.height = imageSize + textHeight; params.setMargins(spacing, spacing, spacing, spacing); imageGrid.addView(itemView, params); } } private void handleDateError(VolleyError error) { progressBar.setVisibility(View.GONE); handleNetworkError(error, "日期加载失败"); } private void handleImageError(VolleyError error) { progressBar.setVisibility(View.GONE); handleNetworkError(error, "图片加载失败"); } private void handleNetworkError(VolleyError error, String prefix) { String message = prefix + ": "; if (error instanceof TimeoutError) { message += "请求超时(请检查网络)"; } else if (error instanceof NoConnectionError) { message += "网络未连接"; } else if (error instanceof ServerError) { message += "服务器错误(HTTP " + error.networkResponse.statusCode + ")"; } else if (error instanceof AuthFailureError) { message += "认证失败(请检查权限)"; } else if (error instanceof ParseError) { message += "数据解析异常(请检查API格式)"; } else { message += "未知错误"; } Toast.makeText(this, message, Toast.LENGTH_LONG).show(); } private void handleDataError(String message) { Toast.makeText(this, message, Toast.LENGTH_SHORT).show(); } private void showFullscreenImage(String imageUrl) { fullscreenContainer.setVisibility(View.VISIBLE); progressBar.setVisibility(View.VISIBLE); // fullImageView.resetMatrix(); // 使用Glide加载全屏图片 Glide.with(this) .load(imageUrl) .listener(new RequestListener<String, GlideDrawable>() { @Override public boolean onException(Exception e, String model, Target<GlideDrawable> target, boolean isFirstResource) { progressBar.setVisibility(View.GONE); // 显示错误图片 fullImageView.setImageResource(R.drawable.error_image); return true; // 消费异常事件 } @Override public boolean onResourceReady(GlideDrawable resource, String model, Target<GlideDrawable> target, boolean isFromMemoryCache, boolean isFirstResource) { // 延迟执行确保视图已布局 fullImageView.post(() -> { fullImageView.resetMatrix(); progressBar.setVisibility(View.GONE); }); return false; } }) .error(R.drawable.error_image) .into(fullImageView); } public void closeFullscreen(View view) { fullscreenContainer.setVisibility(View.GONE); } @Override protected void onStop() { super.onStop(); if (requestQueue != null) { requestQueue.cancelAll(REQUEST_TAG); } } } 依据上述代码解决错:Incompatible types. Found: 'android.view.View', required: 'android.widget.Button'
最新发布
06-27
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值