Rubber Roller Brush DIY Diamond Painting Brushing Craft Drawing Tools (S)
Rubber Roller Brush DIY Diamond Painting Brushing Craft Drawing Tools (S)
Rubber Roller Brush DIY Diamond Painting Brushing Craft Drawing Tools (S)
Rubber Roller Brush DIY Diamond Painting Brushing Craft Drawing Tools (S)
1 / 4
Rubber Roller Brush DIY Diamond Painting Brushing Craft Drawing Tools (S)
Rubber Roller Brush DIY Diamond Painting Brushing Craft Drawing Tools (S)
Rubber Roller Brush DIY Diamond Painting Brushing Craft Drawing Tools (S)
Rubber Roller Brush DIY Diamond Painting Brushing Craft Drawing Tools (S)
0% OFF
SOD

Rubber Roller Brush DIY Diamond Painting Brushing Craft Drawing Tools (S)

291461.01

$9.99
7 sold
Qty 7 in stock

Descriptions:
It is mainly applicable to DIY clay sculpture and other aspects.
The oil roll for engraving includes three parts: the handle, the bracket and the oil roll body. The oil roll body is made of rubber and has a blind hole in the center of both ends of the oil roll. The bending is performed at a right angle, a rib is provided at the corner, and a protruding portion is respectively formed at the inner sides of the two ends of the bracket. The protruding portion is movable connected with the holes opened at both end surfaces of the oil rolling body, and the handle is disposed on the top surface of the bracket. Reinforcing ribs are also attached to the top of the bracket. 

Features: 
1.The product is made of high elasticity and high toughness rubber.The structure is simple, Flexible and convenient to use, durable and practical.        
2.The roll surface is smooth and the covering power is strong.      
3.Due to the use of high quality components and reasonable structure, it can be used for a long time. 

Specifications:  
Small size: 13.5*12.5*2.5cm/5.31*4.92*0.98"
Material: stainless steel + rubber 

Notes:
1. Due to the different monitor and light effect, the actual color of the item might be slightly different from the color showed on the pictures. Thank you!
2. Please allow slight measuring deviation due to manual measurement.

1 X Roller Brush 

/** @private {string} */ class SpzCustomAnchorScroll extends SPZ.BaseElement { static deferredMount() { return false; } constructor(element) { super(element); /** @private {Element} */ this.scrollableContainer_ = null; } isLayoutSupported(layout) { return layout == SPZCore.Layout.LOGIC; } buildCallback() { this.viewport_ = this.getViewport(); this.initActions_(); } setTarget(containerId, targetId) { this.containerId = '#' + containerId; this.targetId = '#' + targetId; } scrollToTarget() { const container = document.querySelector(this.containerId); const target = container.querySelector(this.targetId); const {scrollTop} = container; const eleOffsetTop = this.getOffsetTop_(target, container); this.viewport_ .interpolateScrollIntoView_( container, scrollTop, scrollTop + eleOffsetTop ); } initActions_() { this.registerAction( 'scrollToTarget', (invocation) => this.scrollToTarget(invocation?.caller) ); this.registerAction( 'setTarget', (invocation) => this.setTarget(invocation?.args?.containerId, invocation?.args?.targetId) ); } /** * @param {Element} element * @param {Element} container * @return {number} * @private */ getOffsetTop_(element, container) { if (!element./*OK*/ getClientRects().length) { return 0; } const rect = element./*OK*/ getBoundingClientRect(); if (rect.width || rect.height) { return rect.top - container./*OK*/ getBoundingClientRect().top; } return rect.top; } } SPZ.defineElement('spz-custom-anchor-scroll', SpzCustomAnchorScroll); const STRENGTHEN_TRUST_URL = "/api/strengthen_trust/settings"; class SpzCustomStrengthenTrust extends SPZ.BaseElement { constructor(element) { super(element); this.renderElement_ = null; } isLayoutSupported(layout) { return layout == SPZCore.Layout.CONTAINER; } buildCallback() { this.xhr_ = SPZServices.xhrFor(this.win); const renderId = this.element.getAttribute('render-id'); SPZCore.Dom.waitForChild( document.body, () => !!document.getElementById(renderId), () => { this.renderElement_ = SPZCore.Dom.scopedQuerySelector( document.body, `#${renderId}` ); if (this.renderElement_) { this.render_(); } this.registerAction('track', (invocation) => { this.track_(invocation.args); }); } ); } render_() { this.fetchData_().then((data) => { if (!data) { return; } SPZ.whenApiDefined(this.renderElement_).then((apis) => { apis?.render(data); document.querySelector('#strengthen-trust-render-1736477762476').addEventListener('click',(event)=>{ if(event.target.nodeName == 'A'){ this.track_({type: 'trust_content_click'}); } }) }); }); } track_(data = {}) { const track = window.sa && window.sa.track; if (!track) { return; } track('trust_enhancement_event', data); } parseJSON_(string) { let result = {}; try { result = JSON.parse(string); } catch (e) {} return result; } fetchData_() { return this.xhr_ .fetchJson(STRENGTHEN_TRUST_URL) .then((responseData) => { if (!responseData || !responseData.data) { return null; } const data = responseData.data; const moduleSettings = (data.module_settings || []).reduce((result, moduleSetting) => { return result.concat(Object.assign(moduleSetting, { logos: (moduleSetting.logos || []).map((item) => { return moduleSetting.logos_type == 'custom' ? this.parseJSON_(item) : item; }) })); }, []); return Object.assign(data, { module_settings: moduleSettings, isEditor: window.self !== window.top, }); }); } } SPZ.defineElement('spz-custom-strengthen-trust', SpzCustomStrengthenTrust);