Moodle开发笔记3-Filter开发

2024-04-19 22:48
文章标签 开发 笔记 filter moodle

本文主要是介绍Moodle开发笔记3-Filter开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

Moodle filters 是对修改来自 database content 进行过滤修改后再输出显示。

 

一个例子是 moodle 自带的 multimedia filter ,它能够 detect references to video and audio files ,然后 replace them with a "mini-player" embedded in the content

 

Filter 的工作原理

Moodle 里所有要输出到 screen text 都要经过 format_text function 的处理,该函数会使其 safe to be displayed there are no security issues and that any HTML used contains only allowed tags

 

而且, text还会经过 filter_text function 的处理, 该函数会 apply all enabled filters to 传过来的 text 。该函数返回的是 the result of all of these filters

 

 

下面讲解如何开发一个简单的 filter ,该 filter 会对所有 ” Learning is Fun” 的字眼,都把它转化成带指向 http://2fun2learn.org link

 

1. create “learningisfunlink” folder ( 目录名是你的 filter name) in ”moodle/filter” folder

 

2. create “filter.php” under ”learningisfunlink” folder

filter.php 只需要添加一个函数 learningisfunlink_filter ”  ( 格式为 [filter_name]_filter ) ,该函数带有 2 个参数: course ID and 要过滤的 text 。下面的例子是最简单的 filter ,就是把 text 原样输出。

<?php

function learningisfunlink_filter($courseid, $text) {

return $text;

}

?>

 

3. (Optional) add language file language file详见 block开发)

如果不使用 language file,那么在 filter manage page里显示该 filter name就是learningisfunlink ,但如果我们的 lang/en_utf8/filter_learningisfunlink.php 里添加下列的 code

$string['filtername'] = "Main website link";

那么在 filter manage page里该 filter name "Main website link "

 

4. 修改步骤 2 filter.php learningisfunlink_filter函数 ,使得碰到 ” Learning is Fun” 的字眼就转成 link

 

会用到 /lib/filterlib.php file 里的 filterobject class and the filter_phrases function .

 

filterobject class 定义了一个 object 来包含所有 filter_phrases function 所要的 info

·         filter string

·         the tag to start the replacement with

·         the tag to end the replacement with

·         whether to match case (optional)

·         whether a full match is required (optional)

·         any replacement text for the match

 

filter_phrases($text, $filterobjects) 函数是根据参数 $filterobjects it is an array )来处理第一个参数的 text ,然后返回处理后的 string

 

修改后的 learningisfunlink_filter函数 代码为

function learningisfunlink_filter($courseid, $text) {

//create filterobjects obj

$searchphrase = "learning is fun";

$starttag = "<a href=/"http://2fun2learn.org/">";

$endtag = "</a>";

$filterobjects = array();

$filterobjects[] = new filterobject($searchphrase, $starttag, $endtag);

 

// change any occurrence of the phrase "learning is fun" to a hyperlinked phrase

return filter_phrases($text, $filterobjects);

}

 

注意: filter 要先在 ”Site Administration Block -> Modules -> Filters -> Manage filters” activate 才可使用。

 

 

5. add configuration settings 我们希望能够动态的设置要添加 link 的字串,而不是设死是 ” Learning is Fun” 。同时能够动态设置 link url 。因此我们就要使 filter 具有 configuration 的功能(这样在 filter manage page 里该 filter 就会 多一个 ”setting” link )。

 

1) 添加一个 filtersettings.php under ”learningisfunlink” folder 。当你创建了该文件后,该 filter manage page 里马上就会出现 ”setting” link

 

filtersettings.php会用到 $settings variable and admin_settingpage class

 

$settings 变量 是由 moodle帮我们创建的( /admin/settings/plugins.php里创建 ),该变量是一个数组类型,它包含 class admin_settingpage的对象元素

 

那么 我们的 filter configuration设置的东东,就会被 wrap into a admin_settingpage object,然后添加到变量 $settings

 

admin_setting_configtext 的构造方法为

admin_setting_configtext($name, $visiblename, $description, $defaultsetting,

                                                                        $paramtype=PARAM_RAW, $size=null)

第一个参数最为关键,它相当于 key ,必须在 $settings 里是唯一的。它的格式应该为 [module_type]_[module_name]_key 。例如该例中的 filter_learningisfunlink_phrase

 

因此修改后的 filtersettings.php 为:

<?php

    $settings->add(new admin_setting_configtext('filter_learningisfunlink_phrase',

                   'Phrase', 'Phrase to hyperlink ', 'learning is fun '));

 

    $settings->add(new admin_setting_configtext('filter_learningisfunlink_link',

                   'url', 'URL to link phrase to ', 'http://2fun.org'));

?>

 

对于上面的代码,当你进入该 filter configuration page 时,就会有 2 textbox ,它们的 name 分别为“ filter_learningisfunlink_phrase and filter_learningisfunlink_link ”,当你 submit 时,这 2 text box 的值就会自动付给“ filter_learningisfunlink_phrase and filter_learningisfunlink_link ”的 admin_setting_configtext 变量,并把这 2 个变量添加到 $CFG 变量里(见下面的代码就清楚) .

 

注意:使用 admin_setting_configtext ,对应的就会在 configuration page 里出现 text box 供你设置。如果你希望使用其他类型的设置,可以使用下列 class

·         admin_setting_configselect 用于 list box设置

·         admin_setting_configtextarea 用于 text area设置

等。

 

 

2) 上面的步骤的 configuration 设置好之后,设置的变量被存到 $CFG 里了。我们应该修改 filter.php 来使用它们

 

global $CFG;

if (!isset ($CFG->filter_learningisfunlink_phrase )) {

set_config ( 'filter_learningisfunlink_phrase',

get_string('phrasedefault', 'filter_learningisfunlink'));

}

if (!isset($CFG->filter_learningisfunlink_link)) {

set_config( 'filter_learningisfunlink_link',

get_string('linkdefault', 'filter_learningisfunlink'));

}

 

$searchphrase = $CFG->filter_learningisfunlink_phrase ;

$starttag = "<a href=/"{$CFG->filter_learningisfunlink_link}/">";

$endtag = "</a>";

 

$filterobjects = array();

$filterobjects[] = new filterobject($searchphrase, $starttag, $endtag);

 

return filter_phrases($text, $filterobjects);

 

注意:上面的代码会先 check $CFG 里是否存在我们想要的设置的 key ,如果不存在,就通过 set_config 函数往 $CFG 里添加该 key with default value

 

这篇关于Moodle开发笔记3-Filter开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/918652

相关文章

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

基于Python开发PPTX压缩工具

《基于Python开发PPTX压缩工具》在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,不便于传输和存储,所以本文将使用Python开发一个PPTX压缩工具,需要的可以了解下... 目录引言全部代码环境准备代码结构代码实现运行结果引言在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

C#图表开发之Chart详解

《C#图表开发之Chart详解》C#中的Chart控件用于开发图表功能,具有Series和ChartArea两个重要属性,Series属性是SeriesCollection类型,包含多个Series对... 目录OverviChina编程ewSeries类总结OverviewC#中,开发图表功能的控件是Char

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE

Python开发围棋游戏的实例代码(实现全部功能)

《Python开发围棋游戏的实例代码(实现全部功能)》围棋是一种古老而复杂的策略棋类游戏,起源于中国,已有超过2500年的历史,本文介绍了如何用Python开发一个简单的围棋游戏,实例代码涵盖了游戏的... 目录1. 围棋游戏概述1.1 游戏规则1.2 游戏设计思路2. 环境准备3. 创建棋盘3.1 棋盘类