android 学习随笔七(网络:图片及文本传输)

本文介绍了一个Android应用中如何通过子线程进行网络请求,并将数据安全地更新到主线程UI的方法。包括使用Handler机制处理UI更新,实现图片和文本的加载与显示,以及添加缓存机制提高应用性能。

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

  • 主线程、子线程、UI的关系
    • 简单的HTTP请求

    --------------------------------------------------------

    public class MainActivity extends Activity {

    Handler handler = new Handler(){
    //只要消息队列有消息,此方法就会在主线程执行
    public void handleMessage(android.os.Message msg) {
    switch (msg.what) {
    case 1:
    //刷新UI
    //把下载的图片显示
    ImageView iv = (ImageView) findViewById(R.id.iv);
    iv.setImageBitmap((Bitmap)msg.obj);
    break;
    case 2:
    Toast.makeText(MainActivity.this, "请求失败", 0).show();
    break;
    case 3:
    Toast.makeText(MainActivity.this, "连接开始", 0).show();
    break;
    case 4:
    Toast.makeText(MainActivity.this, "连接成功", 0).show();
    break;
    default:
    break;
    }
    };
    };
    @Override
    protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    }

    public void click(View v){
    Thread t= new Thread(){
    @Override
    public void run() {
    //String path="http://192.168.1.106/adtest/11.jpg";
    String path="http://10.0.2.2/adtest/11.jpg";
    //发送HTTP请求
    try {
    //1.使用网址构造一个URL对象
    URL url=new URL(path);
    //获取连接对象
    HttpURLConnection conn = (HttpURLConnection) url.openConnection();
    //设置一些属性
    //设置请求方式
    conn.setRequestMethod("GET");
    //设置请求超时
    conn.setConnectTimeout(8000);
    //设置读取超时
    conn.setReadTimeout(8000);
    handler.sendEmptyMessage(3);
    //发送请求,建立连接
    conn.connect();
    handler.sendEmptyMessage(4);
    //判断请求是否成功
    if(conn.getResponseCode() == 200){
    //获取服务器返回的流,流里就是客户端请求的数据
    InputStream is = conn.getInputStream();
    //读取流里数据,构造出一张图片
    Bitmap bm = BitmapFactory.decodeStream(is);

    //当子线程需要刷新UI时,只需发送一条消息至消息队列
    Message msg = new Message();
    //消息对象可以携带数据
    msg.obj = bm;
    //使用WHAT标注消息类型
    msg.what = 1;
    handler.sendMessage(msg);
    }
    else{
    //如果消息不携带数据,可以用handler发空消息,不用创建Message
    //如果消息池有消息,取出消息池第一条消息(复用空闲消息),返回,如果没有,就NEW一个消息返回
    // Message msg = handler.obtainMessage();
    // msg.what = 2;
    // handler.sendMessage(msg);

    handler.sendEmptyMessage(2);
    }
    } catch (Exception e) {
    e.printStackTrace();
    }
    }
    };
    t.start();
    }
    }

    ------------------------------------------------------------------------------------------

    • 添加缓存机制

    public class MainActivity extends Activity {

    Handler handler = new Handler(){
    //只要消息队列有消息,此方法就会在主线程执行
    public void handleMessage(android.os.Message msg) {
    switch (msg.what) {
    case 1:
    //刷新UI
    //把下载的图片显示
    ImageView iv = (ImageView) findViewById(R.id.iv);
    iv.setImageBitmap((Bitmap)msg.obj);
    break;
    case 2:
    Toast.makeText(MainActivity.this, "请求失败", 0).show();
    break;
    case 3:
    Toast.makeText(MainActivity.this, "连接开始", 0).show();
    break;
    case 4:
    Toast.makeText(MainActivity.this, "连接成功", 0).show();
    break;
    default:
    break;
    }
    };
    };
    @Override
    protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    }

    public void click(View v){
    Thread t= new Thread(){
    @Override
    public void run() {
    //String path="http://192.168.1.106/adtest/11.jpg";
    //String path="http://10.0.2.2/adtest/11.jpg";
    final String path="http://10.0.2.2";
    final File file = new File(getCacheDir() + getFileNameFromPath(path));
    if(file.exists()){
    Bitmap bm = BitmapFactory.decodeFile(file.getAbsolutePath());
    //当子线程需要刷新UI时,只需发送一条消息至消息队列
    Message msg = new Message();
    //消息对象可以携带数据
    msg.obj = bm;
    //使用WHAT标注消息类型
    msg.what = 1;
    handler.sendMessage(msg);

    //在主线程可以直接显示
    // ImageView iv = (ImageView) findViewById(R.id.iv);
    // iv.setImageBitmap((Bitmap)msg.obj);
    }
    else 
    {
    //发送HTTP请求
    try {
    //1.使用网址构造一个URL对象
    URL url=new URL(path);
    //获取连接对象
    HttpURLConnection conn = (HttpURLConnection) url.openConnection();
    //设置一些属性
    //设置请求方式
    conn.setRequestMethod("GET");
    //设置请求超时
    conn.setConnectTimeout(8000);
    //设置读取超时
    conn.setReadTimeout(8000);
    handler.sendEmptyMessage(3);
    //发送请求,建立连接
    //conn.connect();

    //判断请求是否成功(请求时建立连接)
    if(conn.getResponseCode() == 200){
    handler.sendEmptyMessage(4);
    //获取服务器返回的流,流里就是客户端请求的数据
    InputStream is = conn.getInputStream();

    //读取数据(1K),缓存数据
    byte[] b = new byte[1024];
    int len;

    FileOutputStream fos = new FileOutputStream(file);
    while((len = is.read(b)) != -1){
    fos.write(b, 0, len);
    }
    fos.close();
    //读取流里数据,构造出一张图片,缓存把流里的数据读完,流里已经没有数据了
    //Bitmap bm = BitmapFactory.decodeStream(is);

    Bitmap bm = BitmapFactory.decodeFile(file.getAbsolutePath());
    //当子线程需要刷新UI时,只需发送一条消息至消息队列
    Message msg = new Message();
    //消息对象可以携带数据
    msg.obj = bm;
    //使用WHAT标注消息类型
    msg.what = 1;
    handler.sendMessage(msg);
    }
    else{
    //如果消息不携带数据,可以用handler发空消息,不用创建Message
    //如果消息池有消息,取出消息池第一条消息(复用空闲消息),返回,如果没有,就NEW一个消息返回
    // Message msg = handler.obtainMessage();
    // msg.what = 2;
    // handler.sendMessage(msg);

    handler.sendEmptyMessage(2);
    }

    catch (Exception e) {
    e.printStackTrace();
    }
    }
    }
    };
    t.start();
    }

    public String getFileNameFromPath(String path) {
    int index = path.lastIndexOf("/");
    return path.substring(index + 1);
    }
    }

    ------------------------------------------------------------------------------------------------------------

    •  引用现成代码

    https://github.com/loopj/android-smart-image-view

    下载解压拷贝到工程中来

    <RelativeLayout 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"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.ecollab.smartimageview.MainActivity" >

    <Button
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="查看网络图片"
    android:onClick="click"
    />

    <com.loopj.android.image.SmartImageView 
    android:id="@+id/siv"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerInParent="true"
    />

    </RelativeLayout>

    -------------------------------------------------------------------------------

    public void click(View v)
    {
    SmartImageView siv = (SmartImageView) findViewById(R.id.siv);
    //请求网络图片
    siv.setImageUrl("http://10.0.2.2:80/adtest/11.jpg");
    }

     

    •  文本查看器

    ------------------------------------------------------------------------------------------------

    public class Tools {
    public static String getTextFromStream(InputStream is)
    {
    byte[] b = new byte[1024];
    int len;
    ByteArrayOutputStream bos = new ByteArrayOutputStream();
    try {
    while((len = is.read(b)) != -1){
    bos.write(b, 0, len);
    }
    //把字节数组输出流转换成字节数组,然后用字节数组构造一个字符串
    String text = new String(bos.toByteArray());
    //String text = new String(bos.toByteArray(),"gbk");
    return text;
    } catch (Exception e) {
    e.printStackTrace();
    }
    return null;
    }
    }

    --------------------------------------------------------------------------------------------

    public class MainActivity extends Activity {
    Handler handler = new Handler(){
    public void handleMessage(android.os.Message msg) {
    TextView tv = (TextView) findViewById(R.id.tv);
    tv.setText((String)msg.obj);
    };
    };
    @Override
    protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    }

    public void click(View v)
    {
    final String path = "http://10.0.2.2:80/adtest/baidu.html";
    Thread t = new Thread(){
    @Override
    public void run() {
    URL url;
    try {
    //使用网址构造URL
    url = new URL(path);
    HttpURLConnection conn = (HttpURLConnection) url.openConnection();
    conn.setRequestMethod("GET");
    conn.setConnectTimeout(8000);
    conn.setReadTimeout(8000);
    if(conn.getResponseCode() == 200){
    InputStream is = conn.getInputStream();
    String text = Tools.getTextFromStream(is);
    Message msg = handler.obtainMessage();
    msg.obj = text;
    handler.sendMessage(msg);
    }
    }
    catch (Exception e) {
    e.printStackTrace();
    }
    }
    };
    t.start();
    }
    }


内容概要:该论文研究增程式电动汽车(REEV)的能量管理策略,针对现有优化策略实时性差的问题,提出基于工况识别的自适应等效燃油消耗最小策略(A-ECMS)。首先建立整车Simulink模型和基于规则的策略;然后研究动态规划(DP)算法和等效燃油最小策略;接着通过聚类分析将道路工况分为四类,并设计工况识别算法;最后开发基于工况识别的A-ECMS,通过高德地图预判工况类型并自适应调整SOC分配。仿真显示该策略比规则策略节油8%,比简单SOC规划策略节油2%,并通过硬件在环实验验证了实时可行性。 适合人群:具备一定编程基础,特别是对电动汽车能量管理策略有兴趣的研发人员和技术爱好者。 使用场景及目标:①理解增程式电动汽车能量管理策略的基本原理;②掌握动态规划算法和等效燃油消耗最小策略的应用;③学习工况识别算法的设计和实现;④了解基于工况识别的A-ECMS策略的具体实现及其优化效果。 其他说明:此资源不仅提供了详细的MATLAB/Simulink代码实现,还深入分析了各算法的原理和应用场景,适合用于学术研究和工业实践。在学习过程中,建议结合代码调试和实际数据进行实践,以便更好地理解策略的优化效果。此外,论文还探讨了未来的研究方向,如深度学习替代聚类、多目标优化以及V2X集成等,为后续研究提供了思路。
内容概要:论文《基于KANN-DBSCAN带宽优化的核密度估计载荷谱外推》针对统核密度估计(KDE)载荷外推中使用全局固定带宽的局限性,提出了一种基于改进的K平均最近邻DBSCAN(KANN-DBSCAN)聚类算法优化带宽选择的核密度估计方法。该方法通过对载荷数据进行KANN-DBSCAN聚类分组,采用拇指法(ROT)计算各簇最优带宽,再进行核密度估计和蒙特卡洛模拟外推。实验以电动汽车实测载荷数据为对象,通过统计参数、拟合度和伪损伤三个指标验证了该方法的有效性,误差显著降低,拟合度R²>0.99,伪损伤接近1。 适合人群:具备一定编程基础和载荷数据分析经验的研究人员、工程师,尤其是从事汽车工程、机械工程等领域的工作1-5年研发人员。 使用场景及目标:①用于电动汽车载荷谱编制,提高载荷预测的准确性;②应用于机械零部件的载荷外推,特别是非对称载荷分布和多峰扭矩载荷;③实现智能网联汽车载荷预测与数字孪生集成,提供动态更新的载荷预测系统。 其他说明:该方法不仅解决了统KDE方法在复杂工况下的“过平滑”与“欠拟合”问题,还通过自适应参数机制提高了方法的普适性和计算效率。实际应用中,建议结合MATLAB代码实现,确保数据质量,优化参数并通过伪损伤误差等指标进行验证。此外,该方法可扩展至风电装备、航空结构健康监测等多个领域,未来研究方向包括高维载荷扩展、实时外推和多物理场耦合等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值