首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >android学习笔记----短信发送器

android学习笔记----短信发送器

作者头像
砖业洋__
发布于 2023-05-06 11:03:57
发布于 2023-05-06 11:03:57
65700
代码可运行
举报
文章被收录于专栏:博客迁移同步博客迁移同步
运行总次数:0
代码可运行

短信发送器demo地址:https://github.com/liuchenyang0515/SmsSend

模拟效果:

       我们初步想要的功能就是ListView显示一些数据,点击这些数据后想要发送一些祝福短信,要求把这些内容直接显示在发送短信界面的编辑框内,方便发送,因为这个不是我们自己写的界面,所以用隐式意图。为了查找putExtra的键,我们需要查看系统源码。 

MainActivity.java

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;

public class MainActivity extends AppCompatActivity {
    String[] s = {"真心的编织快乐,细心的装满幸福,小心的盛上吉祥,用心的放入喜庆,耐心的把它们进行包装,诚心的用短信发送给你...",
            "周末又已来到,祝福轮番开炮,瞄准劳累之敌,把疲惫郁闷轰掉,打响开心号弹,吹起愉悦号角,冲向快乐山头,让舒畅飘扬高高...",
            "人生忙忙碌碌,日子酸酸甜甜,缘分简简单单,联系断断续续,惦记时时刻刻,祝福长长久久,天天开开心心,祝你平平安安,周末愉快!",
            "勤勤工作,兢兢业业报国志。肯肯上进,升职加薪见几人?东奔西跑,忙忙碌碌周身痛..."};

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        // 找到lv
        ListView lv = (ListView) findViewById(R.id.lv);
        // 设置数据
        ArrayAdapter<String> adapter = new ArrayAdapter<>(this, R.layout.item, s);
        // 设置数据适配器
        lv.setAdapter(adapter);
        // 给listview设置点击事件
        lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                // 把点击条目数据取出来,数据在哪里存着就去哪里取
                String content = s[position];

                // 跳转到发送短信的页面
                // 查询源码得到意图过滤器
                // 源码查看地址https://www.androidos.net.cn/android/8.0.0_r4/xref/packages/apps/Messaging/AndroidManifest.xml
                /*<intent-filter
                android:label="@string/share_intent_label">
                <action android:name="android.intent.action.SEND" />
                <category android:name="android.intent.category.DEFAULT" />
                <data android:mimeType="text/plain" />
                <data android:mimeType="text/x-vCard" />
                <data android:mimeType="text/x-vcard" />
                <data android:mimeType="image/*" />
                <data android:mimeType="audio/*" />
                <data android:mimeType="application/ogg" />
                </intent-filter>*/
                Intent intent = new Intent();
                // 设置action
                intent.setAction("android.intent.action.SEND");
                // 添加category
                intent.addCategory("android.intent.category.DEFAULT");
                // 设置type
                intent.setType("text/plain");
                // 传递数据
                intent.putExtra(Intent.EXTRA_TEXT, content);
                // 跳转到发送短信的页面
                startActivity(intent);
            }
        });
    }
}

查找到android系统源码目录:packages/apps/Messaging/AndroidManifest.xml

地址:

https://www.androidos.net.cn/android/8.0.0_r4/xref/packages/apps/Messaging/AndroidManifest.xml

查找动作android.intent.action.SEND去匹配,发现如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        <!-- Handles sharing intent -->
        <activity
            android:name=".ui.conversationlist.ShareIntentActivity"
            android:configChanges="orientation|screenSize|keyboardHidden"
            android:screenOrientation="user"
            android:theme="@style/BugleTheme.DialogActivity"
            android:excludeFromRecents="true"
            android:documentLaunchMode="always">
            <intent-filter
                android:label="@string/share_intent_label">
                <action android:name="android.intent.action.SEND" />
                <category android:name="android.intent.category.DEFAULT" />
                <data android:mimeType="text/plain" />
                <data android:mimeType="text/x-vCard" />
                <data android:mimeType="text/x-vcard" />
                <data android:mimeType="image/*" />
                <data android:mimeType="audio/*" />
                <data android:mimeType="application/ogg" />
            </intent-filter>
            <intent-filter
                    android:label="@string/share_intent_label">
                <action android:name="android.intent.action.SEND_MULTIPLE" />
                <category android:name="android.intent.category.DEFAULT" />
                <data android:mimeType="image/*" />
            </intent-filter>
        </activity>

看到这个动作是ui.conversationlist.ShareIntentActivity里面的,然后去这个里面找接收数据的键来确定我们发送数据的键是什么。

是哪个包下面的呢?

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.android.messaging"
    android:installLocation="internalOnly">

原来是com.android.messaging包底下的

即package com.android.messaging.ui.conversationlist;

网页地址:

https://www.androidos.net.cn/android/8.0.0_r4/xref/packages/apps/Messaging/src/com/android/messaging/ui/conversationlist/ShareIntentActivity.java

找到之后,在网页中查找getStringExtra去匹配文本

发现了一个Intent.EXTRA_TEXT,这就是我们想要的键

然后putExtra进去的就是这个键。

activity_main.xml

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <ListView
        android:id="@+id/lv"
        android:layout_width="match_parent"
        android:layout_height="match_parent"></ListView>
</LinearLayout>

 item.xml

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<?xml version="1.0" encoding="utf-8"?>
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" />

运行结果(真机测试):

点击一个item,分享到“信息”

然后发现item里面的内容已经在编辑框内了。

短信发送器:

MainActivity.java

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import android.Manifest;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.support.annotation.NonNull;
import android.support.v4.app.ActivityCompat;
import android.support.v4.content.ContextCompat;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.telephony.SmsManager;
import android.view.View;
import android.widget.EditText;
import android.widget.Toast;

import java.util.List;

public class MainActivity extends AppCompatActivity {

    private EditText et_number;
    private EditText et_content;
    private static final int REQUESTCODE_ADD = 1;
    private static final int REQUESTCODE_INSERT = 2;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        // 找到控件
        et_number = (EditText) findViewById(R.id.et_number);
        et_content = (EditText) findViewById(R.id.et_content);
    }

    public void onclick(View view) {
        switch (view.getId()) {
            case R.id.btn_add:
                Intent intent = new Intent(this, ContactActivity.class);
                startActivityForResult(intent, REQUESTCODE_ADD);
                break;
            case R.id.btn_send:
                // 获取动态权限
                if (ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.SEND_SMS)
                        != PackageManager.PERMISSION_GRANTED) {
                    ActivityCompat.requestPermissions(MainActivity.this, new String[]{Manifest.permission.SEND_SMS}, 1);
                } else {
                    sendSms();
                }
                break;
            case R.id.btn_insert:
                Intent intent2 = new Intent(this, SmsTemplateActivity.class);
                startActivityForResult(intent2, REQUESTCODE_INSERT);
                break;
        }
    }

    private void sendSms() {
        // 获取发送短信的号码和发送的内容
        String number = et_number.getText().toString().trim();
        String content = et_content.getText().toString().trim();
        // 获取SmsManager实例
        SmsManager smsManager = SmsManager.getDefault();
        List<String> divideMessage = smsManager.divideMessage(content);
        for (String div : divideMessage) {
            smsManager.sendTextMessage(number, null, div, null, null);
        }
    }

    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        switch (requestCode) {
            case 1:
                if (grantResults.length > 0) {
                    for (int result : grantResults) {
                        if (result != PackageManager.PERMISSION_GRANTED) {
                            if (ActivityCompat.shouldShowRequestPermissionRationale(this,
                                    Manifest.permission.SEND_SMS)) {
                                showPermissionDialog(permissions);
                            } else {
                                Toast.makeText(this, "您已拒绝权限,请在设置手动打开权限", Toast.LENGTH_SHORT).show();
                            }
                            return;
                        }
                    }
                    sendSms();
                }
                break;
        }
    }

    private void showPermissionDialog(final String[] permissions) {
        AlertDialog.Builder dialog = new AlertDialog.Builder(this);
        dialog.setTitle("提示!");
        dialog.setMessage("这个权限关系到发送短信,如拒绝需要在设置手动打开!");
        dialog.setCancelable(false);
        dialog.setPositiveButton("授权", new DialogInterface.OnClickListener() {
            @Override
            public void onClick(DialogInterface dialog, int which) {
                ActivityCompat.requestPermissions(MainActivity.this, permissions, 1);
            }
        });
        dialog.setNegativeButton("拒绝", new DialogInterface.OnClickListener() {
            @Override
            public void onClick(DialogInterface dialog, int which) {

            }
        });
        dialog.show();
    }

    // 当我们开启的activity页面关闭的时候调用此方法
    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        switch (requestCode) {
            case REQUESTCODE_ADD:
                if (resultCode == RESULT_OK) {
                    String phone = data.getStringExtra("phone");
                    et_number.setText(phone);
                }
                break;
            case REQUESTCODE_INSERT:
                if (resultCode == RESULT_OK) {
                    String smsContent = data.getStringExtra("smsContent");
                    //et_content.setText(smsContent);
                    et_content.append(smsContent);
                }
                break;
        }
    }
}

批注:

public void sendTextMessage (String destinationAddress, String scAddress,

String text, PendingIntent sentIntent, PendingIntent deliveryIntent)

发送基于短信的文本。

注:使用此方法需要您的应用程序具有Manifest.permission.SEND_SMS许可。

注:从Android4.4开始(API级别19),如果只有当不选择应用程序作为默认SMS应用程序,系统会自动将使用此方法发送的消息写入SMS提供者(默认SMS应用始终负责将其发送的消息写入SMS提供程序)。有关如何作为默认SMS应用程序运行的信息,请参阅Telephony.

参数

destinationAddress

String:要发送消息的地址

scAddress

String:是服务中心地址或null以使用当前默认SMSC

text

String:要发送的消息正文

sentIntent

PendingIntent:如果不为空,则为PendingIntent消息成功发送或失败时广播。结果代码将是Activity.RESULT_OK对于成功,或其中的一个错误:RESULT_ERROR_GENERIC_FAILURERESULT_ERROR_RADIO_OFFRESULT_ERROR_NULL_PDU 为RESULT_ERROR_GENERIC_FAILURESentIntent可能包含无线电技术特定值的额外“错误代码”,通常只对故障排除有用。 基于每个应用程序的SMS控制检查哨兵。如果SentIntent为NULL,调用者将根据所有未知的应用程序进行检查,这将导致在检查期间发送较少数量的SMS。

deliveryIntent

PendingIntent:如果不为空,则为PendingIntent消息传递到收件人时广播。状态报告的原始PDU位于扩展数据(“PDU”)中。

抛出

IllegalArgumentException

如果destinationAddress或Text为空

短信太长就会分成几封发送出去,所以要用divideMessage

public ArrayList<String> divideMessage (String text)

将一个消息文本分成几个片段,没有一个大于最大SMS消息大小。

参数

text

String:原始信息。不能是空的。

回报

ArrayList<String>

阿ArrayList的字符串,按顺序组成原始消息。

抛出

IllegalArgumentException

如果文本为空

ContactActivity.java

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;

import java.util.ArrayList;
import java.util.List;

public class ContactActivity extends AppCompatActivity {

    private List<Person> lists;
    private ListView lv;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        // 加载布局
        setContentView(R.layout.activity_contact);
        lv = (ListView) findViewById(R.id.lv);
        lists = new ArrayList<>();
        for (int i = 0; i < 20; ++i) {
            Person p = new Person();
            p.setName("张三");
            p.setPhone("11" + i);
            lists.add(p);
        }
        // 展示数据
        lv.setAdapter(new Myadapter());
        // 给listview设置点击事件
        lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            // parent代表listview,view代表item,可在断点调试验证
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                // 获取点中item的数据
                String phone = lists.get(position).getPhone();
                // 把数据返回给调用者
                Intent intent = new Intent();
                intent.putExtra("phone", phone);
                // 把结果返回给调用者
                setResult(RESULT_OK, intent);
                // 关闭当前页面
                finish(); // finish后通过onActivityResult返回数据

            }
        });
    }

    @Override
    public void onBackPressed() {

    }

    private class Myadapter extends BaseAdapter {

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

        @Override
        public Object getItem(int position) {
            return null;
        }

        @Override
        public long getItemId(int position) {
            return 0;
        }

        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            View view;
            ViewHolder viewHolder;
            if (convertView == null) {
                // 获取子布局
                view = LayoutInflater.from(getApplicationContext()).inflate(R.layout.contact_item, parent, false);
                viewHolder = new ViewHolder();
                // 找到在item中定义的控件来显示数据
                // 一定要写view.findViewById,findViewById是有上下文的,默认是在Activity的主布局中
                viewHolder.tv_name = (TextView) view.findViewById(R.id.tv_name);
                viewHolder.tv_phone = (TextView) view.findViewById(R.id.tv_phone);
                view.setTag(viewHolder);
            } else {
                view = convertView;
                viewHolder = (ViewHolder) view.getTag();
            }
            // 展示数据
            viewHolder.tv_name.setText(lists.get(position).getName());
            viewHolder.tv_phone.setText(lists.get(position).getPhone());
            return view;
        }

        private class ViewHolder {
            TextView tv_name, tv_phone;
        }
    }
}

 Person.java

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public class Person {
    private String name;
    private String phone;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getPhone() {
        return phone;
    }

    public void setPhone(String phone) {
        this.phone = phone;
    }
}

 SmsTemplateActivity.java

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;

public class SmsTemplateActivity extends AppCompatActivity {
    String[] str = {"我在吃饭,请稍后联系", "我在开会,请稍后联系",
            "我在上课,请稍后联系", "我在加班,请稍后联系","我在约会,请稍后联系"};

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_smstemplate);
        ListView lv = (ListView) findViewById(R.id.lv);
        ArrayAdapter<String> adapter = new ArrayAdapter<>(this, R.layout.smstemplate_item, R.id.tv, str);
        // 显示数据
        lv.setAdapter(adapter);
        // 设置item点击事件
        lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                // 取出点击item的数据
                String smsContent = str[position];
                // 把smsContent返回给调用者
                Intent intent = new Intent();
                intent.putExtra("smsContent", smsContent);
                setResult(RESULT_OK, intent);
                finish();
            }
        });
    }
}

activity_main.xml

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <EditText
            android:id="@+id/et_number"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:hint="请输入手机号码" />

        <Button
            android:id="@+id/btn_add"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignBottom="@id/et_number"
            android:layout_marginBottom="8dp"
            android:layout_alignParentRight="true"
            android:onClick="onclick"
            android:text="+" />
    </RelativeLayout>

    <EditText
        android:id="@+id/et_content"
        android:layout_width="match_parent"
        android:gravity="top"
        android:layout_height="200dp"
        android:hint="请输入发送短信的内容" />

    <Button
        android:id="@+id/btn_insert"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="onclick"
        android:text="插入短信模版"/>

    <Button
        android:id="@+id/btn_send"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="onclick"
        android:text="发送"/>
</LinearLayout>

 activity_contact.xml

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <ListView
        android:id="@+id/lv"
        android:layout_width="match_parent"
        android:layout_height="match_parent"></ListView>
</LinearLayout>

contact_item.xml

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal">

    <TextView
        android:id="@+id/tv_name"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="aaa"
        android:textSize="20sp" />

    <TextView
        android:id="@+id/tv_phone"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="110"
        android:textSize="20sp" />
</LinearLayout>

activity_smstemplate.xml

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <ListView
        android:id="@+id/lv"
        android:layout_width="match_parent"
        android:layout_height="match_parent"></ListView>
</LinearLayout>

smstemplate_item.xml

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <TextView
        android:id="@+id/tv"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textSize="20sp"/>
</LinearLayout>

AndroidManifest.xml

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.sms_send">

    <uses-permission android:name="android.permission.SEND_SMS" />
    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".ContactActivity" />
        <activity android:name=".SmsTemplateActivity" />
    </application>
</manifest>

具体代码见github:https://github.com/liuchenyang0515/SmsSend

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-08-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
提高10倍开发效率?APT如何让Android开发变得更轻松
在Android开发中,APT(Annotation Processing Tool)是一种强大的工具,它可以让开发者在编译期间处理注解,生成额外的代码。通过APT,我们可以实现很多高级功能,比如自动生成代码、实现依赖注入、生成路由表等。本文将深入探讨APT的运用以及背后的原理。
Rouse
2024/03/18
2570
提高10倍开发效率?APT如何让Android开发变得更轻松
【Android APT】注解处理器 ( 根据注解生成 Java 代码 )
Android APT 学习进阶路径 : 推荐按照顺序阅读 , 从零基础到开发简易 ButterKnife 注解框架的学习路径 ;
韩曙亮
2023/03/29
3700
“终于懂了” 系列:组件化框架 ARouter 完全解析(二)APT技术
在上一篇《“终于懂了” 系列:组件化框架 ARouter 完全解析(一) 原理详解》中,详细介绍了ARouter的核心原理。其中提到了“帮助类”的概念,也就是在运行时生成 用于帮助填充WareHouse路由元信息的类,这里就涉及到了APT技术。那么本篇就对这一技术点进行介绍,并详细分析ARouter中是如何使用APT来生成帮助类的。
胡飞洋
2022/11/08
2.2K0
“终于懂了” 系列:组件化框架 ARouter 完全解析(二)APT技术
Android 注解与注解处理器简述
  在Android开发中,注解是非常多的,如果不去了解,你可能感受不到注解的存在,一些框架用到的注解是很多的,例如Butterknife、Retrofit、Dagger2、Hilt、ViewBinding、DataBinding等等,下面简单的来了解一下注解。
晨曦_LLW
2022/10/24
8000
Android 注解与注解处理器简述
组件化专题-APT实战
apt为何如此重要呢?现今越来越多的第三方库使用了apt技术,Dagger2、ButterKnife、ARouter等,在编译时根据annotation生成相关的代码逻辑,动态的生成Java class文件给开发带来了很大的便利。
用户3045442
2018/09/11
9770
组件化专题-APT实战
编译时注解(一)AbstractProcessor实战
Java中的注解(Annotation)是一个很神奇的东西,特别现在有很多Android库都是使用注解的方式来实现的。 我们并不讨论那些在运行时(Runtime)通过反射机制运行处理的注解,而是讨论在编译时(Compile time)处理的注解。下面便入手学习下Java注解处理器。
提莫队长
2019/02/21
7.6K1
自定义Android注解Part2:代码自动生成
上一期我们已经把butterknife-annotations中的注解变量都已经定义好了,分别为BindView、OnClick与Keep。
Rouse
2019/07/16
6820
自定义Android注解Part2:代码自动生成
Butterknife全方位解析
Butterknife是供职于Square公司的JakeWharton大神开发的开源库,使用这个库,在AS中搭配Android ButterKnife Zelezny插件,可以大大提高开发的效率,从此摆脱繁琐的findViewById(int id),也不用自己手动@bind(int id) , 直接用插件生成即可。本篇博客将对Butterknife进行深入解析。
老马的编程之旅
2022/06/22
8100
Butterknife全方位解析
聊聊AbstractProcessor和Java编译流程
我:我写过一个路由跳转库,我通过了AbstractProcessor生成了路由表的注册类。
逮虾户
2020/10/15
4.9K0
聊聊AbstractProcessor和Java编译流程
【Android APT】注解处理器 ( Element 注解节点相关操作 )
Android APT 学习进阶路径 : 推荐按照顺序阅读 , 从零基础到开发简易 ButterKnife 注解框架的学习路径 ;
韩曙亮
2023/03/29
3010
【Android APT】注解处理器 ( Element 注解节点相关操作 )
Annotation Processor
要了解Annotation Processor,首先需要先了解什么是 Annotation。 Annotation : 是 Java 注解。 例如常见的 @Override @Nullable 等, 可以对类或者字段进行标记。 这些标记可以在反射时读取 或者 通过 Annotation Processor进行解析来自动生成一些对应的代码。
艳龙
2021/12/16
6260
【Android 组件化】路由组件 ( 注解处理器中使用 JavaPoet 生成代码 )
在 【Android 组件化】路由组件 ( 注解处理器获取被注解的节点 ) 博客中 声明了 支持的注解类型 , 并在 Activity 中使用了注解 , 在 注解处理器 中检测出来使用注解的 类节点 TypeElement ;
韩曙亮
2023/03/29
6090
【Android 组件化】路由组件 ( 注解处理器中使用 JavaPoet 生成代码 )
用kotlin实现activity路由框架的ProcessorProcessor的原理下载安装特性使用方法总结
页面路由框架,无论在android还是在iOS的开发中都是很常见的模块与模块之间的解耦工具,特别是对中大型App而言,基本上都会有自己的路由框架。
fengzhizi715
2018/08/24
7970
用kotlin实现activity路由框架的ProcessorProcessor的原理下载安装特性使用方法总结
手写 ButterKnife BindView
先建三个module,分别为Butterknife ButterKnife-Annotions ButterKnife-compiler,其中butterknife为Android Module其余的都是Java Module 。
曾大稳
2018/09/11
6250
Android APT(编译时代码生成)最佳实践
越来越多第三方库使用apt技术,如DBflow、Dagger2、ButterKnife、ActivityRouter、AptPreferences。在编译时根据Annotation生成了相关的代码,非常高大上但是也非常简单的技术,可以给开发带来了很大的便利。
用户1269200
2018/07/30
1.4K0
手把手教你实现Android编译期注解
从早期令人惊艳的ButterKnife,到后来的以ARouter为首的各种路由框架,再到现在谷歌大力推行的Jetpack组件,越来越多的第三方框架都在使用编译期注解这门技术,可以说不管你是想要深入研究这些第三方框架的原理 还是要成为一个Android高级开发工程师,编译期注解都是你不得不好好掌握的一门基础技术。
2020labs小助手
2021/07/27
5450
【Android 组件化】路由组件 ( 组件间共享的服务 )
路由除了支持 Activity 之外 , 还要支持 组件间共享的服务 如 工具类 , 逻辑功能 等 ;
韩曙亮
2023/03/29
1.1K0
【Android 组件化】路由组件 ( 组件间共享的服务 )
ButterKnife原理解析看这篇文章就够了
ButterKnife 算是一款知名老牌 Android 开发框架了,通过注解绑定视图,避免了 findViewById() 的操作,广受好评!由于它是在编译时对注解进行解析完成相关代码的生成,所以在项目编译时会略耗时,但不会影响运行时的性能。接下来让我们从使用到原理一步步深入了解这把黄油刀的故事! 以下内容基于 butterknife:8.8.1 版本,主要包括如下几个方面的内容:
用户1269200
2018/08/14
2.5K0
apt 与 JavaPoet 自动生成代码
吴涛
2017/10/26
4.7K0
apt 与 JavaPoet 自动生成代码
【Android 组件化】路由组件 ( 注解处理器获取被注解的节点 )
在 【Android 组件化】路由组件 ( 路由组件结构 ) 博客中介绍了组件化中的 " 路由组件 " , 分为 " 自定义注解模块 " , " 注解处理器模块 " , " 依赖库模块 " 3 个模块 ;
韩曙亮
2023/03/29
4790
【Android 组件化】路由组件 ( 注解处理器获取被注解的节点 )
推荐阅读
相关推荐
提高10倍开发效率?APT如何让Android开发变得更轻松
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验