自定义对话框使用静态Handler传递参数

直接贴代码:

JsdMainDialog.java

package com.jsd.demo;

import android.app.Activity;
import android.content.Context;
import android.graphics.Color;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;

/**
*
* @author jiangshide
*
*/
public class JsdMainDialog extends Activity {

private Context mContext;

private Button mSub;
private TextView mResultValue;

public static Handler handler = new Handler();

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
getViewById();
}

public void getViewById(){
mContext = this;
mSub = (Button) this.findViewById(R.id.sub);
mResultValue = (TextView) this.findViewById(R.id.resultValue);
mResultValue.setText("没有通过Handler处理");
mSub.setOnClickListener(listener);
}

private OnClickListener listener = new OnClickListener() {
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.sub:
final String flag = "rqbackvalue";
DialogCustomer dc = new DialogCustomer(mContext,flag);
dc.show();
handler = new Handler(){
public void handleMessage(Message msg) {
String resultFlag = msg.getData().getString("flags");
if(resultFlag.equalsIgnoreCase(flag)){
mResultValue.setText("这是通过Handler处理过后来显示数据的");
mResultValue.setTextColor(Color.CYAN);
mResultValue.setTextSize(30);
}
};
};
break;

default:
break;
}
}
};
}

DialogCustomer.java:

package com.jsd.demo;

import android.app.Dialog;
import android.content.Context;
import android.os.Bundle;
import android.os.Message;
import android.view.View;
import android.widget.Button;

/**
*
* @author jiangshide
*
*/
public class DialogCustomer extends Dialog {

private Context mContext;

private Button ok;
String flag;

public DialogCustomer(Context c,String flag) {
super(c);
this.mContext = c;
this.flag = flag;
}

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.dialog);
getViewById();
}

public void getViewById(){
ok = (Button) this.findViewById(R.id.dialog_ok);
ok.setOnClickListener(listener);
}

private android.view.View.OnClickListener listener = new android.view.View.OnClickListener() {
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.dialog_ok:
Message msg = new Message();//获取设置一个信息保存点
msg.what=1;
msg.getData().putString("flags", flag);
JsdMainDialog.handler.sendMessage(msg);//把数据放进LOOPER队列里
dismiss();
break;
}
}
};
}

dialog.xml:

<?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"
>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="当返回时把参数传递过去并执行判断后的操作"
/>
<Button
android:id="@+id/dialog_ok"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="请点击"
/>
</LinearLayout>

### 使用 TinyMCE 获取上传的 PDF 文件内容 为了实现这一功能,在 Vue 项目中集成 TinyMCE 并配置插件来处理 PDF 文件的上传与解析至关重要。TinyMCE 提供了丰富的 API 和事件机制,允许开发自定义文件上传逻辑并捕获上传后的数据。 #### 配置 TinyMCE 插件支持 PDF 处理 安装 TinyMCE 及其相关依赖后,需确保已加载 `image` 或者更全面的 `importcss`, `media` 等插件以便更好地管理多媒体资源[^1]: ```javascript tinymce.init({ selector: 'textarea', // 替换为实际使用的 HTML 元素选择器 plugins: [ "advlist autolink lists link image charmap print preview anchor", "searchreplace visualblocks code fullscreen", "insertdatetime media table paste imagetools wordcount" ], }); ``` 对于特定需求如 PDF 的导入,则可能需要用到第三方库比如 pdf.js 来读取 PDF 文档中的文本和图像信息[^4]。 #### 自定义文件上传处理器 通过覆盖默认的文件上传行为可以实现对不同类型的文件(包括 PDF)进行特殊处理。这通常涉及到设置 `images_upload_handler` 属性以及编写相应的回调函数用于接收客户端发送过来的数据流,并返回给定 URL 地址或其他形式的结果描述对象。 当用户尝试插入 PDF 到编辑区时,可以通过监听 `FilePickerCallback` 或其他合适的时机触发自定义对话框让用户选取本地计算机上的 PDF 文件;接着利用 FileReader 对象异步读取该文件的内容作为 base64 编码字符串或者其他适合的方式传递至服务器端进一步加工转换成可嵌入网页内的格式[^2]。 #### 解析 PDF 内容展示于编辑区内 一旦获得了经过适当编码后的 PDF 数据,就可以考虑将其转化为静态图片序列或是提取纯文本片段插入到当前光标的所在位置。如果选择了前者的话,那么每一页都可以被渲染成为 `<img>` 标签的一部分,而后者则可以直接追加到现有的 HTML 结构之中[^3]。 需要注意的是,直接显示整个 PDF 文件并非总是最佳实践,因为这样做可能会破坏页面布局或者带来性能问题。因此建议仅预览部分内容或提供下载链接指向原始文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值