Fabric.js:如何在画布上取消选择一个或多个对象?

时间:2013-12-09 02:52:54

标签: javascript canvas fabricjs

例如,我在画布上有多个对象, A ,* B *和 C 。其中三个对象被选为激活状态。通过使用Fabric.js,是否可以丢弃/停用一个对象?

例如,选中三个对象,然后单击画布外的按钮时,将丢弃/停用对象B.

我查看了FabricJS官方网站上的doc文件,我只找到 canvas.deactivateAll() canvas.discardActiveObject()。这些函数只能在不是特定活动对象的情况下停用所有活动对象。

有人可以给我一个关于此的指南吗?谢谢!

5 个答案:

答案 0 :(得分:49)

我可能迟到了,但在最新的fabricjs (1.4.3)中,您可以使用以下内容取消选择画布上的所有选定对象。

canvas.deactivateAll().renderAll();

我在创建该画布的图像之前使用它。希望它可以帮到某人。

答案 1 :(得分:13)

假设您有三个对象objectA,ObjectB和ObjectC以及对象被选中。现在,如果要取消选择任何对象(例如ObjectB)。在这种情况下,您可以尝试以下代码。

var activeGroup = canvas.getActiveGroup();
activeGroup.removeWithUpdate(ObjectB);
canvas.renderAll(); 

如果您只有一个节点处于活动状态,那么您可以这样做。

canvas.discardActiveObject();
canvas.renderAll(); 

答案 2 :(得分:11)

要丢弃您可以在功能下使用的所有活动组。当前活动的组和火灾事件如果由于鼠标事件而由结构调用该功能,则该事件将作为参数传递并发送到火灾功能自定义事件。当用作方法时,e param没有任何应用程序。

<div class="col-md-12">
            <div class="portlet light bordered">
                <div class="portlet-body">
                    <form action="{{ $formIs === 'add' ? route('campus-media.save', $campusId) : route('campus-media.update', [$campusId, $campusMedia->id]) }}" method="post" class="form-horizontal" enctype="multipart/form-data">
                    {{ csrf_field() }}
                        <div class="form-body">
                            <div class="form-group">
                                <label class="control-label col-md-3">Title</label>
                                <div class="col-md-4">
                                    {!! Form::text('title', $campusMedia->title, array('class' => 'form-control', 'placeholder' => 'Campus Media Title')) !!}                                        
                                </div>
                            </div>
                        </div>
                        <div class="form-body">
                            <div class="form-group">
                                <label class="control-label col-md-3">Media</label>
                                <div class="col-md-4">
                                    {!! Form::file('media', $campusMedia->media, array('class' => 'form-control')) !!}                                
                                </div>
                            </div>
                        </div>
                        <div class="form-body">
                            <div class="form-group">
                                <label class="control-label col-md-3">Media type</label>
                                    <div class="col-md-4">
                                        {!! Form::select('media_type', $fileType, $campusMedia->media_type,array('placeholder' => 'Choose media type', 'class' => 'form-control')) !!}
                                        <span class="help-block">0: Image, 1: Video, 2: Logo</span>
                                    </div>
                            </div>
                        </div>
                        <div class="form-body">
                            <div class="form-group">
                                <label class="control-label col-md-3">Description</label>
                                <div class="col-md-4">
                                    {!! Form::textarea('description', $campusMedia->description, array('class' => 'form-control', 'placeholder' => 'Campus Media Description', 'rows' => 3)) !!}              
                                </div>
                            </div>
                        </div>
                        <div class="form-body">
                            <div class="form-group">
                                <label class="control-label col-md-3">Status</label>
                                    <div class="col-md-4">
                                        {!! Form::select('status', $status, $campusMedia->status,array('placeholder' => 'Choose status', 'class' => 'form-control')) !!}
                                        <span class="help-block">0: Inactive, 1: Active</span>
                                    </div>
                            </div>
                        </div>
                        <div class="form-body">
                            <div class="form-group">
                                <label class="control-label col-md-3">Tags</label>
                                <div class="col-md-4">
                                    {!! Form::text('tags', $campusMedia->tags, array('class' => 'form-control', 'placeholder' => 'Campus Media Tags')) !!}                                        
                                </div>
                            </div>
                        </div>
                        <div class="form-actions">
                            <div class="row">
                                <div class="col-md-offset-3 col-md-9">
                                    <input type="submit" name="save" class="btn btn-primary" value="Save"/>
                                    <a href="{{ route('campus-media.index', $campusId) }}" class="btn btn-default"> Cancel </a>
                                </div>
                            </div>
                        </div>
                    </form>
                </div>
            </div>
        </div>

要丢弃sigle对象,您可以像这样使用。丢弃当前活动的对象和火灾事件。如果由于鼠标事件而由fabric调用该函数,则该事件将作为parmater传递并发送到fire函数以获取自定义事件。当用作方法时,e param没有任何应用程序。

class CampusMediaController extends Controller
{
//
public function index($campusId)
{
    $campusMedia = CampusMedia::ofCampus($campusId)->get();
    $data = [
        'campusMedia'   => $campusMedia,
        'campusId'      => $campusId
    ];

    return view('campus-media.index', $data);
}

public function add($campusId)
{
    $campusMedia = new CampusMedia;
    $data = [
        'campusMedia' => $campusMedia,
        'campusId'    => $campusId,
        'fileType'    => CampusMedia::getMediaType(),
        'status'      => CampusMedia::getStatus(),
        'formIs'      => 'add'
    ];

    return view('campus-media.form', $data);
}

public function save(Request $request, $campusId)
{
    $this->validation($request);
    $post = $request->all();
    $fileName = $this->upload($request, $campusId);
    $campusMedia = $this->bindToObject($post, $fileName, $campusId);
    $campusMedia->save();

    return redirect()->route('campus-media.index', $campusId)->with('message','Item Succesfully Added');
}

public function edit($campusId, $id)
{
    $campusMedia = CampusMedia::find($id);

    $data = [
        'campusMedia'             => $campusMedia,
        'campusId'                => $campusId,
        'fileType'                => CampusMedia::getMediaType(),
        'status'                  => CampusMedia::getStatus(),
        'formIs'                  => 'edit'
    ];

    return view('campus-media.form', $data);
}

public function update(Request $request,$campusId,$id)
{
    $this->validation($request);
    $post = $request->all();
    $fileName = $this->upload($request, $campusId);
    $campusMedia = $this->bindToObject($post, $fileName,$campusId,$id);
    $campusMedia->save();

    return redirect()->route('campus-media.index', $campusId)->with('message','Item updated Succesfully');
}

public function upload($request, $campusId)
{
    $this->validate($request, [
            'media' => 'mimes:png,jpeg,mp4,avi,mpeg,flv,m4v'
        ]
    );

    if($request->input('media_type') == 0){
        $type = "image";
    }elseif($request->input('media_type') == 1){
            $type = "video";
    }else{
        $type = "logo";
    }

    $file   = $request->file('media');
    if(is_null($file))
        return null;

    $ext = $file->getClientOriginalExtension();


    $fileName    = sprintf('%s-%s-%s.%s',
        $campusId,
        $type,
        time(),
        $ext
    );

    $upload      = config('app.upload_path').'/campus/'.$campusId;
    $file->move($upload,$fileName);

    return $fileName;
}

public function delete($campusId,$id)
{
    $campusMedia = CampusMedia::find($id);
    $campusMedia->delete();

    return redirect()->route('campus-media.index', $campusId)->with('message','Item deleted Succesfully');
}

private function validation($request){
    $this->validate($request, [
            'media' => 'required'
        ]
    );
}

private function bindToObject($post, $fileName,$campusId,$id=null)
{
    if(is_null($id)){
        $campusMedia = new CampusMedia;
    } else {
        $campusMedia = CampusMedia::find($id);
    }

    $campusMedia->campus_id = $campusId;
    $campusMedia->title = $post['title'];
    $campusMedia->media = $fileName;
    $campusMedia->media_type = $post['media_type'];
    $campusMedia->description = $post['description'];
    $campusMedia->status = $post['status'];
    $campusMedia->tags = $post['tags'];

    return $campusMedia;
}

在最后,最后渲染顶部画布和辅助容器画布。

canvas.discardActiveGroup();

答案 3 :(得分:1)

我刚刚找到了这样做的方法:

当激活多个对象时,它们实际上形成了一个组。然后实际上只需要使用一个名为“removeWithUpdate”的fabric.group方法然后就可以了。

示例:

var activeGroup = canvas.getActiveGroup();
activeGroup.removeWithUpdate(theObject);
canvas.renderAll();

答案 4 :(得分:0)

只有更新

canvas.discardActiveObject()